我正在使用 django rest 框架构建 RESTful API 服务,我已经到了必须为我的 RESTful API 服务创建自动化测试的地步。
sessionList api 需要令牌身份验证,以防用户没有令牌,他将无法访问会话集合。
当我使用 POSTMAN 和真正的浏览器对其进行测试时,该 api 运行良好。
会话列表:
class SessionList(generics.ListCreateAPIView):
authentication_classes = [TokenAuthentication, ]
permission_classes = [IsAuthenticated, ]
throttle_scope = 'session'
throttle_classes = (ScopedRateThrottle,)
name = 'session-list'
filter_class = SessionFilter
serializer_class = SessionSerializer
ordering_fields = (
'distance_in_miles',
'speed'
)
def get_queryset(self):
return Session.objects.filter(owner=self.request.user)
def perform_create(self, serializer):
serializer.save(owner=self.request.user)
然后我使用 DRF 测试创建了一个自动化测试
运行会话测试:
class RunningSessionTest(APITestCase):
def test_get_sessions(self):
factory = APIRequestFactory()
view = views.SessionList.as_view()
user = User.objects.create_user(
'user01', 'user01@example.com', 'user01P4ssw0rD')
request = factory.get('http://localhost:8000/sessions/')
force_authenticate(request, user=user)
response = view(request)
assert Response.status_code == status.HTTP_200_OK
def test_get_sessions_not_authenticated_user(self):
factory = APIRequestFactory()
view = views.SessionList.as_view()
user = User.objects.create_user(
'user01', 'user01@example.com', 'user01P4ssw0rD')
request = factory.get('http://localhost:8000/sessions/')
response = view(request)
assert Response.status_code == status.HTTP_401_UNAUTHORIZED
问题:在这两种情况下,如果用户有令牌或没有响应值是 HTTP_200_OK
我试图通过尝试不同的方法来实现测试来解决这个问题。我使用过 APIRequestFactory,也使用过 APIClient,但得到了相同的结果。老实说,多次阅读文档后,我无法理解 APIClient 和 APIRequestFactory 之间的区别。
测试结果:
Traceback (most recent call last):
File "C:\python_work\DjnagoREST\01\restful01\RunKeeper\tests.py", line 67, in test_get_sessions_not_authenticated_user
assert Response.status_code == status.HTTP_401_UNAUTHORIZED
AssertionError
我会很感激你的帮助。