|
| 1 | +from django.contrib.auth.models import User |
| 2 | +from django.test import TestCase, override_settings |
| 3 | +from django.urls import reverse |
| 4 | + |
| 5 | +from arch.models import PackageArchitecture |
| 6 | +from packages.models import Package, PackageName, PackageUpdate |
| 7 | + |
| 8 | + |
| 9 | +@override_settings( |
| 10 | + CELERY_TASK_ALWAYS_EAGER=True, |
| 11 | + CACHES={'default': {'BACKEND': 'django.core.cache.backends.locmem.LocMemCache'}} |
| 12 | +) |
| 13 | +class PackageUpdateViewTests(TestCase): |
| 14 | + |
| 15 | + def setUp(self): |
| 16 | + self.user = User.objects.create_user( |
| 17 | + username='testuser', password='testpass' |
| 18 | + ) |
| 19 | + self.client.login(username='testuser', password='testpass') |
| 20 | + self.arch = PackageArchitecture.objects.create(name='x86_64') |
| 21 | + self.name = PackageName.objects.create(name='openssl') |
| 22 | + self.old = Package.objects.create( |
| 23 | + name=self.name, arch=self.arch, epoch='', |
| 24 | + version='1.1.1', release='1', packagetype='R', |
| 25 | + ) |
| 26 | + self.new = Package.objects.create( |
| 27 | + name=self.name, arch=self.arch, epoch='', |
| 28 | + version='1.1.2', release='1', packagetype='R', |
| 29 | + ) |
| 30 | + self.sec_update = PackageUpdate.objects.create( |
| 31 | + oldpackage=self.old, newpackage=self.new, security=True, |
| 32 | + ) |
| 33 | + self.bug_update = PackageUpdate.objects.create( |
| 34 | + oldpackage=self.old, newpackage=self.new, security=False, |
| 35 | + ) |
| 36 | + |
| 37 | + def test_update_list(self): |
| 38 | + resp = self.client.get(reverse('packages:package_update_list')) |
| 39 | + self.assertEqual(resp.status_code, 200) |
| 40 | + self.assertContains(resp, 'openssl') |
| 41 | + |
| 42 | + def test_update_list_filter_security(self): |
| 43 | + resp = self.client.get( |
| 44 | + reverse('packages:package_update_list'), {'security': 'true'} |
| 45 | + ) |
| 46 | + self.assertEqual(resp.status_code, 200) |
| 47 | + self.assertContains(resp, 'Security') |
| 48 | + |
| 49 | + def test_update_list_filter_bugfix(self): |
| 50 | + resp = self.client.get( |
| 51 | + reverse('packages:package_update_list'), {'security': 'false'} |
| 52 | + ) |
| 53 | + self.assertEqual(resp.status_code, 200) |
| 54 | + self.assertContains(resp, 'Bugfix') |
| 55 | + |
| 56 | + def test_update_list_search(self): |
| 57 | + resp = self.client.get( |
| 58 | + reverse('packages:package_update_list'), {'search': 'openssl'} |
| 59 | + ) |
| 60 | + self.assertEqual(resp.status_code, 200) |
| 61 | + self.assertContains(resp, 'openssl') |
| 62 | + |
| 63 | + def test_update_list_search_no_results(self): |
| 64 | + resp = self.client.get( |
| 65 | + reverse('packages:package_update_list'), {'search': 'nonexistent'} |
| 66 | + ) |
| 67 | + self.assertEqual(resp.status_code, 200) |
| 68 | + |
| 69 | + def test_update_list_requires_login(self): |
| 70 | + self.client.logout() |
| 71 | + resp = self.client.get(reverse('packages:package_update_list')) |
| 72 | + self.assertEqual(resp.status_code, 302) |
0 commit comments