當前位置: 首頁>>代碼示例>>Python>>正文


Python Role.save方法代碼示例

本文整理匯總了Python中treemap.audit.Role.save方法的典型用法代碼示例。如果您正苦於以下問題:Python Role.save方法的具體用法?Python Role.save怎麽用?Python Role.save使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在treemap.audit.Role的用法示例。


在下文中一共展示了Role.save方法的11個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: FieldPermMgmtTest

# 需要導入模塊: from treemap.audit import Role [as 別名]
# 或者: from treemap.audit.Role import save [as 別名]
class FieldPermMgmtTest(OTMTestCase):
    def setUp(self):
        self.instance = make_instance()
        self.commander = make_commander_user(self.instance)

        self.new_role = Role(name='Ambassador', instance=self.instance,
                             rep_thresh=0)
        self.new_role.save()

        self.factory = RequestFactory()

    def assertInvalidFPRaises(self, **kwargs):
        fp = FieldPermission(**kwargs)
        fp.role = self.instance.default_role
        fp.instance = self.instance
        self.assertRaises(ValidationError, fp.save)

    def test_invalid_model_does_not_exist_unit(self):
        self.assertInvalidFPRaises(model_name='Gethen', field_name='readonly')

    def test_invalid_model_does_not_authorizable_unit(self):
        self.assertInvalidFPRaises(model_name='FieldPermission',
                                   field_name='role')

    def test_invalid_field_name_unit(self):
        self.assertInvalidFPRaises(model_name='Tree', field_name='model_name')
開發者ID:OpenTreeMap,項目名稱:otm-core,代碼行數:28,代碼來源:test_audit.py

示例2: setUp

# 需要導入模塊: from treemap.audit import Role [as 別名]
# 或者: from treemap.audit.Role import save [as 別名]
    def setUp(self):
        self.instance = make_instance()

        self.user = make_user(username='user', password='user')

        self.role = Role(name='role', instance=self.instance, rep_thresh=0)
        self.role.save()

        self.user_perm, __ = FieldPermission.objects.get_or_create(
            model_name='Plot', field_name='width',
            permission_level=FieldPermission.NONE,
            role=self.role, instance=self.instance)

        iuser = InstanceUser(instance=self.instance, user=self.user,
                             role=self.role)
        iuser.save_with_user(self.user)

        inst_role = Role(name='inst def role',
                         instance=self.instance,
                         rep_thresh=0)
        inst_role.save()

        self.inst_perm, __ = FieldPermission.objects.get_or_create(
            model_name='Plot', field_name='width',
            permission_level=FieldPermission.NONE,
            role=inst_role, instance=self.instance)

        self.instance.default_role = inst_role
        self.instance.save()

        self.plot = Plot(instance=self.instance)
開發者ID:JoshIUSBStudent,項目名稱:otm-core,代碼行數:33,代碼來源:test_templatetags.py

示例3: test_invites_updated

# 需要導入模塊: from treemap.audit import Role [as 別名]
# 或者: from treemap.audit.Role import save [as 別名]
    def test_invites_updated(self):
        email = "[email protected]"
        invite = InstanceInvitation(email=email,
                                    instance=self.instance,
                                    created_by=self.user4,
                                    role=self.instance.default_role)
        invite.save()

        new_role = Role(name='Ambassador', instance=self.instance,
                        rep_thresh=0)
        new_role.save()

        body = {'invites':
                {invite.pk:
                 {'role': new_role.pk}}}

        update_user_roles(
            make_request(method='POST',
                         body=json.dumps(body),
                         user=self.commander),
            self.instance)

        # requery invite
        invite = InstanceInvitation.objects.get(pk=invite.pk)
        self.assertEqual(invite.role, new_role)
開發者ID:OpenTreeMap,項目名稱:otm-core,代碼行數:27,代碼來源:test_roles.py

示例4: test_user_roles_updated

# 需要導入模塊: from treemap.audit import Role [as 別名]
# 或者: from treemap.audit.Role import save [as 別名]
    def test_user_roles_updated(self):
        iuser = InstanceUser(user=self.user2, instance=self.instance,
                             role=self.instance.default_role)
        iuser.save_with_user(self.commander)

        new_role = Role(name='Ambassador', instance=self.instance,
                        rep_thresh=0)
        new_role.save()

        body = {'users':
                {iuser.pk:
                 {'role': new_role.pk, 'admin': False}}}

        update_user_roles(
            make_request(method='POST',
                         body=json.dumps(body),
                         user=self.commander),
            self.instance)

        #requery iuser
        iuser = InstanceUser.objects.get(pk=iuser.pk)
        self.assertEqual(iuser.role, new_role)
        self.assertEqual(iuser.admin, False)

        body = {'users':
                {iuser.pk: {'role': new_role.pk, 'admin': True}}}

        update_user_roles(
            make_request(method='POST',
                         body=json.dumps(body),
                         user=self.commander),
            self.instance)

        #requery iuser
        iuser = InstanceUser.objects.get(pk=iuser.pk)
        self.assertEqual(iuser.role, new_role)
        self.assertEqual(iuser.admin, True)
開發者ID:OpenTreeMap,項目名稱:otm-core,代碼行數:39,代碼來源:test_roles.py

示例5: ModelUnicodeTests

# 需要導入模塊: from treemap.audit import Role [as 別名]
# 或者: from treemap.audit.Role import save [as 別名]
class ModelUnicodeTests(OTMTestCase):

    def setUp(self):
        self.instance = make_instance(name='Test Instance')

        self.species = Species(instance=self.instance,
                               common_name='Test Common Name',
                               genus='Test Genus',
                               cultivar='Test Cultivar',
                               species='Test Species')
        self.species.save_base()

        self.user = make_user(username='commander', password='pw')

        self.plot = Plot(geom=Point(1, 1), instance=self.instance,
                         address_street="123 Main Street")

        self.plot.save_base()

        self.tree = Tree(plot=self.plot, instance=self.instance)

        self.tree.save_base()

        self.boundary = make_simple_boundary("Test Boundary")

        self.role = Role(instance=self.instance, name='Test Role',
                         rep_thresh=2)
        self.role.save()

        self.field_permission = FieldPermission(
            model_name="Tree",
            field_name="readonly",
            permission_level=FieldPermission.READ_ONLY,
            role=self.role,
            instance=self.instance)
        self.field_permission.save_base()

        self.audit = Audit(action=Audit.Type.Update,
                           model="Tree",
                           field="readonly",
                           model_id=1,
                           user=self.user,
                           previous_value=True,
                           current_value=False)
        self.audit.save_base()

        self.reputation_metric = ReputationMetric(instance=self.instance,
                                                  model_name="Tree",
                                                  action="Test Action")
        self.reputation_metric.save_base()

    def test_instance_model(self):
        self.assertEqual(unicode(self.instance), "Test Instance")

    def test_species_model(self):
        self.assertEqual(
            unicode(self.species),
            "Test Common Name [Test Genus Test Species 'Test Cultivar']")

    def test_user_model(self):
        self.assertEqual(unicode(self.user), 'commander')

    def test_plot_model(self):
        self.assertEqual(unicode(self.plot),
                         'Plot (1.0, 1.0) 123 Main Street')

    def test_tree_model(self):
        self.assertEqual(unicode(self.tree), '')

    def test_boundary_model(self):
        self.assertEqual(unicode(self.boundary), 'Test Boundary')

    def test_role_model(self):
        self.assertEqual(unicode(self.role), 'Test Role (%s)' % self.role.pk)

    def test_field_permission_model(self):
        self.assertEqual(unicode(self.field_permission),
                         'Tree.readonly - Test Role (%s) - Read Only'
                         % self.role.pk)

    def test_audit_model(self):
        self.assertEqual(
            unicode(self.audit),
            'pk=%s - action=Update - Tree.readonly:(1) - True => False'
            % self.audit.pk)

    def test_reputation_metric_model(self):
        self.assertEqual(unicode(self.reputation_metric),
                         'Test Instance - Tree - Test Action')
開發者ID:jwalgran,項目名稱:otm-core,代碼行數:91,代碼來源:test_models.py

示例6: InlineFieldTagTests

# 需要導入模塊: from treemap.audit import Role [as 別名]
# 或者: from treemap.audit.Role import save [as 別名]
class InlineFieldTagTests(OTMTestCase):

    def setUp(self):
        self.instance = make_instance()
        self.instance.config['advanced_search_fields'] = {}
        self.instance.save()
        self.role = Role(name='role', instance=self.instance, rep_thresh=0)
        self.role.save()

        self.observer = make_observer_user(self.instance)

        self.udf_role = Role(name='udf', instance=self.instance, rep_thresh=0)
        self.udf_role.save()

        self.template_dir = tempfile.mkdtemp()
        self.template_file_path = os.path.join(self.template_dir,
                                               "field_template.html")

        UserDefinedFieldDefinition.objects.create(
            instance=self.instance,
            model_type='Plot',
            datatype=json.dumps({'type': 'choice',
                                 'choices': ["a", "b", "c"]}),
            iscollection=False,
            name='Test choice')

        udf_perm, __ = FieldPermission.objects.get_or_create(
            model_name='Plot', field_name='udf:Test choice',
            permission_level=FieldPermission.READ_ONLY,
            role=self.role, instance=self.instance)
        udf_perm.save()
        udf_write_perm, __ = FieldPermission.objects.get_or_create(
            model_name='Plot', field_name='udf:Test choice',
            permission_level=FieldPermission.WRITE_DIRECTLY,
            role=self.udf_role, instance=self.instance)
        udf_write_perm.save()

    def tearDown(self):
        rmtree(self.template_dir)

    def _form_template_with_request_user_for(self, identifier):
        field_name = '"' + identifier + '"'
        template_text = """{% load form_extras %}""" +\
            """{% field "Test Field" from """ + field_name +\
            """ for request.user withtemplate "field_template.html" %}"""
        return Template(template_text)

    def _form_template_for(self, identifier):
        field_name = '"' + identifier + '"'
        template_text = """{% load form_extras %}""" +\
            """{% field "Test Field" from """ + field_name +\
            """ withtemplate "field_template.html" %}"""
        return Template(template_text)

    def _form_template_labelless_with_request_user_for(self, identifier):
        field_name = '"' + identifier + '"'
        template_text = """{% load form_extras %}""" +\
            """{% field from """ + field_name +\
            """ for request.user withtemplate "field_template.html" %}"""
        return Template(template_text)

    def _form_template_labelless_for(self, identifier):
        field_name = '"' + identifier + '"'
        template_text = """{% load form_extras %}""" +\
            """{% field from """ + field_name +\
            """ withtemplate "field_template.html" %}"""
        return Template(template_text)

    def _form_template_create(self, identifier):
        field_name = '"' + identifier + '"'
        template_text = """{% load form_extras %}""" +\
            """{% create from """ + field_name +\
            """ in request.instance""" +\
            """ withtemplate "field_template.html" %}"""
        return Template(template_text)

    def _form_template_search(self):
        template_text = """{% load form_extras %}""" +\
            """{% search from search_json""" +\
            """ for request.user in request.instance """ +\
            """ withtemplate "field_template.html" %}"""
        return Template(template_text)

    def _write_field_template(self, text):
        with open(self.template_file_path, 'w') as f:
                f.write(text)

    def assert_plot_length_context_value(self, user, name, value,
                                         template_fn=None):
        if template_fn is None:
            template_fn = (self._form_template_with_request_user_for
                           if user else self._form_template_for)
        plot = Plot(length=12.3, instance=self.instance)
        plot.convert_to_display_units()

        template = template_fn('plot.length')
        self._write_field_template("{{" + name + "}}")
        with self.settings(TEMPLATE_DIRS=(self.template_dir,)):
            content = template.render(Context({
                'request': {'user': user, 'instance': self.instance},
#.........這裏部分代碼省略.........
開發者ID:JoshIUSBStudent,項目名稱:otm-core,代碼行數:103,代碼來源:test_templatetags.py

示例7: UserCanReadTagTest

# 需要導入模塊: from treemap.audit import Role [as 別名]
# 或者: from treemap.audit.Role import save [as 別名]
class UserCanReadTagTest(OTMTestCase):

    def setUp(self):
        self.instance = make_instance()

        self.user = make_user(username='user', password='user')

        self.role = Role(name='role', instance=self.instance, rep_thresh=0)
        self.role.save()

        self.user_perm, __ = FieldPermission.objects.get_or_create(
            model_name='Plot', field_name='width',
            permission_level=FieldPermission.NONE,
            role=self.role, instance=self.instance)

        iuser = InstanceUser(instance=self.instance, user=self.user,
                             role=self.role)
        iuser.save_with_user(self.user)

        inst_role = Role(name='inst def role',
                         instance=self.instance,
                         rep_thresh=0)
        inst_role.save()

        self.inst_perm, __ = FieldPermission.objects.get_or_create(
            model_name='Plot', field_name='width',
            permission_level=FieldPermission.NONE,
            role=inst_role, instance=self.instance)

        self.instance.default_role = inst_role
        self.instance.save()

        self.plot = Plot(instance=self.instance)

    basic_template = Template(
        """
        {% load auth_extras %}
        {% usercanread plot "width" as w %}
        plot width {{ w }}
        {% endusercanread %}
        """)

    def _render_basic_template_with_vars(self, user, plot):
        return UserCanReadTagTest.basic_template.render(
            Context({
                'request': {'user': user},
                'plot': plot})).strip()

    def test_works_with_empty_user_no_perm(self):
        self.assertEqual(
            self._render_basic_template_with_vars(None, self.plot), '')

    def test_works_with_empty_user_with_perm(self):
        perms = [FieldPermission.READ_ONLY,
                 FieldPermission.WRITE_WITH_AUDIT,
                 FieldPermission.WRITE_DIRECTLY]

        self.plot.width = 9

        for plevel in perms:
            self.inst_perm.permission_level = plevel
            self.inst_perm.save()

            self.assertEqual(
                self._render_basic_template_with_vars(None, self.plot),
                'plot width 9')

    def test_works_with_user_with_role_no_perm(self):
        self.assertEqual(
            self._render_basic_template_with_vars(self.user, self.plot), '')

    def test_works_with_user_with_role_with_perm(self):
        perms = [FieldPermission.READ_ONLY,
                 FieldPermission.WRITE_WITH_AUDIT,
                 FieldPermission.WRITE_DIRECTLY]

        self.plot.width = 9

        for plevel in perms:
            self.user_perm.permission_level = plevel
            self.user_perm.save()

            self.assertEqual(
                self._render_basic_template_with_vars(self.user, self.plot),
                'plot width 9')

    def test_works_with_udf(self):
        UserDefinedFieldDefinition.objects.create(
            instance=self.instance,
            model_type='Plot',
            datatype=json.dumps({'type': 'choice',
                                 'choices': ['a', 'b', 'c']}),
            iscollection=False,
            name='Test choice')

        udf_perm, __ = FieldPermission.objects.get_or_create(
            model_name='Plot', field_name='udf:Test choice',
            permission_level=FieldPermission.NONE,
            role=self.role, instance=self.instance)
        udf_perm.save()
#.........這裏部分代碼省略.........
開發者ID:JoshIUSBStudent,項目名稱:otm-core,代碼行數:103,代碼來源:test_templatetags.py

示例8: InlineFieldTagTests

# 需要導入模塊: from treemap.audit import Role [as 別名]
# 或者: from treemap.audit.Role import save [as 別名]
class InlineFieldTagTests(TestCase):
    def setUp(self):
        self.instance = make_instance()
        self.instance.config["advanced_search_fields"] = {}
        self.instance.save()
        self.role = Role(name="role", instance=self.instance, rep_thresh=0)
        self.role.save()

        self.observer = make_observer_user(self.instance)

        self.udf_role = Role(name="udf", instance=self.instance, rep_thresh=0)
        self.udf_role.save()

        self.template_dir = tempfile.mkdtemp()
        self.template_file_path = os.path.join(self.template_dir, "field_template.html")

        UserDefinedFieldDefinition.objects.create(
            instance=self.instance,
            model_type="Plot",
            datatype=json.dumps({"type": "choice", "choices": ["a", "b", "c"]}),
            iscollection=False,
            name="Test choice",
        )

        udf_perm, _ = FieldPermission.objects.get_or_create(
            model_name="Plot",
            field_name="udf:Test choice",
            permission_level=FieldPermission.READ_ONLY,
            role=self.role,
            instance=self.instance,
        )
        udf_perm.save()
        udf_write_perm, _ = FieldPermission.objects.get_or_create(
            model_name="Plot",
            field_name="udf:Test choice",
            permission_level=FieldPermission.WRITE_DIRECTLY,
            role=self.udf_role,
            instance=self.instance,
        )
        udf_write_perm.save()

    def tearDown(self):
        rmtree(self.template_dir)

    def _form_template_with_request_user_for(self, identifier):
        field_name = '"' + identifier + '"'
        template_text = (
            """{% load form_extras %}"""
            + """{% field "Test Field" from """
            + field_name
            + """ for request.user withtemplate "field_template.html" %}"""
        )
        return Template(template_text)

    def _form_template_for(self, identifier):
        field_name = '"' + identifier + '"'
        template_text = (
            """{% load form_extras %}"""
            + """{% field "Test Field" from """
            + field_name
            + """ withtemplate "field_template.html" %}"""
        )
        return Template(template_text)

    def _form_template_labelless_with_request_user_for(self, identifier):
        field_name = '"' + identifier + '"'
        template_text = (
            """{% load form_extras %}"""
            + """{% field from """
            + field_name
            + """ for request.user withtemplate "field_template.html" %}"""
        )
        return Template(template_text)

    def _form_template_labelless_for(self, identifier):
        field_name = '"' + identifier + '"'
        template_text = (
            """{% load form_extras %}"""
            + """{% field from """
            + field_name
            + """ withtemplate "field_template.html" %}"""
        )
        return Template(template_text)

    def _form_template_create(self, identifier):
        field_name = '"' + identifier + '"'
        template_text = (
            """{% load form_extras %}"""
            + """{% create from """
            + field_name
            + """ in request.instance"""
            + """ withtemplate "field_template.html" %}"""
        )
        return Template(template_text)

    def _form_template_search(self):
        template_text = (
            """{% load form_extras %}"""
            + """{% search from search_json"""
            + """ for request.user in request.instance """
#.........這裏部分代碼省略.........
開發者ID:heath,項目名稱:OTM2,代碼行數:103,代碼來源:templatetags.py

示例9: UserCanReadTagTest

# 需要導入模塊: from treemap.audit import Role [as 別名]
# 或者: from treemap.audit.Role import save [as 別名]
class UserCanReadTagTest(TestCase):
    def setUp(self):
        self.instance = make_instance()

        self.user = make_user(username="user", password="user")

        self.role = Role(name="role", instance=self.instance, rep_thresh=0)
        self.role.save()

        self.user_perm, _ = FieldPermission.objects.get_or_create(
            model_name="Plot",
            field_name="width",
            permission_level=FieldPermission.NONE,
            role=self.role,
            instance=self.instance,
        )

        iuser = InstanceUser(instance=self.instance, user=self.user, role=self.role)
        iuser.save_with_user(self.user)

        inst_role = Role(name="inst def role", instance=self.instance, rep_thresh=0)
        inst_role.save()

        self.inst_perm, _ = FieldPermission.objects.get_or_create(
            model_name="Plot",
            field_name="width",
            permission_level=FieldPermission.NONE,
            role=inst_role,
            instance=self.instance,
        )

        self.instance.default_role = inst_role
        self.instance.save()

        self.plot = Plot(instance=self.instance)

    basic_template = Template(
        """
        {% load auth_extras %}
        {% usercanread plot "width" as w %}
        plot width {{ w }}
        {% endusercanread %}
        """
    )

    def _render_basic_template_with_vars(self, user, plot):
        return UserCanReadTagTest.basic_template.render(Context({"request": {"user": user}, "plot": plot})).strip()

    def test_works_with_empty_user_no_perm(self):
        self.assertEqual(self._render_basic_template_with_vars(None, self.plot), "")

    def test_works_with_empty_user_with_perm(self):
        perms = [FieldPermission.READ_ONLY, FieldPermission.WRITE_WITH_AUDIT, FieldPermission.WRITE_DIRECTLY]

        self.plot.width = 9

        for plevel in perms:
            self.inst_perm.permission_level = plevel
            self.inst_perm.save()

            self.assertEqual(self._render_basic_template_with_vars(None, self.plot), "plot width 9")

    def test_works_with_user_with_role_no_perm(self):
        self.assertEqual(self._render_basic_template_with_vars(self.user, self.plot), "")

    def test_works_with_user_with_role_with_perm(self):
        perms = [FieldPermission.READ_ONLY, FieldPermission.WRITE_WITH_AUDIT, FieldPermission.WRITE_DIRECTLY]

        self.plot.width = 9

        for plevel in perms:
            self.user_perm.permission_level = plevel
            self.user_perm.save()

            self.assertEqual(self._render_basic_template_with_vars(self.user, self.plot), "plot width 9")

    def test_works_with_udf(self):
        UserDefinedFieldDefinition.objects.create(
            instance=self.instance,
            model_type="Plot",
            datatype=json.dumps({"type": "choice", "choices": ["a", "b", "c"]}),
            iscollection=False,
            name="Test choice",
        )

        udf_perm, _ = FieldPermission.objects.get_or_create(
            model_name="Plot",
            field_name="udf:Test choice",
            permission_level=FieldPermission.NONE,
            role=self.role,
            instance=self.instance,
        )
        udf_perm.save()

        plot = self.plot
        plot.udfs["Test choice"] = "b"

        def render():
            return (
                Template(
#.........這裏部分代碼省略.........
開發者ID:heath,項目名稱:OTM2,代碼行數:103,代碼來源:templatetags.py

示例10: FieldPermMgmtTest

# 需要導入模塊: from treemap.audit import Role [as 別名]
# 或者: from treemap.audit.Role import save [as 別名]
class FieldPermMgmtTest(OTMTestCase):
    def setUp(self):
        self.instance = make_instance()
        self.commander = make_commander_user(self.instance)

        self.new_role = Role(name='Ambassador', instance=self.instance,
                             rep_thresh=0)
        self.new_role.save()

        self.factory = RequestFactory()

    def make_updates(self, role_id, field_json):
        return {
            role_id: {
                'fields': field_json,
                'models': {}
            }
        }

    def test_updates(self):

        # TODO: For now, don't use '2', which is pending
        updates = self.make_updates(
            self.new_role.pk, {'Tree.diameter': 3})

        json_updates = json.dumps(updates)
        request = make_request(method='PUT', body=json_updates)
        roles_update(request, self.instance)

        #requery new_role
        self.new_role = Role.objects.get(pk=self.new_role.pk)

        self.assertEqual(1,
                         FieldPermission.objects.filter(
                             model_name='Tree',
                             field_name='diameter',
                             instance=self.instance,
                             role=self.new_role,
                             permission_level=3).count())

    def test_no_updates(self):
        updates = {}

        json_updates = json.dumps(updates)
        request = make_request(method='PUT', body=json_updates)
        roles_update(request, self.instance)

    def assertUpdatesRaisesValidation(self, updates):
        json_updates = json.dumps(updates)
        request = make_request(method='PUT', body=json_updates)
        self.assertRaises(ValidationError, roles_update,
                          request, self.instance)

    def test_invalid_model_does_not_exist_integration(self):
        updates = self.make_updates(
            self.new_role.pk, {'Gethen.model_name': 2})
        self.assertUpdatesRaisesValidation(updates)

    def test_invalid_model_not_authorizable_integration(self):
        updates = self.make_updates(
            self.new_role.pk, {'FieldPermission.model_name': 2})
        self.assertUpdatesRaisesValidation(updates)

    def test_invalid_field_name_integration(self):
        updates = self.make_updates(
            self.new_role.pk, {'Tree.model_name': 2})
        self.assertUpdatesRaisesValidation(updates)

    def test_invalid_role_id_integration(self):
        updates = self.make_updates(
            100, {'Tree.readonly': 2})
        self.assertUpdatesRaisesValidation(updates)
開發者ID:OpenTreeMap,項目名稱:otm-core,代碼行數:74,代碼來源:test_roles.py

示例11: ModelPermMgmtTest

# 需要導入模塊: from treemap.audit import Role [as 別名]
# 或者: from treemap.audit.Role import save [as 別名]
class ModelPermMgmtTest(OTMTestCase):
    def setUp(self):
        self.instance = make_instance()

        self.commander = make_commander_user(self.instance)

        self.new_role = Role(name='Ambassador', instance=self.instance,
                             rep_thresh=0)
        self.new_role.save()

        self.factory = RequestFactory()

        self.RolePermissionModel = Role.instance_permissions.through

    def request_updates(self, perm_specs):
        updates = {self.new_role.pk: {'fields': {}, 'models': perm_specs}}
        request = make_request(method='PUT', body=json.dumps(updates))
        roles_update(request, self.instance)

    def assert_assignment(self, permission, role, is_assigned=True):
        assignment = self.RolePermissionModel.objects.filter(
            role=role, permission=permission)
        self.assertEqual(assignment.exists(), is_assigned)

    def test_instance_assignment(self):
        permission = make_permission('do_all_the_things', Instance)
        self.request_updates({'Instance.do_all_the_things': True})

        self.assert_assignment(permission, self.new_role)

    def test_model_assignment(self):
        self.instance.add_map_feature_types(['Bioswale'])
        permissions = [
            'Plot.add_plot',
            'Plot.delete_plot',
            'Tree.add_tree',
            'Tree.delete_tree',
            'TreePhoto.add_treephoto',
            'TreePhoto.delete_treephoto',
            'Bioswale.add_bioswale',
            'Bioswale.delete_bioswale',
            'MapFeaturePhoto.add_bioswalephoto',
            'MapFeaturePhoto.delete_bioswalephoto']

        self.request_updates(
            dict(zip(permissions, [True] * len(permissions))))

        for existing in permissions:
            __, codename = dotted_split(existing, 2, maxsplit=1)
            permission = Permission.objects.get(codename=codename)
            self.assert_assignment(permission, self.new_role)

    def test_unassignment(self):
        instance_permission = make_permission('do_all_the_things', Instance)
        add_plot_permission = Permission.objects.get(codename='add_plot')
        self.assertIsNotNone(instance_permission)
        self.assertIsNotNone(add_plot_permission)

        self.RolePermissionModel.objects.bulk_create([
            self.RolePermissionModel(
                role=self.new_role, permission=instance_permission),
            self.RolePermissionModel(
                role=self.new_role, permission=add_plot_permission)])

        self.assertEqual(
            self.RolePermissionModel.objects.filter(
                role=self.new_role).count(), 2)

        self.request_updates({
            'Instance.do_all_the_things': False,
            'Plot.add_plot': False})

        self.assertEqual(
            self.RolePermissionModel.objects.filter(
                role=self.new_role).count(), 0)
開發者ID:OpenTreeMap,項目名稱:otm-core,代碼行數:77,代碼來源:test_roles.py


注:本文中的treemap.audit.Role.save方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。