This initial change provides the support in keystoneclient to match the api specified in the blueprint. Keystone itself does not yet support these calls, so if you actually called these, then you would get an error from the server. However the changes should be benign in terms of other api calls. Blueprint keystone/+spec/user-groups Api changes: review.openstack.org/#/c/18138 DocImpact Change-Id: I9abfa82b39fa0c6d58fe0d22622944d3e6be39be
		
			
				
	
	
		
			519 lines
		
	
	
		
			16 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			519 lines
		
	
	
		
			16 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
# vim: tabstop=4 shiftwidth=4 softtabstop=4
 | 
						|
 | 
						|
# Copyright 2012 OpenStack LLC
 | 
						|
#
 | 
						|
# Licensed under the Apache License, Version 2.0 (the "License"); you may
 | 
						|
# not use this file except in compliance with the License. You may obtain
 | 
						|
# a copy of the License at
 | 
						|
#
 | 
						|
#      http://www.apache.org/licenses/LICENSE-2.0
 | 
						|
#
 | 
						|
# Unless required by applicable law or agreed to in writing, software
 | 
						|
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
 | 
						|
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
 | 
						|
# License for the specific language governing permissions and limitations
 | 
						|
# under the License.
 | 
						|
 | 
						|
import copy
 | 
						|
import urlparse
 | 
						|
import uuid
 | 
						|
 | 
						|
import requests
 | 
						|
 | 
						|
from keystoneclient import exceptions
 | 
						|
from keystoneclient.v3 import roles
 | 
						|
from tests.v3 import utils
 | 
						|
 | 
						|
 | 
						|
class RoleTests(utils.TestCase, utils.CrudTests):
 | 
						|
    def setUp(self):
 | 
						|
        super(RoleTests, self).setUp()
 | 
						|
        self.additionalSetUp()
 | 
						|
        self.key = 'role'
 | 
						|
        self.collection_key = 'roles'
 | 
						|
        self.model = roles.Role
 | 
						|
        self.manager = self.client.roles
 | 
						|
 | 
						|
    def new_ref(self, **kwargs):
 | 
						|
        kwargs = super(RoleTests, self).new_ref(**kwargs)
 | 
						|
        kwargs.setdefault('name', uuid.uuid4().hex)
 | 
						|
        return kwargs
 | 
						|
 | 
						|
    def test_domain_role_grant(self):
 | 
						|
        user_id = uuid.uuid4().hex
 | 
						|
        domain_id = uuid.uuid4().hex
 | 
						|
        ref = self.new_ref()
 | 
						|
        resp = utils.TestResponse({
 | 
						|
            "status_code": 201,
 | 
						|
            "text": '',
 | 
						|
        })
 | 
						|
 | 
						|
        method = 'PUT'
 | 
						|
        kwargs = copy.copy(self.TEST_REQUEST_BASE)
 | 
						|
        kwargs['headers'] = self.headers[method]
 | 
						|
        requests.request(
 | 
						|
            method,
 | 
						|
            urlparse.urljoin(
 | 
						|
                self.TEST_URL,
 | 
						|
                'v3/domains/%s/users/%s/%s/%s' % (
 | 
						|
                    domain_id, user_id, self.collection_key, ref['id'])),
 | 
						|
            **kwargs).AndReturn((resp))
 | 
						|
        self.mox.ReplayAll()
 | 
						|
 | 
						|
        self.manager.grant(role=ref['id'], domain=domain_id, user=user_id)
 | 
						|
 | 
						|
    def test_domain_group_role_grant(self):
 | 
						|
        group_id = uuid.uuid4().hex
 | 
						|
        domain_id = uuid.uuid4().hex
 | 
						|
        ref = self.new_ref()
 | 
						|
        resp = utils.TestResponse({
 | 
						|
            "status_code": 201,
 | 
						|
            "text": '',
 | 
						|
        })
 | 
						|
 | 
						|
        method = 'PUT'
 | 
						|
        kwargs = copy.copy(self.TEST_REQUEST_BASE)
 | 
						|
        kwargs['headers'] = self.headers[method]
 | 
						|
        requests.request(
 | 
						|
            method,
 | 
						|
            urlparse.urljoin(
 | 
						|
                self.TEST_URL,
 | 
						|
                'v3/domains/%s/groups/%s/%s/%s' % (
 | 
						|
                    domain_id, group_id, self.collection_key, ref['id'])),
 | 
						|
            **kwargs).AndReturn((resp))
 | 
						|
        self.mox.ReplayAll()
 | 
						|
 | 
						|
        self.manager.grant(role=ref['id'], domain=domain_id, group=group_id)
 | 
						|
 | 
						|
    def test_domain_role_list(self):
 | 
						|
        user_id = uuid.uuid4().hex
 | 
						|
        domain_id = uuid.uuid4().hex
 | 
						|
        ref_list = [self.new_ref(), self.new_ref()]
 | 
						|
        resp = utils.TestResponse({
 | 
						|
            "status_code": 200,
 | 
						|
            "text": self.serialize(ref_list),
 | 
						|
        })
 | 
						|
 | 
						|
        method = 'GET'
 | 
						|
        kwargs = copy.copy(self.TEST_REQUEST_BASE)
 | 
						|
        kwargs['headers'] = self.headers[method]
 | 
						|
        requests.request(
 | 
						|
            method,
 | 
						|
            urlparse.urljoin(
 | 
						|
                self.TEST_URL,
 | 
						|
                'v3/domains/%s/users/%s/%s' % (
 | 
						|
                    domain_id, user_id, self.collection_key)),
 | 
						|
            **kwargs).AndReturn((resp))
 | 
						|
        self.mox.ReplayAll()
 | 
						|
 | 
						|
        self.manager.list(domain=domain_id, user=user_id)
 | 
						|
 | 
						|
    def test_domain_group_role_list(self):
 | 
						|
        group_id = uuid.uuid4().hex
 | 
						|
        domain_id = uuid.uuid4().hex
 | 
						|
        ref_list = [self.new_ref(), self.new_ref()]
 | 
						|
        resp = utils.TestResponse({
 | 
						|
            "status_code": 200,
 | 
						|
            "text": self.serialize(ref_list),
 | 
						|
        })
 | 
						|
 | 
						|
        method = 'GET'
 | 
						|
        kwargs = copy.copy(self.TEST_REQUEST_BASE)
 | 
						|
        kwargs['headers'] = self.headers[method]
 | 
						|
        requests.request(
 | 
						|
            method,
 | 
						|
            urlparse.urljoin(
 | 
						|
                self.TEST_URL,
 | 
						|
                'v3/domains/%s/groups/%s/%s' % (
 | 
						|
                    domain_id, group_id, self.collection_key)),
 | 
						|
            **kwargs).AndReturn((resp))
 | 
						|
        self.mox.ReplayAll()
 | 
						|
 | 
						|
        self.manager.list(domain=domain_id, group=group_id)
 | 
						|
 | 
						|
    def test_domain_role_check(self):
 | 
						|
        user_id = uuid.uuid4().hex
 | 
						|
        domain_id = uuid.uuid4().hex
 | 
						|
        ref = self.new_ref()
 | 
						|
        resp = utils.TestResponse({
 | 
						|
            "status_code": 204,
 | 
						|
            "text": '',
 | 
						|
        })
 | 
						|
 | 
						|
        method = 'HEAD'
 | 
						|
        kwargs = copy.copy(self.TEST_REQUEST_BASE)
 | 
						|
        kwargs['headers'] = self.headers[method]
 | 
						|
        requests.request(
 | 
						|
            method,
 | 
						|
            urlparse.urljoin(
 | 
						|
                self.TEST_URL,
 | 
						|
                'v3/domains/%s/users/%s/%s/%s' % (
 | 
						|
                    domain_id, user_id, self.collection_key, ref['id'])),
 | 
						|
            **kwargs).AndReturn((resp))
 | 
						|
        self.mox.ReplayAll()
 | 
						|
 | 
						|
        self.manager.check(role=ref['id'], domain=domain_id,
 | 
						|
                           user=user_id)
 | 
						|
 | 
						|
    def test_domain_group_role_check(self):
 | 
						|
        return
 | 
						|
        group_id = uuid.uuid4().hex
 | 
						|
        domain_id = uuid.uuid4().hex
 | 
						|
        ref = self.new_ref()
 | 
						|
        resp = utils.TestResponse({
 | 
						|
            "status_code": 204,
 | 
						|
            "text": '',
 | 
						|
        })
 | 
						|
 | 
						|
        method = 'HEAD'
 | 
						|
        kwargs = copy.copy(self.TEST_REQUEST_BASE)
 | 
						|
        kwargs['headers'] = self.headers[method]
 | 
						|
        requests.request(
 | 
						|
            method,
 | 
						|
            urlparse.urljoin(
 | 
						|
                self.TEST_URL,
 | 
						|
                'v3/domains/%s/groups/%s/%s/%s' % (
 | 
						|
                    domain_id, group_id, self.collection_key, ref['id'])),
 | 
						|
            **kwargs).AndReturn((resp))
 | 
						|
        self.mox.ReplayAll()
 | 
						|
 | 
						|
        self.manager.check(role=ref['id'], domain=domain_id, group=group_id)
 | 
						|
 | 
						|
    def test_domain_role_revoke(self):
 | 
						|
        user_id = uuid.uuid4().hex
 | 
						|
        domain_id = uuid.uuid4().hex
 | 
						|
        ref = self.new_ref()
 | 
						|
        resp = utils.TestResponse({
 | 
						|
            "status_code": 204,
 | 
						|
            "text": '',
 | 
						|
        })
 | 
						|
 | 
						|
        method = 'DELETE'
 | 
						|
        kwargs = copy.copy(self.TEST_REQUEST_BASE)
 | 
						|
        kwargs['headers'] = self.headers[method]
 | 
						|
        requests.request(
 | 
						|
            method,
 | 
						|
            urlparse.urljoin(
 | 
						|
                self.TEST_URL,
 | 
						|
                'v3/domains/%s/users/%s/%s/%s' % (
 | 
						|
                    domain_id, user_id, self.collection_key, ref['id'])),
 | 
						|
            **kwargs).AndReturn((resp))
 | 
						|
        self.mox.ReplayAll()
 | 
						|
 | 
						|
        self.manager.revoke(role=ref['id'], domain=domain_id, user=user_id)
 | 
						|
 | 
						|
    def test_domain_group_role_revoke(self):
 | 
						|
        group_id = uuid.uuid4().hex
 | 
						|
        domain_id = uuid.uuid4().hex
 | 
						|
        ref = self.new_ref()
 | 
						|
        resp = utils.TestResponse({
 | 
						|
            "status_code": 204,
 | 
						|
            "text": '',
 | 
						|
        })
 | 
						|
 | 
						|
        method = 'DELETE'
 | 
						|
        kwargs = copy.copy(self.TEST_REQUEST_BASE)
 | 
						|
        kwargs['headers'] = self.headers[method]
 | 
						|
        requests.request(
 | 
						|
            method,
 | 
						|
            urlparse.urljoin(
 | 
						|
                self.TEST_URL,
 | 
						|
                'v3/domains/%s/groups/%s/%s/%s' % (
 | 
						|
                    domain_id, group_id, self.collection_key, ref['id'])),
 | 
						|
            **kwargs).AndReturn((resp))
 | 
						|
        self.mox.ReplayAll()
 | 
						|
 | 
						|
        self.manager.revoke(role=ref['id'], domain=domain_id, group=group_id)
 | 
						|
 | 
						|
    def test_project_role_grant(self):
 | 
						|
        user_id = uuid.uuid4().hex
 | 
						|
        project_id = uuid.uuid4().hex
 | 
						|
        ref = self.new_ref()
 | 
						|
        resp = utils.TestResponse({
 | 
						|
            "status_code": 201,
 | 
						|
            "text": '',
 | 
						|
        })
 | 
						|
 | 
						|
        method = 'PUT'
 | 
						|
        kwargs = copy.copy(self.TEST_REQUEST_BASE)
 | 
						|
        kwargs['headers'] = self.headers[method]
 | 
						|
        requests.request(
 | 
						|
            method,
 | 
						|
            urlparse.urljoin(
 | 
						|
                self.TEST_URL,
 | 
						|
                'v3/projects/%s/users/%s/%s/%s' % (
 | 
						|
                    project_id, user_id, self.collection_key, ref['id'])),
 | 
						|
            **kwargs).AndReturn((resp))
 | 
						|
        self.mox.ReplayAll()
 | 
						|
 | 
						|
        self.manager.grant(role=ref['id'], project=project_id, user=user_id)
 | 
						|
 | 
						|
    def test_project_group_role_grant(self):
 | 
						|
        group_id = uuid.uuid4().hex
 | 
						|
        project_id = uuid.uuid4().hex
 | 
						|
        ref = self.new_ref()
 | 
						|
        resp = utils.TestResponse({
 | 
						|
            "status_code": 201,
 | 
						|
            "text": '',
 | 
						|
        })
 | 
						|
 | 
						|
        method = 'PUT'
 | 
						|
        kwargs = copy.copy(self.TEST_REQUEST_BASE)
 | 
						|
        kwargs['headers'] = self.headers[method]
 | 
						|
        requests.request(
 | 
						|
            method,
 | 
						|
            urlparse.urljoin(
 | 
						|
                self.TEST_URL,
 | 
						|
                'v3/projects/%s/groups/%s/%s/%s' % (
 | 
						|
                    project_id, group_id, self.collection_key, ref['id'])),
 | 
						|
            **kwargs).AndReturn((resp))
 | 
						|
        self.mox.ReplayAll()
 | 
						|
 | 
						|
        self.manager.grant(role=ref['id'], project=project_id, group=group_id)
 | 
						|
 | 
						|
    def test_project_role_list(self):
 | 
						|
        user_id = uuid.uuid4().hex
 | 
						|
        project_id = uuid.uuid4().hex
 | 
						|
        ref_list = [self.new_ref(), self.new_ref()]
 | 
						|
        resp = utils.TestResponse({
 | 
						|
            "status_code": 200,
 | 
						|
            "text": self.serialize(ref_list),
 | 
						|
        })
 | 
						|
 | 
						|
        method = 'GET'
 | 
						|
        kwargs = copy.copy(self.TEST_REQUEST_BASE)
 | 
						|
        kwargs['headers'] = self.headers[method]
 | 
						|
        requests.request(
 | 
						|
            method,
 | 
						|
            urlparse.urljoin(
 | 
						|
                self.TEST_URL,
 | 
						|
                'v3/projects/%s/users/%s/%s' % (
 | 
						|
                    project_id, user_id, self.collection_key)),
 | 
						|
            **kwargs).AndReturn((resp))
 | 
						|
        self.mox.ReplayAll()
 | 
						|
 | 
						|
        self.manager.list(project=project_id, user=user_id)
 | 
						|
 | 
						|
    def test_project_group_role_list(self):
 | 
						|
        group_id = uuid.uuid4().hex
 | 
						|
        project_id = uuid.uuid4().hex
 | 
						|
        ref_list = [self.new_ref(), self.new_ref()]
 | 
						|
        resp = utils.TestResponse({
 | 
						|
            "status_code": 200,
 | 
						|
            "text": self.serialize(ref_list),
 | 
						|
        })
 | 
						|
 | 
						|
        method = 'GET'
 | 
						|
        kwargs = copy.copy(self.TEST_REQUEST_BASE)
 | 
						|
        kwargs['headers'] = self.headers[method]
 | 
						|
        requests.request(
 | 
						|
            method,
 | 
						|
            urlparse.urljoin(
 | 
						|
                self.TEST_URL,
 | 
						|
                'v3/projects/%s/groups/%s/%s' % (
 | 
						|
                    project_id, group_id, self.collection_key)),
 | 
						|
            **kwargs).AndReturn((resp))
 | 
						|
        self.mox.ReplayAll()
 | 
						|
 | 
						|
        self.manager.list(project=project_id, group=group_id)
 | 
						|
 | 
						|
    def test_project_role_check(self):
 | 
						|
        user_id = uuid.uuid4().hex
 | 
						|
        project_id = uuid.uuid4().hex
 | 
						|
        ref = self.new_ref()
 | 
						|
        resp = utils.TestResponse({
 | 
						|
            "status_code": 200,
 | 
						|
            "text": '',
 | 
						|
        })
 | 
						|
 | 
						|
        method = 'HEAD'
 | 
						|
        kwargs = copy.copy(self.TEST_REQUEST_BASE)
 | 
						|
        kwargs['headers'] = self.headers[method]
 | 
						|
        requests.request(
 | 
						|
            method,
 | 
						|
            urlparse.urljoin(
 | 
						|
                self.TEST_URL,
 | 
						|
                'v3/projects/%s/users/%s/%s/%s' % (
 | 
						|
                    project_id, user_id, self.collection_key, ref['id'])),
 | 
						|
            **kwargs).AndReturn((resp))
 | 
						|
        self.mox.ReplayAll()
 | 
						|
 | 
						|
        self.manager.check(role=ref['id'], project=project_id, user=user_id)
 | 
						|
 | 
						|
    def test_project_group_role_check(self):
 | 
						|
        group_id = uuid.uuid4().hex
 | 
						|
        project_id = uuid.uuid4().hex
 | 
						|
        ref = self.new_ref()
 | 
						|
        resp = utils.TestResponse({
 | 
						|
            "status_code": 200,
 | 
						|
            "text": '',
 | 
						|
        })
 | 
						|
 | 
						|
        method = 'HEAD'
 | 
						|
        kwargs = copy.copy(self.TEST_REQUEST_BASE)
 | 
						|
        kwargs['headers'] = self.headers[method]
 | 
						|
        requests.request(
 | 
						|
            method,
 | 
						|
            urlparse.urljoin(
 | 
						|
                self.TEST_URL,
 | 
						|
                'v3/projects/%s/groups/%s/%s/%s' % (
 | 
						|
                    project_id, group_id, self.collection_key, ref['id'])),
 | 
						|
            **kwargs).AndReturn((resp))
 | 
						|
        self.mox.ReplayAll()
 | 
						|
 | 
						|
        self.manager.check(role=ref['id'], project=project_id, group=group_id)
 | 
						|
 | 
						|
    def test_project_role_revoke(self):
 | 
						|
        user_id = uuid.uuid4().hex
 | 
						|
        project_id = uuid.uuid4().hex
 | 
						|
        ref = self.new_ref()
 | 
						|
        resp = utils.TestResponse({
 | 
						|
            "status_code": 204,
 | 
						|
            "text": '',
 | 
						|
        })
 | 
						|
 | 
						|
        method = 'DELETE'
 | 
						|
        kwargs = copy.copy(self.TEST_REQUEST_BASE)
 | 
						|
        kwargs['headers'] = self.headers[method]
 | 
						|
        requests.request(
 | 
						|
            method,
 | 
						|
            urlparse.urljoin(
 | 
						|
                self.TEST_URL,
 | 
						|
                'v3/projects/%s/users/%s/%s/%s' % (
 | 
						|
                    project_id, user_id, self.collection_key, ref['id'])),
 | 
						|
            **kwargs).AndReturn((resp))
 | 
						|
        self.mox.ReplayAll()
 | 
						|
 | 
						|
        self.manager.revoke(role=ref['id'], project=project_id, user=user_id)
 | 
						|
 | 
						|
    def test_project_group_role_revoke(self):
 | 
						|
        group_id = uuid.uuid4().hex
 | 
						|
        project_id = uuid.uuid4().hex
 | 
						|
        ref = self.new_ref()
 | 
						|
        resp = utils.TestResponse({
 | 
						|
            "status_code": 204,
 | 
						|
            "text": '',
 | 
						|
        })
 | 
						|
 | 
						|
        method = 'DELETE'
 | 
						|
        kwargs = copy.copy(self.TEST_REQUEST_BASE)
 | 
						|
        kwargs['headers'] = self.headers[method]
 | 
						|
        requests.request(
 | 
						|
            method,
 | 
						|
            urlparse.urljoin(
 | 
						|
                self.TEST_URL,
 | 
						|
                'v3/projects/%s/groups/%s/%s/%s' % (
 | 
						|
                    project_id, group_id, self.collection_key, ref['id'])),
 | 
						|
            **kwargs).AndReturn((resp))
 | 
						|
        self.mox.ReplayAll()
 | 
						|
 | 
						|
        self.manager.revoke(role=ref['id'], project=project_id, group=group_id)
 | 
						|
 | 
						|
    def test_domain_project_role_grant_fails(self):
 | 
						|
        user_id = uuid.uuid4().hex
 | 
						|
        project_id = uuid.uuid4().hex
 | 
						|
        domain_id = uuid.uuid4().hex
 | 
						|
        ref = self.new_ref()
 | 
						|
 | 
						|
        self.assertRaises(
 | 
						|
            exceptions.ValidationError,
 | 
						|
            self.manager.grant,
 | 
						|
            role=ref['id'],
 | 
						|
            domain=domain_id,
 | 
						|
            project=project_id,
 | 
						|
            user=user_id)
 | 
						|
 | 
						|
    def test_domain_project_role_list_fails(self):
 | 
						|
        user_id = uuid.uuid4().hex
 | 
						|
        project_id = uuid.uuid4().hex
 | 
						|
        domain_id = uuid.uuid4().hex
 | 
						|
 | 
						|
        self.assertRaises(
 | 
						|
            exceptions.ValidationError,
 | 
						|
            self.manager.list,
 | 
						|
            domain=domain_id,
 | 
						|
            project=project_id,
 | 
						|
            user=user_id)
 | 
						|
 | 
						|
    def test_domain_project_role_check_fails(self):
 | 
						|
        user_id = uuid.uuid4().hex
 | 
						|
        project_id = uuid.uuid4().hex
 | 
						|
        domain_id = uuid.uuid4().hex
 | 
						|
        ref = self.new_ref()
 | 
						|
 | 
						|
        self.assertRaises(
 | 
						|
            exceptions.ValidationError,
 | 
						|
            self.manager.check,
 | 
						|
            role=ref['id'],
 | 
						|
            domain=domain_id,
 | 
						|
            project=project_id,
 | 
						|
            user=user_id)
 | 
						|
 | 
						|
    def test_domain_project_role_revoke_fails(self):
 | 
						|
        user_id = uuid.uuid4().hex
 | 
						|
        project_id = uuid.uuid4().hex
 | 
						|
        domain_id = uuid.uuid4().hex
 | 
						|
        ref = self.new_ref()
 | 
						|
 | 
						|
        self.assertRaises(
 | 
						|
            exceptions.ValidationError,
 | 
						|
            self.manager.revoke,
 | 
						|
            role=ref['id'],
 | 
						|
            domain=domain_id,
 | 
						|
            project=project_id,
 | 
						|
            user=user_id)
 | 
						|
 | 
						|
    def test_user_group_role_grant_fails(self):
 | 
						|
        user_id = uuid.uuid4().hex
 | 
						|
        group_id = uuid.uuid4().hex
 | 
						|
        project_id = uuid.uuid4().hex
 | 
						|
        ref = self.new_ref()
 | 
						|
 | 
						|
        self.assertRaises(
 | 
						|
            exceptions.ValidationError,
 | 
						|
            self.manager.grant,
 | 
						|
            role=ref['id'],
 | 
						|
            project=project_id,
 | 
						|
            group=group_id,
 | 
						|
            user=user_id)
 | 
						|
 | 
						|
    def test_user_group_role_list_fails(self):
 | 
						|
        user_id = uuid.uuid4().hex
 | 
						|
        group_id = uuid.uuid4().hex
 | 
						|
        project_id = uuid.uuid4().hex
 | 
						|
 | 
						|
        self.assertRaises(
 | 
						|
            exceptions.ValidationError,
 | 
						|
            self.manager.list,
 | 
						|
            project=project_id,
 | 
						|
            group=group_id,
 | 
						|
            user=user_id)
 | 
						|
 | 
						|
    def test_user_group_role_check_fails(self):
 | 
						|
        user_id = uuid.uuid4().hex
 | 
						|
        group_id = uuid.uuid4().hex
 | 
						|
        project_id = uuid.uuid4().hex
 | 
						|
        ref = self.new_ref()
 | 
						|
 | 
						|
        self.assertRaises(
 | 
						|
            exceptions.ValidationError,
 | 
						|
            self.manager.check,
 | 
						|
            role=ref['id'],
 | 
						|
            project=project_id,
 | 
						|
            group=group_id,
 | 
						|
            user=user_id)
 | 
						|
 | 
						|
    def test_user_group_role_revoke_fails(self):
 | 
						|
        user_id = uuid.uuid4().hex
 | 
						|
        group_id = uuid.uuid4().hex
 | 
						|
        project_id = uuid.uuid4().hex
 | 
						|
        ref = self.new_ref()
 | 
						|
 | 
						|
        self.assertRaises(
 | 
						|
            exceptions.ValidationError,
 | 
						|
            self.manager.revoke,
 | 
						|
            role=ref['id'],
 | 
						|
            project=project_id,
 | 
						|
            group=group_id,
 | 
						|
            user=user_id)
 |