-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #702 from UW-GAC/feature/workspace-adapter-after-a…
…nvil-import Automatically share workspaces with admin group after import
- Loading branch information
Showing
2 changed files
with
201 additions
and
1 deletion.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,7 +1,12 @@ | ||
import responses | ||
from anvil_consortium_manager.adapters.default import DefaultWorkspaceAdapter | ||
from anvil_consortium_manager.models import Account, GroupGroupMembership, WorkspaceGroupSharing | ||
from anvil_consortium_manager.tests.factories import AccountFactory, ManagedGroupFactory, WorkspaceFactory | ||
from anvil_consortium_manager.tests.factories import ( | ||
AccountFactory, | ||
ManagedGroupFactory, | ||
WorkspaceFactory, | ||
WorkspaceGroupSharingFactory, | ||
) | ||
from anvil_consortium_manager.tests.utils import AnVILAPIMockTestMixin | ||
from django.test import TestCase, override_settings | ||
|
||
|
@@ -230,6 +235,172 @@ def test_after_anvil_create_no_admins_group(self): | |
# No WorkspaceGroupSharing objects were created. | ||
self.assertEqual(WorkspaceGroupSharing.objects.count(), 0) | ||
|
||
def test_after_anvil_import(self): | ||
admins_group = ManagedGroupFactory.create(name="TEST_PRIMED_CC_ADMINS") | ||
workspace = WorkspaceFactory.create( | ||
billing_project__name="bar", name="foo", workspace_type=self.adapter.get_type() | ||
) | ||
# API response for admin group workspace owner. | ||
acls = [ | ||
{ | ||
"email": "[email protected]", | ||
"accessLevel": "OWNER", | ||
"canShare": False, | ||
"canCompute": True, | ||
} | ||
] | ||
self.anvil_response_mock.add( | ||
responses.PATCH, | ||
self.api_client.rawls_entry_point + "/api/workspaces/bar/foo/acl?inviteUsersNotFound=false", | ||
status=200, | ||
match=[responses.matchers.json_params_matcher(acls)], | ||
json={"invitesSent": {}, "usersNotFound": {}, "usersUpdated": acls}, | ||
) | ||
# Run the adapter method. | ||
self.adapter.after_anvil_import(workspace) | ||
# Check for WorkspaceGroupSharing. | ||
self.assertEqual(WorkspaceGroupSharing.objects.count(), 1) | ||
sharing = WorkspaceGroupSharing.objects.first() | ||
self.assertEqual(sharing.workspace, workspace) | ||
self.assertEqual(sharing.group, admins_group) | ||
self.assertEqual(sharing.access, WorkspaceGroupSharing.OWNER) | ||
self.assertTrue(sharing.can_compute) | ||
|
||
@override_settings(ANVIL_CC_ADMINS_GROUP_NAME="foobar") | ||
def test_after_anvil_import_different_admins_group(self): | ||
admins_group = ManagedGroupFactory.create(name="foobar") | ||
workspace = WorkspaceFactory.create( | ||
billing_project__name="bar", name="foo", workspace_type=self.adapter.get_type() | ||
) | ||
# API response for admin group workspace owner. | ||
acls = [ | ||
{ | ||
"email": "[email protected]", | ||
"accessLevel": "OWNER", | ||
"canShare": False, | ||
"canCompute": True, | ||
} | ||
] | ||
self.anvil_response_mock.add( | ||
responses.PATCH, | ||
self.api_client.rawls_entry_point + "/api/workspaces/bar/foo/acl?inviteUsersNotFound=false", | ||
status=200, | ||
match=[responses.matchers.json_params_matcher(acls)], | ||
json={"invitesSent": {}, "usersNotFound": {}, "usersUpdated": acls}, | ||
) | ||
# Run the adapter method. | ||
self.adapter.after_anvil_import(workspace) | ||
# Check for WorkspaceGroupSharing. | ||
self.assertEqual(WorkspaceGroupSharing.objects.count(), 1) | ||
sharing = WorkspaceGroupSharing.objects.first() | ||
self.assertEqual(sharing.workspace, workspace) | ||
self.assertEqual(sharing.group, admins_group) | ||
self.assertEqual(sharing.access, WorkspaceGroupSharing.OWNER) | ||
self.assertTrue(sharing.can_compute) | ||
|
||
def test_after_anvil_import_no_admins_group(self): | ||
workspace = WorkspaceFactory.create( | ||
billing_project__name="bar", name="foo", workspace_type=self.adapter.get_type() | ||
) | ||
# Run the adapter method. | ||
self.adapter.after_anvil_import(workspace) | ||
# No WorkspaceGroupSharing objects were created. | ||
self.assertEqual(WorkspaceGroupSharing.objects.count(), 0) | ||
|
||
def test_after_anvil_import_already_shared(self): | ||
admins_group = ManagedGroupFactory.create(name="TEST_PRIMED_CC_ADMINS") | ||
workspace = WorkspaceFactory.create(workspace_type=self.adapter.get_type()) | ||
WorkspaceGroupSharingFactory.create( | ||
workspace=workspace, | ||
group=admins_group, | ||
access=WorkspaceGroupSharing.OWNER, | ||
can_compute=True, | ||
) | ||
# No API call - record already exists. | ||
# Run the adapter method. | ||
self.adapter.after_anvil_import(workspace) | ||
# Check for WorkspaceGroupSharing. | ||
self.assertEqual(WorkspaceGroupSharing.objects.count(), 1) | ||
sharing = WorkspaceGroupSharing.objects.first() | ||
self.assertEqual(sharing.workspace, workspace) | ||
self.assertEqual(sharing.group, admins_group) | ||
self.assertEqual(sharing.access, WorkspaceGroupSharing.OWNER) | ||
self.assertTrue(sharing.can_compute) | ||
|
||
def test_after_anvil_import_already_shared_wrong_access(self): | ||
admins_group = ManagedGroupFactory.create(name="TEST_PRIMED_CC_ADMINS") | ||
workspace = WorkspaceFactory.create( | ||
billing_project__name="bar", name="foo", workspace_type=self.adapter.get_type() | ||
) | ||
sharing = WorkspaceGroupSharingFactory.create( | ||
workspace=workspace, | ||
group=admins_group, | ||
access=WorkspaceGroupSharing.READER, | ||
can_compute=True, | ||
) | ||
# API response to update sharing. | ||
acls = [ | ||
{ | ||
"email": "[email protected]", | ||
"accessLevel": "OWNER", | ||
"canShare": False, | ||
"canCompute": True, | ||
} | ||
] | ||
self.anvil_response_mock.add( | ||
responses.PATCH, | ||
self.api_client.rawls_entry_point + "/api/workspaces/bar/foo/acl?inviteUsersNotFound=false", | ||
status=200, | ||
match=[responses.matchers.json_params_matcher(acls)], | ||
json={"invitesSent": {}, "usersNotFound": {}, "usersUpdated": acls}, | ||
) | ||
# Run the adapter method. | ||
self.adapter.after_anvil_import(workspace) | ||
# Check for WorkspaceGroupSharing. | ||
self.assertEqual(WorkspaceGroupSharing.objects.count(), 1) | ||
sharing.refresh_from_db() | ||
self.assertEqual(sharing.workspace, workspace) | ||
self.assertEqual(sharing.group, admins_group) | ||
self.assertEqual(sharing.access, WorkspaceGroupSharing.OWNER) | ||
self.assertTrue(sharing.can_compute) | ||
|
||
def test_after_anvil_import_already_shared_wrong_can_compute(self): | ||
admins_group = ManagedGroupFactory.create(name="TEST_PRIMED_CC_ADMINS") | ||
workspace = WorkspaceFactory.create( | ||
billing_project__name="bar", name="foo", workspace_type=self.adapter.get_type() | ||
) | ||
sharing = WorkspaceGroupSharingFactory.create( | ||
workspace=workspace, | ||
group=admins_group, | ||
access=WorkspaceGroupSharing.OWNER, | ||
can_compute=False, | ||
) | ||
# API response to update sharing. | ||
acls = [ | ||
{ | ||
"email": "[email protected]", | ||
"accessLevel": "OWNER", | ||
"canShare": False, | ||
"canCompute": True, | ||
} | ||
] | ||
self.anvil_response_mock.add( | ||
responses.PATCH, | ||
self.api_client.rawls_entry_point + "/api/workspaces/bar/foo/acl?inviteUsersNotFound=false", | ||
status=200, | ||
match=[responses.matchers.json_params_matcher(acls)], | ||
json={"invitesSent": {}, "usersNotFound": {}, "usersUpdated": acls}, | ||
) | ||
# Run the adapter method. | ||
self.adapter.after_anvil_import(workspace) | ||
# Check for WorkspaceGroupSharing. | ||
self.assertEqual(WorkspaceGroupSharing.objects.count(), 1) | ||
sharing.refresh_from_db() | ||
self.assertEqual(sharing.workspace, workspace) | ||
self.assertEqual(sharing.group, admins_group) | ||
self.assertEqual(sharing.access, WorkspaceGroupSharing.OWNER) | ||
self.assertTrue(sharing.can_compute) | ||
|
||
|
||
class ManagedGroupAdapterTest(AnVILAPIMockTestMixin, TestCase): | ||
"""Tests for the custom PRIMED ManagedGroupAdapter.""" | ||
|