Portal/rsconcept/backend/apps/users/tests/t_views.py

193 lines
6.1 KiB
Python
Raw Normal View History

2024-06-07 20:17:03 +03:00
''' Testing API: users. '''
from rest_framework.test import APIClient, APITestCase
from apps.users.models import User
from shared.EndpointTester import EndpointTester, decl_endpoint
2024-06-07 20:17:03 +03:00
class TestUserAPIViews(EndpointTester):
''' Testing Authentication views. '''
def setUp(self):
2024-07-15 12:35:47 +03:00
super().setUpFullUsers()
2024-06-07 20:17:03 +03:00
@decl_endpoint('/users/api/login', method='post')
def test_login(self):
self.logout()
data = {'username': self.user.username, 'password': 'invalid'}
self.executeBadData(data)
data = {'username': self.user.username, 'password': 'password'}
self.executeAccepted(data)
self.executeAccepted(data)
self.logout()
data = {'username': self.user.email, 'password': 'password'}
self.executeAccepted(data)
@decl_endpoint('/users/api/logout', method='post')
def test_logout(self):
self.logout()
self.executeForbidden()
self.login()
self.executeNoContent()
self.executeNoContent()
@decl_endpoint('/users/api/auth', method='get')
def test_auth(self):
response = self.executeOK()
self.assertEqual(response.data['id'], self.user.pk)
self.assertEqual(response.data['username'], self.user.username)
self.assertEqual(response.data['is_staff'], self.user.is_staff)
self.assertEqual(response.data['subscriptions'], [])
self.assertEqual(response.data['editor'], [])
self.logout()
response = self.executeOK()
self.assertEqual(response.data['id'], None)
self.assertEqual(response.data['username'], '')
self.assertEqual(response.data['is_staff'], False)
self.assertEqual(response.data['subscriptions'], [])
self.assertEqual(response.data['editor'], [])
class TestUserUserProfileAPIView(EndpointTester):
''' Testing User profile views. '''
def setUp(self):
2024-07-15 12:35:47 +03:00
super().setUpFullUsers()
2024-06-07 20:17:03 +03:00
self.user.first_name = 'John'
self.user.second_name = 'Smith'
self.user.save()
@decl_endpoint('/users/api/profile', method='get')
def test_read_profile(self):
response = self.executeOK()
self.assertEqual(response.data['username'], self.user.username)
self.assertEqual(response.data['email'], self.user.email)
self.assertEqual(response.data['first_name'], self.user.first_name)
self.assertEqual(response.data['last_name'], self.user.last_name)
self.logout()
self.executeForbidden()
@decl_endpoint('/users/api/profile', method='patch')
def test_edit_profile(self):
data = {
'email': '123@mail.ru',
'first_name': 'firstName',
'last_name': 'lastName',
}
response = self.executeOK(data)
self.user.refresh_from_db()
self.assertEqual(response.data['email'], '123@mail.ru')
self.assertEqual(self.user.email, '123@mail.ru')
self.assertEqual(response.data['first_name'], 'firstName')
self.assertEqual(self.user.first_name, 'firstName')
self.assertEqual(response.data['last_name'], 'lastName')
self.assertEqual(self.user.last_name, 'lastName')
data = {
'email': data['email'],
'first_name': 'new',
'last_name': 'new2',
}
self.executeOK(data)
data = {'email': self.user2.email}
self.executeBadData(data)
self.logout()
self.executeForbidden()
@decl_endpoint('/users/api/change-password', method='patch')
def test_change_password(self):
data = {
'old_password': 'invalid',
'new_password': 'password2'
}
self.executeBadData(data)
data = {
'old_password': 'password',
'new_password': 'password2'
}
oldHash = self.user.password
response = self.executeNoContent(data)
self.user.refresh_from_db()
self.assertNotEqual(self.user.password, oldHash)
self.assertTrue(self.client.login(username=self.user.username, password='password2'))
self.assertFalse(self.client.login(username=self.user.username, password='password'))
self.logout()
self.executeForbidden()
@decl_endpoint('/users/api/password-reset', method='post')
def test_password_reset_request(self):
self.executeBadData({'email': 'invalid@mail.ru'})
self.executeOK({'email': self.user.email})
# TODO: check if mail server actually sent email and if reset procedure works
class TestSignupAPIView(EndpointTester):
''' Testing signup. '''
def setUp(self):
super().setUp()
@decl_endpoint('/users/api/signup', method='post')
def test_signup(self):
data = {
'username': 'NewUser',
'email': 'newMail@mail.ru',
'password': 'Test@@123',
'password2': 'Test@@123456',
'first_name': 'firstName',
'last_name': 'lastName'
}
self.executeBadData(data)
data = {
'username': 'NewUser',
'email': 'newMail@mail.ru',
'password': 'Test@@123',
'password2': 'Test@@123',
'first_name': 'firstName',
'last_name': 'lastName'
}
response = self.executeCreated(data)
self.assertTrue('id' in response.data)
self.assertEqual(response.data['username'], data['username'])
self.assertEqual(response.data['email'], data['email'])
self.assertEqual(response.data['first_name'], data['first_name'])
self.assertEqual(response.data['last_name'], data['last_name'])
data = {
'username': 'NewUser',
'email': 'newMail2@mail.ru',
'password': 'Test@@123',
'password2': 'Test@@123',
'first_name': 'firstName',
'last_name': 'lastName'
}
self.executeBadData(data)
data = {
'username': 'NewUser2',
'email': self.user.email,
'password': 'Test@@123',
'password2': 'Test@@123',
'first_name': 'firstName',
'last_name': 'lastName'
}
self.executeBadData(data)