def setUp(self): """ Create a map """ self.saved_map = SavedMap( **{ 'urlhash': 'abc123', 'mapdata': '{"global": {"lines": {"0896d7": {"displayName": "Blue Line"}}}, "1": {"1": {"line": "0896d7"}, "2": {"line": "0896d7"}}, "2": {"1": {"line": "0896d7"}}, "3": {"1": {"line": "0896d7"}}, "4": {"1": {"line": "0896d7"}, "2": {"line": "0896d7"}}}' }) self.saved_map.save()
def setUp(self): """ Create a map and a user """ self.saved_map = SavedMap(**{ 'urlhash': 'abc123', 'mapdata': '{"global": {"lines": {"0896d7": {"displayName": "Blue Line"}}}, "1": {"1": {"line": "0896d7"}, "2": {"line": "0896d7"}}, "2": {"1": {"line": "0896d7"}}, "3": {"1": {"line": "0896d7"}}, "4": {"1": {"line": "0896d7"}, "2": {"line": "0896d7"}}}' }) self.saved_map.save() self.test_user = User.objects.create_user(username='******', password='******') self.test_user.save()
def test_existing_maps(self): """ Confirm the |existing_maps template filter returns the correct numbers """ for count in range(1, 11): saved_map = SavedMap( **{ 'name': 'test_existing_maps', 'gallery_visible': True, 'thumbnail': 'test_existing_maps', 'urlhash': 'abc123', 'mapdata': '{"global": {"lines": {"0896d7": {"displayName": "Blue Line"}}}, "1": {"1": {"line": "0896d7"}, "2": {"line": "0896d7"}}, "2": {"1": {"line": "0896d7"}}, "3": {"1": {"line": "0896d7"}}, "4": {"1": {"line": "0896d7"}, "2": {"line": "0896d7"}}}', }) saved_map.save() saved_map.refresh_from_db() saved_map.tags.add('real') saved_map.save() self.assertEqual(count, existing_maps(saved_map, 'real'))
class ModeratePermissionsTestCase(TestCase): def setUp(self): self.saved_map = SavedMap( **{ 'urlhash': 'abcd1234', 'mapdata': '{"global": {"lines": {"0896d7": {"displayName": "Blue Line"}}}, "1": {"1": {"line": "0896d7"}, "2": {"line": "0896d7"}}, "2": {"1": {"line": "0896d7"}}, "3": {"1": {"line": "0896d7"}}, "4": {"1": {"line": "0896d7"}, "2": {"line": "0896d7"}}}' }) self.saved_map.save() self.test_user = User.objects.create_user(username='******', password='******') self.test_user.save() def test_only_own_activity_log(self): """ Confirm that you can only view your own activity log, nobody else's, and not the main log of everyone's activity """ # Create a user who is trying to be sneaky snoop_user = User.objects.create_user(username='******', password='******') snoop_user.save() client = Client() client.login(username='******', password='******') # Not allowed to view the main log response = client.get('/admin/activity/', follow=True) self.assertEqual(response.status_code, 403) # Not allowed to view someone else's log response = client.get(f'/admin/activity/{self.test_user.id}') self.assertEqual(response.status_code, 403) # Not allowed to view a map directly, either response = client.get(f'/admin/activity/{self.saved_map.urlhash}') self.assertEqual(response.status_code, 403) # But allowed to view my own log response = client.get(f'/admin/activity/{snoop_user.id}') self.assertEqual(response.status_code, 200)
class SavedMapTest(TestCase): def setUp(self): """ Create a map """ self.saved_map = SavedMap( **{ 'urlhash': 'abc123', 'mapdata': '{"global": {"lines": {"0896d7": {"displayName": "Blue Line"}}}, "1": {"1": {"line": "0896d7"}, "2": {"line": "0896d7"}}, "2": {"1": {"line": "0896d7"}}, "3": {"1": {"line": "0896d7"}}, "4": {"1": {"line": "0896d7"}, "2": {"line": "0896d7"}}}' }) self.saved_map.save() def confirm_gallery_presence(self, visible): """ Helper function to DRY this test; Confirms that .publicly_visible and actual gallery presence are the same """ self.saved_map.save() self.saved_map.refresh_from_db() client = Client() response = client.get('/gallery/') self.assertEqual(visible, self.saved_map.publicly_visible) if visible: self.assertContains(response, 'Cool Map') else: self.assertNotContains(response, 'Cool Map') def test_publicly_visible(self): """ Confirm that a map is only publicly visible when ALL of the following conditions are met: .gallery_visible = True .name is not blank .thumbnail is not blank and it has at least one tag in PUBLICLY_VISIBLE_TAGS If any of those conditions stop being true, the map should stop being publicly visible upon .save() """ self.confirm_gallery_presence(False) assignments = { 'gallery_visible': True, 'name': 'Cool Map', 'thumbnail': 'Thumbnail', } # Even after all of these, I still don't have the tag for key, value in assignments.items(): setattr(self.saved_map, key, value) self.confirm_gallery_presence(False) self.saved_map.tags.add('irrelevant') self.confirm_gallery_presence(False) # This tag is good, so now my map is finally publicly visible self.saved_map.tags.add('real') self.confirm_gallery_presence(True) # Any of these is sufficient to make the map no longer publicly visible negative_assignments = { 'gallery_visible': False, 'name': ' ', 'thumbnail': ' ', } for key, value in negative_assignments.items(): setattr(self.saved_map, key, value) self.confirm_gallery_presence(False) # But let's put it back the way it was and confirm we're visible again setattr(self.saved_map, key, assignments[key]) self.confirm_gallery_presence(True) # Addding the 'reviewed' tag makes it no longer visible self.saved_map.tags.add('reviewed') self.confirm_gallery_presence(False) # Remove the 'reviewed' tag and it's visible again self.saved_map.tags.remove('reviewed') self.confirm_gallery_presence(True) # Finally, remove the 'real' tag and confirm it's no longer visible self.saved_map.tags.remove('real') self.confirm_gallery_presence(False) # Maliciously set publicly_visible = True, save, and confirm it's unset self.saved_map.publicly_visible = True self.confirm_gallery_presence(False) def test_existing_maps(self): """ Confirm the |existing_maps template filter returns the correct numbers """ for count in range(1, 11): saved_map = SavedMap( **{ 'name': 'test_existing_maps', 'gallery_visible': True, 'thumbnail': 'test_existing_maps', 'urlhash': 'abc123', 'mapdata': '{"global": {"lines": {"0896d7": {"displayName": "Blue Line"}}}, "1": {"1": {"line": "0896d7"}, "2": {"line": "0896d7"}}, "2": {"1": {"line": "0896d7"}}, "3": {"1": {"line": "0896d7"}}, "4": {"1": {"line": "0896d7"}, "2": {"line": "0896d7"}}}', }) saved_map.save() saved_map.refresh_from_db() saved_map.tags.add('real') saved_map.save() self.assertEqual(count, existing_maps(saved_map, 'real'))
class AdminPermissionsTestCase(TestCase): def setUp(self): """ Create a map and a user """ self.saved_map = SavedMap(**{ 'urlhash': 'abc123', 'mapdata': '{"global": {"lines": {"0896d7": {"displayName": "Blue Line"}}}, "1": {"1": {"line": "0896d7"}, "2": {"line": "0896d7"}}, "2": {"1": {"line": "0896d7"}}, "3": {"1": {"line": "0896d7"}}, "4": {"1": {"line": "0896d7"}, "2": {"line": "0896d7"}}}' }) self.saved_map.save() self.test_user = User.objects.create_user(username='******', password='******') self.test_user.save() def confirm_activity_log(self, action, details=''): """ Helper function to confirm that an ActivityLog is created for every entry """ activity_log = self.saved_map.activitylog_set.order_by('-created_at').first() self.assertEqual(activity_log.user, self.test_user) self.assertEqual(activity_log.savedmap, self.saved_map) self.assertEqual(activity_log.action, action) self.assertEqual(activity_log.details, details) def test_redirect_if_not_logged_in(self): """ Confirm that if you are not logged in, a request to one of these will result in a redirect to the login page """ client = Client() admin_only_pages = ( '/admin/gallery/', '/admin/gallery/?page=2', '/admin/gallery/real/', '/admin/gallery/real/?page=2', '/admin/similar/abc123', '/admin/direct/https://metromapmaker.com/?map=abc123', '/admin/activity/', ) for admin_only_page in admin_only_pages: response = client.get(admin_only_page) self.assertEqual(response.status_code, 302, admin_only_page) self.assertTrue(response.url.startswith('/accounts/login/'), response.url) response = client.post('/admin/action/', {'action': 'hide', 'map': 1}) self.assertEqual(response.status_code, 302, admin_only_page) self.assertTrue(response.url.startswith('/accounts/login/'), response.url) def test_admin_permission_denied(self): """ Confirm that a logged-in user without the proper permissions cannot change the objects """ client = Client() client.login(username='******', password='******') saved_map = self.saved_map self.assertTrue(saved_map.gallery_visible) client.post('/admin/action/', { 'action': 'hide', 'map': saved_map.id }) # Unchanged, because user did not have permission to hide saved_map.refresh_from_db() self.assertTrue(saved_map.gallery_visible) self.assertEqual(0, saved_map.tags.count()) client.post('/admin/action/', { 'action': 'addtag', 'map': saved_map.id, 'tag': 'real' }) saved_map.refresh_from_db() self.assertEqual(0, saved_map.tags.count()) self.assertEqual('', saved_map.name) client.post('/admin/action/', { 'action': 'name', 'map': saved_map.id, 'name': 'London' }) saved_map.refresh_from_db() self.assertEqual('', saved_map.name) self.assertEqual('', saved_map.thumbnail) client.post('/admin/action/', { 'action': 'thumbnail', 'map': saved_map.id, 'data': 'thumbnail data' }) saved_map.refresh_from_db() self.assertEqual('', saved_map.thumbnail) def test_admin_permission_granted_hide_map(self): """ Confirm that a logged-in user with the proper permissions can hide a map """ permission = Permission.objects.get(name="Can set a map's gallery_visible to hidden") test_user = self.test_user test_user.user_permissions.add(permission) test_user.save() client = Client() client.login(username='******', password='******') saved_map = self.saved_map action = 'hide' self.assertTrue(saved_map.gallery_visible) response = client.post('/admin/action/', { 'action': 'hide', 'map': saved_map.id }) saved_map.refresh_from_db() self.assertFalse(saved_map.gallery_visible, response.context['status']) # Confirm there is a record of this action self.assertEqual(saved_map.activitylog_set.count(), 1) self.confirm_activity_log(action) # Hiding the map again will show it response = client.post('/admin/action/', { 'action': 'hide', 'map': saved_map.id }) saved_map.refresh_from_db() self.assertTrue(saved_map.gallery_visible) # Confirm there is a record of this action self.assertEqual(saved_map.activitylog_set.count(), 2) self.confirm_activity_log('show') def test_admin_permission_granted_add_tag(self): """ Confirm that a logged-in user with the proper permissions can tag a map """ permission = Permission.objects.get(name="Can change the tags associated with a map") test_user = self.test_user test_user.user_permissions.add(permission) test_user.save() client = Client() client.login(username='******', password='******') saved_map = self.saved_map # Need to create the tag, because it only can add a tag if that tag exists already Tag.objects.create(name='real', slug='real') action = 'addtag' self.assertEqual(0, saved_map.tags.count()) response = client.post('/admin/action/', { 'action': action, 'map': saved_map.id, 'tag': 'real' }) saved_map.refresh_from_db() self.assertEqual(1, saved_map.tags.count()) # Confirm there is a record of this action self.assertEqual(saved_map.activitylog_set.count(), 1) self.confirm_activity_log(action, 'real') # Remove the tag action = 'removetag' response = client.post('/admin/action/', { 'action': action, 'map': saved_map.id, 'tag': 'real' }) saved_map.refresh_from_db() self.assertEqual(0, saved_map.tags.count()) # Confirm there is a record of this action self.assertEqual(saved_map.activitylog_set.count(), 2) self.confirm_activity_log(action, 'real') def test_admin_permission_granted_name_map(self): """ Confirm that a logged-in user with the proper permissions can name a map """ permission = Permission.objects.get(name="Can set a map's name") test_user = self.test_user test_user.user_permissions.add(permission) test_user.save() client = Client() client.login(username='******', password='******') saved_map = self.saved_map action = 'name' self.assertEqual('', saved_map.name) client.post('/admin/action/', { 'action': action, 'map': saved_map.id, 'name': 'London' }) saved_map.refresh_from_db() self.assertEqual('London', saved_map.name) # Confirm there is a record of this action self.assertEqual(saved_map.activitylog_set.count(), 1) self.confirm_activity_log(action, 'London') def test_admin_permission_granted_generate_thumbnail(self): """ Confirm that a logged-in user with the proper permissions can name a map """ permission = Permission.objects.get(name="Can generate thumbnails for a map") test_user = self.test_user test_user.user_permissions.add(permission) test_user.save() client = Client() client.login(username='******', password='******') saved_map = self.saved_map action = 'thumbnail' self.assertEqual('', saved_map.thumbnail) client.post('/admin/action/', { 'action': 'thumbnail', 'map': saved_map.id, 'data': '' }) saved_map.refresh_from_db() self.assertTrue(saved_map.thumbnail) # Confirm there is a record of this action self.assertEqual(saved_map.activitylog_set.count(), 1) self.confirm_activity_log(action, 'data:image/png;base64') def test_admin_permission_edit_publicly_visible(self): """ Confirm that a logged-in user with the proper permissions can edit a publicly visible map """ # Give permission to hide permission = Permission.objects.get(name="Can set a map's gallery_visible to hidden") test_user = self.test_user test_user.user_permissions.add(permission) test_user.save() client = Client() client.login(username='******', password='******') # Add a name, thumbnail, and tag, then confirm this map is publicly visible saved_map = self.saved_map saved_map.gallery_visible = True saved_map.name = saved_map.thumbnail = 'test_admin_permission_granted_edit_publicly_visible' saved_map.tags.add('real') saved_map.save() saved_map.refresh_from_db() self.assertTrue(saved_map.publicly_visible) # We haven't added the permission yet, so the hide action should fail response = client.post('/admin/action/', { 'action': 'hide', 'map': saved_map.id }) saved_map.refresh_from_db() self.assertTrue(saved_map.publicly_visible) # Add the permission to edit a publicly visible map permission = Permission.objects.get(name="Can edit a publicly visible map") test_user = User.objects.get(username='******') test_user.user_permissions.add(permission) test_user.save() # Now the hide action will succeed response = client.post('/admin/action/', { 'action': 'hide', 'map': saved_map.id }) saved_map.refresh_from_db() self.assertFalse(saved_map.publicly_visible)