single workspace role for task order officers

This commit is contained in:
dandds 2019-01-08 14:36:32 -05:00
parent d41f233f5a
commit 95e7adfcf3
6 changed files with 41 additions and 36 deletions

View File

@ -141,22 +141,10 @@ WORKSPACE_ROLES = [
],
},
{
"name": "contracting_officer",
"description": "Can approve funding for a task order. Has view and edit permissions for task orders in a workspace.",
"display_name": "Contracting Officer",
"permissions": [Permissions.VIEW_WORKSPACE, Permissions.KO_SIGN_TASK_ORDER],
},
{
"name": "contracting_officer_representative",
"description": "Assists in submitting task order documents. Can update Task Order.",
"display_name": "Contracting Officer Representative",
"permissions": [Permissions.VIEW_WORKSPACE],
},
{
"name": "security_officer",
"description": "Can edit security questions for a task order.",
"display_name": "Security Officer",
"permissions": [Permissions.VIEW_WORKSPACE, Permissions.SO_SIGN_TASK_ORDER],
"name": "officer",
"description": "Officer involved with setting up a Task Order",
"display_name": "Task Order Officer",
"permissions": [],
},
]

View File

@ -102,18 +102,34 @@ class TaskOrders(object):
]
@classmethod
def add_officer(cls, user, task_order, role, officer_data):
if role in TaskOrders.OFFICERS:
member = Workspaces.create_member(
user, task_order.workspace, {**officer_data, "workspace_role": role}
def add_officer(cls, user, task_order, officer_type, officer_data):
if officer_type in TaskOrders.OFFICERS:
workspace = task_order.workspace
existing_member = next(
(
member
for member in workspace.members
if member.user.dod_id is officer_data["dod_id"]
),
None,
)
setattr(task_order, role, member.user)
if existing_member:
user = existing_member.user
else:
member = Workspaces.create_member(
user, workspace, {**officer_data, "workspace_role": "officer"}
)
user = member.user
setattr(task_order, officer_type, user)
db.session.add(task_order)
db.session.commit()
return member.user
return user
else:
raise TaskOrderError(
"{} is not an officer role on task orders".format(role)
"{} is not an officer role on task orders".format(officer_type)
)

View File

@ -105,16 +105,10 @@ COMPLETION_DATE_RANGES = [
("Above 12 months", "Above 12 months"),
]
NONDISPLAY_ROLES = [
"contracting_officer",
"contracting_officer_representative",
"security_officer",
]
WORKSPACE_ROLES = [
(role["name"], {"name": role["display_name"], "description": role["description"]})
for role in WORKSPACE_ROLE_DEFINITIONS
if role["name"] not in NONDISPLAY_ROLES
if role["name"] is not "officer"
]
ENVIRONMENT_ROLES = [

View File

@ -42,6 +42,3 @@ class Permissions(object):
ADD_TAG_TO_WORKSPACE = "add_tag_to_workspace"
REMOVE_TAG_FROM_WORKSPACE = "remove_tag_from_workspace"
KO_SIGN_TASK_ORDER = "ko_sign_task_order"
SO_SIGN_TASK_ORDER = "so_sign_task_order"

View File

@ -48,3 +48,15 @@ def test_add_officer_with_nonexistent_role():
owner = task_order.workspace.owner
with pytest.raises(TaskOrderError):
TaskOrders.add_officer(owner, task_order, "pilot", ko.to_dictionary())
def test_add_officer_who_is_already_workspace_member():
task_order = TaskOrderFactory.create()
owner = task_order.workspace.owner
TaskOrders.add_officer(
owner, task_order, "contracting_officer", owner.to_dictionary()
)
assert task_order.contracting_officer == owner
member = task_order.workspace.members[0]
assert member.user == owner and member.role_name == "owner"

View File

@ -150,9 +150,7 @@ def test_invite_officers_to_task_order(queue):
assert len(workspace.members) == 4
roles = [member.role.name for member in workspace.members]
# officers exist in roles
assert "contracting_officer" in roles
assert "contracting_officer_representative" in roles
assert "security_officer" in roles
assert roles.count("officer") == 3
# email invitations are enqueued
assert len(queue.get_queue()) == 3
# task order has relationship to user for each officer role