Esempio n. 1
0
    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()
Esempio n. 3
0
    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'))
Esempio n. 4
0
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)
Esempio n. 5
0
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)