File: test_serializers.py

package info (click to toggle)
python-django-rest-framework-guardian 0.4.0-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 136 kB
  • sloc: python: 267; makefile: 7; sh: 6
file content (105 lines) | stat: -rw-r--r-- 3,733 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
from django.contrib.auth.models import Group, User
from django.test import TestCase
from rest_framework import serializers
from rest_framework.test import APIRequestFactory

from rest_framework_guardian.serializers import ObjectPermissionsAssignmentMixin
from tests.models import BasicModel


factory = APIRequestFactory()


class BasicSerializer(ObjectPermissionsAssignmentMixin, serializers.ModelSerializer):
    class Meta:
        model = BasicModel
        fields = '__all__'

    def get_permissions_map(self, created):
        current_user = self.context['request'].user
        readers = Group.objects.get(name='readers')

        return {
            'view_%s' % BasicModel._meta.model_name: [current_user, readers],
            'change_%s' % BasicModel._meta.model_name: [current_user],
        }


class ObjectPermissionsAssignmentIntegrationTests(TestCase):
    """
    Integration tests for the object level permissions assignment API.
    """

    def setUp(self):
        create = User.objects.create_user
        self.writer = create('writer', password='password')
        self.reader = create('reader', password='password')
        self.no_perms = create('no_perms', password='password')

        # Add readers to our reader group
        reader_group = Group.objects.create(name='readers')
        reader_group.user_set.add(self.reader)

    def create_object(self):
        request = factory.post('/')
        request.user = self.writer

        serializer = BasicSerializer(
            data={'text': 'test'},
            context={'request': request},
        )
        serializer.is_valid(raise_exception=True)
        instance = serializer.save()

        return instance

    def test_read_permissions(self):
        instance = self.create_object()

        # Reader is indirectly assigned via its group permissions
        self.assertTrue(self.writer.has_perm('view_basicmodel', instance))
        self.assertTrue(self.reader.has_perm('view_basicmodel', instance))
        self.assertFalse(self.no_perms.has_perm('view_basicmodel', instance))

    def test_change_permissions(self):
        instance = self.create_object()

        self.assertTrue(self.writer.has_perm('change_basicmodel', instance))
        self.assertFalse(self.reader.has_perm('change_basicmodel', instance))
        self.assertFalse(self.no_perms.has_perm('change_basicmodel', instance))

    def test_delete_permissions(self):
        instance = self.create_object()

        # No user should be assigned delete permissions
        self.assertFalse(self.writer.has_perm('delete_basicmodel', instance))
        self.assertFalse(self.reader.has_perm('delete_basicmodel', instance))
        self.assertFalse(self.no_perms.has_perm('delete_basicmodel', instance))


class ObjectPermissionsAssignmentImplementationTests(TestCase):

    def test_get_permissions_map_should_return_a_mapping(self):
        class TestSerializer(BasicSerializer):
            def get_permissions_map(self, created):
                return dict()

        serializer = TestSerializer(data={'text': 'test'})
        serializer.is_valid(raise_exception=True)
        self.assertIsInstance(serializer.save(), BasicModel)

    def test_get_permissions_map_error_message(self):
        error_message = (
            'Expected InvalidSerializer.get_permissions_map '
            'to return a dict, got list instead.'
        )

        class InvalidSerializer(BasicSerializer):
            def get_permissions_map(self, created):
                return []

        serializer = InvalidSerializer(data={'text': 'test'})
        serializer.is_valid(raise_exception=True)

        with self.assertRaisesMessage(AssertionError, error_message):
            serializer.save()