mirror of
https://pagure.io/fm-orchestrator.git
synced 2026-04-24 10:43:16 +08:00
Support NO_AUTH changing owner in patch method
This commit is contained in:
@@ -668,3 +668,32 @@ class TestViews(unittest.TestCase):
|
||||
|
||||
build = ModuleBuild.query.filter(ModuleBuild.id == result['id']).one()
|
||||
self.assertTrue(build.owner == result['owner'] == 'foo')
|
||||
|
||||
@patch('module_build_service.auth.get_user', return_value=anonymous_user)
|
||||
@patch('module_build_service.scm.SCM')
|
||||
@patch("module_build_service.config.Config.no_auth", new_callable=PropertyMock)
|
||||
def test_patch_set_different_owner(self, mocked_no_auth, mocked_scm, mocked_get_user):
|
||||
MockedSCM(mocked_scm, 'testmodule', 'testmodule.yaml',
|
||||
'620ec77321b2ea7b0d67d82992dda3e1d67055b4')
|
||||
|
||||
mocked_no_auth.return_value = True
|
||||
data = {
|
||||
'branch': 'master',
|
||||
'scmurl': 'git://pkgs.stg.fedoraproject.org/modules/'
|
||||
'testmodule.git?#68931c90de214d9d13feefbd35246a81b6cb8d49',
|
||||
'owner': 'foo',
|
||||
}
|
||||
rv = self.client.post('/module-build-service/1/module-builds/', data=json.dumps(data))
|
||||
r1 = json.loads(rv.data)
|
||||
|
||||
url = '/module-build-service/1/module-builds/' + str(r1['id'])
|
||||
r2 = self.client.patch(url, data=json.dumps({'state': 'failed'}))
|
||||
self.assertEquals(r2.status_code, 403)
|
||||
|
||||
r3 = self.client.patch(url, data=json.dumps({'state': 'failed', 'owner': 'foo'}))
|
||||
self.assertEquals(r3.status_code, 200)
|
||||
|
||||
mocked_no_auth.return_value = False
|
||||
r3 = self.client.patch(url, data=json.dumps({'state': 'failed', 'owner': 'foo'}))
|
||||
self.assertEquals(r3.status_code, 400)
|
||||
self.assertIn("The request contains 'owner' parameter", json.loads(r3.data)['message'])
|
||||
|
||||
Reference in New Issue
Block a user