2015-06-11 12:18:45 +02:00
|
|
|
from django.contrib.auth import get_user_model
|
2015-12-16 16:09:15 +01:00
|
|
|
from django.contrib.auth.models import Permission
|
2017-12-28 15:11:34 +01:00
|
|
|
from django.urls import reverse
|
2015-06-11 12:18:45 +02:00
|
|
|
from django.test import TestCase
|
|
|
|
from django.test.client import Client
|
|
|
|
|
2015-12-16 16:09:15 +01:00
|
|
|
from helpdesk.models import Queue, Ticket
|
2015-06-11 12:18:45 +02:00
|
|
|
from helpdesk import settings
|
2019-10-30 19:34:58 +01:00
|
|
|
from helpdesk.query import __Query__
|
2019-10-16 17:36:55 +02:00
|
|
|
from helpdesk.user import HelpdeskUser
|
2015-06-11 12:18:45 +02:00
|
|
|
|
|
|
|
|
|
|
|
class PerQueueStaffMembershipTestCase(TestCase):
|
|
|
|
|
|
|
|
IDENTIFIERS = (1, 2)
|
|
|
|
|
|
|
|
def setUp(self):
|
|
|
|
"""
|
2019-10-16 17:36:55 +02:00
|
|
|
Create user_1 with access to queue_1 containing 2 ticket
|
|
|
|
and user_2 with access to queue_2 containing 4 tickets
|
2015-06-11 12:18:45 +02:00
|
|
|
and superuser who should be able to access both queues
|
|
|
|
"""
|
2015-12-16 16:09:15 +01:00
|
|
|
self.HELPDESK_ENABLE_PER_QUEUE_STAFF_PERMISSION = settings.HELPDESK_ENABLE_PER_QUEUE_STAFF_PERMISSION
|
|
|
|
settings.HELPDESK_ENABLE_PER_QUEUE_STAFF_PERMISSION = True
|
2015-06-11 12:18:45 +02:00
|
|
|
self.client = Client()
|
|
|
|
User = get_user_model()
|
|
|
|
|
|
|
|
self.superuser = User.objects.create(
|
|
|
|
username='superuser',
|
|
|
|
is_staff=True,
|
|
|
|
is_superuser=True,
|
|
|
|
)
|
|
|
|
self.superuser.set_password('superuser')
|
|
|
|
self.superuser.save()
|
|
|
|
|
2019-10-16 17:36:55 +02:00
|
|
|
self.identifier_users = {}
|
|
|
|
|
2015-06-11 12:18:45 +02:00
|
|
|
for identifier in self.IDENTIFIERS:
|
|
|
|
queue = self.__dict__['queue_%d' % identifier] = Queue.objects.create(
|
|
|
|
title='Queue %d' % identifier,
|
|
|
|
slug='q%d' % identifier,
|
|
|
|
)
|
|
|
|
|
|
|
|
user = self.__dict__['user_%d' % identifier] = User.objects.create(
|
|
|
|
username='User_%d' % identifier,
|
|
|
|
is_staff=True,
|
2019-10-16 17:36:55 +02:00
|
|
|
email="foo%s@example.com" % identifier
|
2015-06-11 12:18:45 +02:00
|
|
|
)
|
2016-06-30 01:56:27 +02:00
|
|
|
user.set_password(str(identifier))
|
2015-06-11 12:18:45 +02:00
|
|
|
user.save()
|
2019-10-16 17:36:55 +02:00
|
|
|
self.identifier_users[identifier] = user
|
2015-06-11 12:18:45 +02:00
|
|
|
|
2015-12-16 16:09:15 +01:00
|
|
|
# The prefix 'helpdesk.' must be trimmed
|
|
|
|
p = Permission.objects.get(codename=queue.permission_name[9:])
|
|
|
|
user.user_permissions.add(p)
|
2015-06-11 12:18:45 +02:00
|
|
|
|
|
|
|
for ticket_number in range(1, identifier + 1):
|
|
|
|
Ticket.objects.create(
|
2022-07-12 12:34:19 +02:00
|
|
|
title='Unassigned Ticket %d in Queue %d' % (
|
|
|
|
ticket_number, identifier),
|
2015-06-11 12:18:45 +02:00
|
|
|
queue=queue,
|
|
|
|
)
|
|
|
|
Ticket.objects.create(
|
2022-07-12 12:34:19 +02:00
|
|
|
title='Ticket %d in Queue %d Assigned to User_%d' % (
|
|
|
|
ticket_number, identifier, identifier),
|
2015-06-11 12:18:45 +02:00
|
|
|
queue=queue,
|
|
|
|
assigned_to=user,
|
|
|
|
)
|
|
|
|
|
2015-11-16 12:45:27 +01:00
|
|
|
def tearDown(self):
|
|
|
|
"""
|
|
|
|
Reset HELPDESK_ENABLE_PER_QUEUE_STAFF_MEMBERSHIP to original value
|
|
|
|
"""
|
2015-12-16 16:09:15 +01:00
|
|
|
settings.HELPDESK_ENABLE_PER_QUEUE_STAFF_PERMISSION = self.HELPDESK_ENABLE_PER_QUEUE_STAFF_PERMISSION
|
2015-11-16 12:45:27 +01:00
|
|
|
|
2015-06-11 12:18:45 +02:00
|
|
|
def test_dashboard_ticket_counts(self):
|
|
|
|
"""
|
|
|
|
Check that the regular users' dashboard only shows 1 of the 2 queues,
|
2019-10-16 17:36:55 +02:00
|
|
|
that user_1 only sees a total of 2 tickets, that user_2 sees a total of 4
|
2015-06-11 12:18:45 +02:00
|
|
|
tickets, but that the superuser's dashboard shows all queues and tickets.
|
|
|
|
"""
|
|
|
|
|
|
|
|
# Regular users
|
|
|
|
for identifier in self.IDENTIFIERS:
|
2022-07-12 12:34:19 +02:00
|
|
|
self.client.login(username='User_%d' %
|
|
|
|
identifier, password=str(identifier))
|
2015-12-22 10:10:00 +01:00
|
|
|
response = self.client.get(reverse('helpdesk:dashboard'))
|
2015-06-11 12:18:45 +02:00
|
|
|
self.assertEqual(
|
|
|
|
len(response.context['unassigned_tickets']),
|
|
|
|
identifier,
|
|
|
|
'Unassigned tickets were not properly limited by queue membership'
|
|
|
|
)
|
2016-09-13 06:06:38 +02:00
|
|
|
self.assertEqual(
|
|
|
|
response.context['basic_ticket_stats']['open_ticket_stats'][0][1],
|
|
|
|
identifier * 2,
|
|
|
|
'Basic ticket stats were not properly limited by queue membership'
|
|
|
|
)
|
|
|
|
|
|
|
|
# Superuser
|
|
|
|
self.client.login(username='superuser', password='superuser')
|
2016-10-29 10:33:27 +02:00
|
|
|
response = self.client.get(reverse('helpdesk:dashboard'))
|
2016-09-13 06:06:38 +02:00
|
|
|
self.assertEqual(
|
|
|
|
len(response.context['unassigned_tickets']),
|
|
|
|
3,
|
|
|
|
'Unassigned tickets were limited by queue membership for a superuser'
|
|
|
|
)
|
|
|
|
self.assertEqual(
|
|
|
|
response.context['basic_ticket_stats']['open_ticket_stats'][0][1] +
|
|
|
|
response.context['basic_ticket_stats']['open_ticket_stats'][1][1],
|
|
|
|
6,
|
|
|
|
'Basic ticket stats were limited by queue membership for a superuser'
|
|
|
|
)
|
|
|
|
|
|
|
|
def test_report_ticket_counts(self):
|
|
|
|
"""
|
|
|
|
Check that the regular users' report only shows 1 of the 2 queues,
|
2019-10-16 17:36:55 +02:00
|
|
|
that user_1 only sees a total of 2 tickets, that user_2 sees a total of 4
|
2016-09-13 06:06:38 +02:00
|
|
|
tickets, but that the superuser's report shows all queues and tickets.
|
|
|
|
"""
|
|
|
|
|
|
|
|
# Regular users
|
|
|
|
for identifier in self.IDENTIFIERS:
|
2022-07-12 12:34:19 +02:00
|
|
|
self.client.login(username='User_%d' %
|
|
|
|
identifier, password=str(identifier))
|
2016-10-29 10:33:27 +02:00
|
|
|
response = self.client.get(reverse('helpdesk:report_index'))
|
2015-06-11 12:18:45 +02:00
|
|
|
self.assertEqual(
|
|
|
|
len(response.context['dash_tickets']),
|
|
|
|
1,
|
|
|
|
'The queues in dash_tickets were not properly limited by queue membership'
|
|
|
|
)
|
|
|
|
self.assertEqual(
|
|
|
|
response.context['dash_tickets'][0]['open'],
|
|
|
|
identifier * 2,
|
|
|
|
'The tickets in dash_tickets were not properly limited by queue membership'
|
|
|
|
)
|
|
|
|
self.assertEqual(
|
|
|
|
response.context['basic_ticket_stats']['open_ticket_stats'][0][1],
|
|
|
|
identifier * 2,
|
|
|
|
'Basic ticket stats were not properly limited by queue membership'
|
|
|
|
)
|
|
|
|
|
|
|
|
# Superuser
|
|
|
|
self.client.login(username='superuser', password='superuser')
|
2016-10-29 09:47:15 +02:00
|
|
|
response = self.client.get(reverse('helpdesk:report_index'))
|
2015-06-11 12:18:45 +02:00
|
|
|
self.assertEqual(
|
|
|
|
len(response.context['dash_tickets']),
|
|
|
|
2,
|
|
|
|
'The queues in dash_tickets were limited by queue membership for a superuser'
|
|
|
|
)
|
|
|
|
self.assertEqual(
|
|
|
|
response.context['dash_tickets'][0]['open'] +
|
|
|
|
response.context['dash_tickets'][1]['open'],
|
|
|
|
6,
|
|
|
|
'The tickets in dash_tickets were limited by queue membership for a superuser'
|
|
|
|
)
|
|
|
|
self.assertEqual(
|
|
|
|
response.context['basic_ticket_stats']['open_ticket_stats'][0][1] +
|
|
|
|
response.context['basic_ticket_stats']['open_ticket_stats'][1][1],
|
|
|
|
6,
|
|
|
|
'Basic ticket stats were limited by queue membership for a superuser'
|
|
|
|
)
|
|
|
|
|
|
|
|
def test_ticket_list_per_queue_user_restrictions(self):
|
|
|
|
"""
|
|
|
|
Ensure that while the superuser can list all tickets, user_1 can only
|
2019-10-16 17:36:55 +02:00
|
|
|
list the 2 tickets in his queue and user_2 can list only the 4 tickets
|
2015-06-11 12:18:45 +02:00
|
|
|
in his queue.
|
|
|
|
"""
|
|
|
|
# Regular users
|
|
|
|
for identifier in self.IDENTIFIERS:
|
2022-07-12 12:34:19 +02:00
|
|
|
self.client.login(username='User_%d' %
|
|
|
|
identifier, password=str(identifier))
|
2015-12-22 10:10:00 +01:00
|
|
|
response = self.client.get(reverse('helpdesk:list'))
|
2022-07-12 12:34:19 +02:00
|
|
|
tickets = __Query__(HelpdeskUser(
|
|
|
|
self.identifier_users[identifier]), base64query=response.context['urlsafe_query']).get()
|
2015-06-11 12:18:45 +02:00
|
|
|
self.assertEqual(
|
2019-10-16 17:36:55 +02:00
|
|
|
len(tickets),
|
2015-06-11 12:18:45 +02:00
|
|
|
identifier * 2,
|
|
|
|
'Ticket list was not properly limited by queue membership'
|
|
|
|
)
|
|
|
|
self.assertEqual(
|
|
|
|
len(response.context['queue_choices']),
|
|
|
|
1,
|
|
|
|
'Queue choices were not properly limited by queue membership'
|
|
|
|
)
|
|
|
|
self.assertEqual(
|
|
|
|
response.context['queue_choices'][0],
|
|
|
|
Queue.objects.get(title="Queue %d" % identifier),
|
|
|
|
'Queue choices were not properly limited by queue membership'
|
|
|
|
)
|
|
|
|
|
|
|
|
# Superuser
|
|
|
|
self.client.login(username='superuser', password='superuser')
|
2015-12-22 10:10:00 +01:00
|
|
|
response = self.client.get(reverse('helpdesk:list'))
|
2022-07-12 12:34:19 +02:00
|
|
|
tickets = __Query__(HelpdeskUser(self.superuser),
|
|
|
|
base64query=response.context['urlsafe_query']).get()
|
2015-06-11 12:18:45 +02:00
|
|
|
self.assertEqual(
|
2019-10-16 17:36:55 +02:00
|
|
|
len(tickets),
|
2015-06-11 12:18:45 +02:00
|
|
|
6,
|
|
|
|
'Ticket list was limited by queue membership for a superuser'
|
|
|
|
)
|
|
|
|
|
|
|
|
def test_ticket_reports_per_queue_user_restrictions(self):
|
|
|
|
"""
|
|
|
|
Ensure that while the superuser can generate reports on all queues and
|
|
|
|
tickets, user_1 can only generate reports for queue 1 and user_2 can
|
|
|
|
only do so for queue 2
|
|
|
|
"""
|
|
|
|
# Regular users
|
|
|
|
for identifier in self.IDENTIFIERS:
|
2022-07-12 12:34:19 +02:00
|
|
|
self.client.login(username='User_%d' %
|
|
|
|
identifier, password=str(identifier))
|
2015-06-11 12:18:45 +02:00
|
|
|
response = self.client.get(
|
2015-12-22 10:10:00 +01:00
|
|
|
reverse('helpdesk:run_report', kwargs={'report': 'userqueue'})
|
2015-06-11 12:18:45 +02:00
|
|
|
)
|
|
|
|
# Only two columns of data should be present: ticket counts for
|
|
|
|
# unassigned and this user only
|
|
|
|
self.assertEqual(
|
|
|
|
len(response.context['data']),
|
|
|
|
2,
|
|
|
|
'Queues in report were not properly limited by queue membership'
|
|
|
|
)
|
2022-07-12 12:34:19 +02:00
|
|
|
# Each user should see a total number of tickets equal to twice
|
|
|
|
# their ID
|
2015-06-11 12:18:45 +02:00
|
|
|
self.assertEqual(
|
2022-07-12 12:34:19 +02:00
|
|
|
sum([sum(user_tickets[1:])
|
|
|
|
for user_tickets in response.context['data']]),
|
2015-06-11 12:18:45 +02:00
|
|
|
identifier * 2,
|
|
|
|
'Tickets in report were not properly limited by queue membership'
|
|
|
|
)
|
|
|
|
# Each user should only be able to pick 1 queue
|
|
|
|
self.assertEqual(
|
|
|
|
len(response.context['headings']),
|
|
|
|
2,
|
|
|
|
'Queue choices were not properly limited by queue membership'
|
|
|
|
)
|
2022-07-12 12:34:19 +02:00
|
|
|
# The queue each user can pick should be the queue named after
|
|
|
|
# their ID
|
2015-06-11 12:18:45 +02:00
|
|
|
self.assertEqual(
|
|
|
|
response.context['headings'][1],
|
|
|
|
"Queue %d" % identifier,
|
|
|
|
'Queue choices were not properly limited by queue membership'
|
|
|
|
)
|
|
|
|
|
|
|
|
# Superuser
|
|
|
|
self.client.login(username='superuser', password='superuser')
|
|
|
|
response = self.client.get(
|
2015-12-22 10:10:00 +01:00
|
|
|
reverse('helpdesk:run_report', kwargs={'report': 'userqueue'})
|
2015-06-11 12:18:45 +02:00
|
|
|
)
|
|
|
|
# Superuser should see ticket counts for all two queues, which includes
|
|
|
|
# three columns: unassigned and both user 1 and user 2
|
|
|
|
self.assertEqual(
|
|
|
|
len(response.context['data'][0]),
|
|
|
|
3,
|
|
|
|
'Queues in report were improperly limited by queue membership for a superuser'
|
|
|
|
)
|
|
|
|
# Superuser should see the total ticket count of three tickets
|
|
|
|
self.assertEqual(
|
2022-07-12 12:34:19 +02:00
|
|
|
sum([sum(user_tickets[1:])
|
|
|
|
for user_tickets in response.context['data']]),
|
2015-06-11 12:18:45 +02:00
|
|
|
6,
|
|
|
|
'Tickets in report were improperly limited by queue membership for a superuser'
|
|
|
|
)
|
|
|
|
self.assertEqual(
|
|
|
|
len(response.context['headings']),
|
|
|
|
3,
|
|
|
|
'Queue choices were improperly limited by queue membership for a superuser'
|
|
|
|
)
|