Pylint 10
This commit is contained in:
parent
f803d81caf
commit
a6ceae8240
@ -145,7 +145,7 @@ disable=print-statement,
|
||||
exception-escape,
|
||||
comprehension-escape,
|
||||
E5110,
|
||||
C0415,
|
||||
C0415
|
||||
|
||||
|
||||
# Enable the message, report, category or checker with the given id(s). You can
|
||||
|
@ -170,7 +170,7 @@ Quickstart
|
||||
Для проверки pylint используем:
|
||||
-------------------------------
|
||||
|
||||
pylint ../access_controller_new
|
||||
pylint ../access_controller_new (папка проекта)
|
||||
|
||||
Для приведения файлов к стандарту PEP8 используем:
|
||||
--------------------------------------------------
|
||||
|
@ -1,9 +1,18 @@
|
||||
"""
|
||||
Авторизация пользователя.
|
||||
"""
|
||||
from django.contrib.auth.backends import ModelBackend
|
||||
from django.contrib.auth import get_user_model
|
||||
|
||||
|
||||
class EmailAuthBackend(ModelBackend):
|
||||
"""
|
||||
Класс авторизации пользователя по email.
|
||||
"""
|
||||
def authenticate(self, request, username=None, password=None, **kwargs):
|
||||
"""
|
||||
Функция получения пользователя (модель User) по email.
|
||||
"""
|
||||
try:
|
||||
user = get_user_model().objects.get(email=username)
|
||||
if user.check_password(password):
|
||||
@ -13,6 +22,9 @@ class EmailAuthBackend(ModelBackend):
|
||||
return None
|
||||
|
||||
def get_user(self, user_id):
|
||||
"""
|
||||
Функция получения пользователя по id.
|
||||
"""
|
||||
try:
|
||||
return get_user_model().objects.get(pk=user_id)
|
||||
except get_user_model().DoesNotExist:
|
||||
|
@ -1,3 +1,6 @@
|
||||
"""
|
||||
Обработка тикетов.
|
||||
"""
|
||||
import requests
|
||||
from zenpy import TicketApi
|
||||
from zenpy.lib.api_objects import Ticket
|
||||
@ -6,6 +9,9 @@ from main.zendesk_admin import zenpy
|
||||
|
||||
|
||||
class TicketListRequester:
|
||||
"""
|
||||
Класс обработки тикетов.
|
||||
"""
|
||||
def __init__(self):
|
||||
self.email = zenpy.credentials['email']
|
||||
if zenpy.credentials.get('token'):
|
||||
@ -15,11 +21,17 @@ class TicketListRequester:
|
||||
self.token_or_password = zenpy.credentials.get('password')
|
||||
self.prefix = f'https://{zenpy.credentials.get("subdomain")}.zendesk.com/api/v2/'
|
||||
|
||||
def get_tickets_list_for_user(self, zendesk_user):
|
||||
def get_tickets_list_for_user(self, zendesk_user: zenpy) -> str:
|
||||
"""
|
||||
Функция получения списка тикетов пользователя Zendesk.
|
||||
"""
|
||||
url = self.prefix + f'users/{zendesk_user.id}/tickets/assigned'
|
||||
return self._get_tickets(url)
|
||||
|
||||
def get_tickets_list_for_group(self, group):
|
||||
def get_tickets_list_for_group(self, group: zenpy) -> list():
|
||||
"""
|
||||
Функция получения списка тикетов группы пользователей Zendesk.
|
||||
"""
|
||||
url = self.prefix + '/tickets'
|
||||
all_tickets = self._get_tickets(url)
|
||||
tickets = list()
|
||||
@ -28,7 +40,10 @@ class TicketListRequester:
|
||||
tickets.append(ticket)
|
||||
return tickets
|
||||
|
||||
def _get_tickets(self, url):
|
||||
def _get_tickets(self, url: str) -> list():
|
||||
"""
|
||||
Функция получения полного списка тикетов по url.
|
||||
"""
|
||||
response = requests.get(url, auth=(self.email, self.token_or_password))
|
||||
tickets = []
|
||||
if response.status_code != 200:
|
||||
|
@ -98,7 +98,7 @@ class RegistrationTestCase(TestCase):
|
||||
"""
|
||||
with self.settings(EMAIL_BACKEND=self.email_backend):
|
||||
self.client.post(reverse('registration'), data={'email': self.any_zendesk_user_email})
|
||||
user = User.objects.get(email=self.any_zendesk_user_email)
|
||||
user = get_user_model().objects.get(email=self.any_zendesk_user_email)
|
||||
zendesk_user = zenpy.get_user(self.any_zendesk_user_email)
|
||||
self.assertEqual(user.userprofile.name, zendesk_user.name)
|
||||
|
||||
@ -108,71 +108,96 @@ class RegistrationTestCase(TestCase):
|
||||
"""
|
||||
with self.settings(EMAIL_BACKEND=self.email_backend):
|
||||
self.client.post(reverse('registration'), data={'email': self.zendesk_admin_email})
|
||||
user = User.objects.get(email=self.zendesk_admin_email)
|
||||
user = get_user_model().objects.get(email=self.zendesk_admin_email)
|
||||
self.assertEqual(user.userprofile.role, 'admin')
|
||||
self.assertTrue(user.has_perm('main.has_control_access'))
|
||||
|
||||
|
||||
class MakeEngineerTestCase(TestCase):
|
||||
"""
|
||||
Класс тестов для проверки функции назначения роли engineer.
|
||||
"""
|
||||
fixtures = ['fixtures/test_make_engineer.json']
|
||||
|
||||
def setUp(self):
|
||||
"""
|
||||
Предустановленные значения для проведения тестов.
|
||||
"""
|
||||
self.light_agent = '123@test.ru'
|
||||
self.admin = 'admin@gmail.com'
|
||||
self.engineer = 'customer@example.com'
|
||||
self.client = Client()
|
||||
self.client.force_login(User.objects.get(email=self.light_agent))
|
||||
self.client.force_login(get_user_model().objects.get(email=self.light_agent))
|
||||
self.admin_client = Client()
|
||||
self.admin_client.force_login(User.objects.get(email=self.admin))
|
||||
self.admin_client.force_login(get_user_model().objects.get(email=self.admin))
|
||||
|
||||
@patch('main.extra_func.zenpy')
|
||||
def test_redirect(self, ZenpyMock):
|
||||
user = User.objects.get(email=self.light_agent)
|
||||
def test_redirect(self):
|
||||
"""
|
||||
Функция проверки переадресации пользователя на рабочую страницу после назначения роли engineer.
|
||||
"""
|
||||
user = get_user_model().objects.get(email=self.light_agent)
|
||||
resp = self.client.post(reverse_lazy('work_become_engineer'))
|
||||
self.assertRedirects(resp, reverse('work', args=[user.id]))
|
||||
self.assertEqual(resp.status_code, 302)
|
||||
|
||||
@patch('main.extra_func.zenpy')
|
||||
def test_light_agent_make_engineer(self, ZenpyMock):
|
||||
def test_light_agent_make_engineer(self, zenpy_mock):
|
||||
"""
|
||||
Функция проверки назначения light_agent на роль engineer.
|
||||
"""
|
||||
self.client.post(reverse_lazy('work_become_engineer'))
|
||||
self.assertEqual(ZenpyMock.update_user.call_args[0][0].custom_role_id, sets.ZENDESK_ROLES['engineer'])
|
||||
self.assertEqual(zenpy_mock.update_user.call_args[0][0].custom_role_id, sets.ZENDESK_ROLES['engineer'])
|
||||
|
||||
@patch('main.extra_func.zenpy')
|
||||
def test_admin_make_engineer(self, ZenpyMock):
|
||||
def test_admin_make_engineer(self, zenpy_mock):
|
||||
"""
|
||||
Функция проверки назначения admin на роль engineer.
|
||||
"""
|
||||
self.admin_client.post(reverse_lazy('work_become_engineer'))
|
||||
self.assertEqual(ZenpyMock.update_user.call_args[0][0].custom_role_id, sets.ZENDESK_ROLES['engineer'])
|
||||
self.assertEqual(zenpy_mock.update_user.call_args[0][0].custom_role_id, sets.ZENDESK_ROLES['engineer'])
|
||||
|
||||
@patch('main.extra_func.zenpy')
|
||||
def test_engineer_make_engineer(self, ZenpyMock):
|
||||
def test_engineer_make_engineer(self, zenpy_mock):
|
||||
"""
|
||||
Функция проверки назначения engineer на роль engineer.
|
||||
"""
|
||||
client = Client()
|
||||
client.force_login(User.objects.get(email=self.engineer))
|
||||
client.force_login(get_user_model().objects.get(email=self.engineer))
|
||||
client.post(reverse_lazy('work_become_engineer'))
|
||||
self.assertEqual(ZenpyMock.update_user.call_args[0][0].custom_role_id, sets.ZENDESK_ROLES['engineer'])
|
||||
self.assertEqual(zenpy_mock.update_user.call_args[0][0].custom_role_id, sets.ZENDESK_ROLES['engineer'])
|
||||
|
||||
@patch('main.extra_func.zenpy')
|
||||
def test_control_page_make_one(self, ZenpyMock):
|
||||
def test_control_page_make_one(self, zenpy_mock):
|
||||
"""
|
||||
Функция проверки назначения администратором на роль engineer одного пользователя.
|
||||
"""
|
||||
self.admin_client.post(
|
||||
reverse_lazy('control'),
|
||||
data={'users': [User.objects.get(email=self.light_agent).userprofile.id], 'engineer': 'engineer'}
|
||||
data={'users': [get_user_model().objects.get(email=self.light_agent).userprofile.id],
|
||||
'engineer': 'engineer'}
|
||||
)
|
||||
call_list = ZenpyMock.update_user.call_args_list
|
||||
call_list = zenpy_mock.update_user.call_args_list
|
||||
mock_object = call_list[0][0][0]
|
||||
self.assertEqual(len(call_list), 1)
|
||||
self.assertEqual(mock_object.custom_role_id, sets.ZENDESK_ROLES['engineer'])
|
||||
|
||||
@patch('main.extra_func.zenpy')
|
||||
def test_control_page_make_many(self, ZenpyMock):
|
||||
def test_control_page_make_many(self, zenpy_mock):
|
||||
"""
|
||||
Функция проверки назначения администратором на роль engineer нескольких пользователей.
|
||||
"""
|
||||
self.admin_client.post(
|
||||
reverse_lazy('control'),
|
||||
data={
|
||||
'users': [
|
||||
User.objects.get(email=self.light_agent).userprofile.id,
|
||||
User.objects.get(email=self.engineer).userprofile.id,
|
||||
get_user_model().objects.get(email=self.light_agent).userprofile.id,
|
||||
get_user_model().objects.get(email=self.engineer).userprofile.id,
|
||||
],
|
||||
'engineer': 'engineer'
|
||||
}
|
||||
)
|
||||
call_list = ZenpyMock.update_user.call_args_list
|
||||
call_list = zenpy_mock.update_user.call_args_list
|
||||
mock_objects = list(call_list)
|
||||
self.assertEqual(len(call_list), 2)
|
||||
for obj in mock_objects:
|
||||
|
Loading…
x
Reference in New Issue
Block a user