Compare commits
3 commits
43ed768f66
...
3f7abc5986
| Author | SHA1 | Date | |
|---|---|---|---|
| 3f7abc5986 | |||
| 2b4c875da3 | |||
| da6bd22199 |
3 changed files with 127 additions and 1 deletions
|
|
@ -612,7 +612,7 @@ async def invitation(
|
|||
|
||||
|
||||
@router.put(
|
||||
path="/group/user//invitation/accept",
|
||||
path="/group/user/invitation/accept",
|
||||
summary="Accept email invitation to join an org's group",
|
||||
status_code=status.HTTP_200_OK,
|
||||
response_model=IAMPutGroupInvitationAcceptResponse,
|
||||
|
|
|
|||
|
|
@ -136,3 +136,55 @@ async def test_post_iam_permissions_search_auth_approval(no_su_client: AsyncClie
|
|||
)
|
||||
assert resp.status_code != 422
|
||||
assert "has not been approved." in resp.json()["detail"]
|
||||
|
||||
|
||||
@pytest.mark.anyio
|
||||
async def test_delete_org_user_auth_approval(no_su_client: AsyncClient):
|
||||
resp = await no_su_client.delete("/org/user?org_id=3&user_id=1")
|
||||
|
||||
assert resp.status_code != 422
|
||||
assert "has not been approved." in resp.json()["detail"]
|
||||
|
||||
|
||||
@pytest.mark.anyio
|
||||
async def test_delete_preapproval_auth_approval(no_su_client: AsyncClient):
|
||||
resp = await no_su_client.delete("/org/self?org_id=3")
|
||||
|
||||
assert resp.status_code != 422
|
||||
assert resp.status_code == 204
|
||||
|
||||
|
||||
@pytest.mark.anyio
|
||||
async def test_post_user_invitation_auth_approval(no_su_client: AsyncClient):
|
||||
body = {"user_email": "admin@test.com", "organisation_id": 3}
|
||||
resp = await no_su_client.post("/user/invitation", json=body)
|
||||
|
||||
assert resp.status_code != 422
|
||||
assert "has not been approved." in resp.json()["detail"]
|
||||
|
||||
|
||||
@pytest.mark.anyio
|
||||
async def test_delete_group_permissions_auth_approval(no_su_client: AsyncClient):
|
||||
resp = await no_su_client.delete(
|
||||
"/iam/group/permission?org_id=3&group_id=1&perm_id=1"
|
||||
)
|
||||
|
||||
assert resp.status_code != 422
|
||||
assert "has not been approved." in resp.json()["detail"]
|
||||
|
||||
|
||||
@pytest.mark.anyio
|
||||
async def test_delete_group_users_success(no_su_client: AsyncClient):
|
||||
resp = await no_su_client.delete("/iam/group/user?org_id=3&group_id=1&user_id=1")
|
||||
|
||||
assert resp.status_code != 422
|
||||
assert "has not been approved." in resp.json()["detail"]
|
||||
|
||||
|
||||
@pytest.mark.anyio
|
||||
async def test_put_group_user_invitation_success(no_su_client: AsyncClient):
|
||||
body = {"user_email": "admin@test.com", "organisation_id": 3, "group_id": 1}
|
||||
resp = await no_su_client.put("/iam/group/user/invitation", json=body)
|
||||
|
||||
assert resp.status_code != 422
|
||||
assert "has not been approved." in resp.json()["detail"]
|
||||
|
|
|
|||
|
|
@ -675,3 +675,77 @@ async def test_delete_group_users_success(default_client: AsyncClient):
|
|||
assert "group" in data
|
||||
assert data["group"]["id"] == 1
|
||||
assert data["group"]["name"] == "Org One Group"
|
||||
|
||||
|
||||
@pytest.mark.anyio
|
||||
async def test_put_group_user_invitation_success(default_client: AsyncClient):
|
||||
body = {"user_email": "admin@test.com", "organisation_id": 1, "group_id": 1}
|
||||
resp = await default_client.put("/iam/group/user/invitation", json=body)
|
||||
|
||||
assert resp.status_code == 200
|
||||
data = resp.json()
|
||||
assert "organisation" in data
|
||||
assert isinstance(data["organisation"], dict)
|
||||
assert data["organisation"]["id"] == 1
|
||||
assert data["organisation"]["name"] == "Org One"
|
||||
|
||||
assert "invited_email" in data
|
||||
assert isinstance(data["invited_email"], str)
|
||||
assert data["invited_email"] == "admin@test.com"
|
||||
|
||||
assert "group" in data
|
||||
assert isinstance(data["group"], dict)
|
||||
assert data["group"]["name"] == "Org One Group"
|
||||
assert data["group"]["id"] == 1
|
||||
|
||||
|
||||
@pytest.mark.parametrize(
|
||||
"body, expected_status",
|
||||
[
|
||||
({"organisation_id": 42, "user_email": "admin@test.com", "group_id": 1}, 404),
|
||||
(
|
||||
{
|
||||
"organisation_id": "Test Org",
|
||||
"user_email": "admin@test.com",
|
||||
"group_id": 1,
|
||||
},
|
||||
422,
|
||||
),
|
||||
({"organisation_id": "", "user_email": "admin@test.com", "group_id": 1}, 422),
|
||||
({}, 422),
|
||||
({"user_email": 42, "group_id": 1}, 422),
|
||||
({"organisation_id": 1, "user_email": "Test User", "group_id": 1}, 422),
|
||||
({"organisation_id": 1, "user_email": "admin@test.com", "group_id": 42}, 404),
|
||||
({"organisation_id": "Test Org", "user_email": "admin@test.com"}, 422),
|
||||
({"organisation_id": "", "user_email": "admin@test.com"}, 422),
|
||||
({"user_email": 42}, 422),
|
||||
],
|
||||
)
|
||||
@pytest.mark.anyio
|
||||
async def test_put_group_user_invitation_status_checks(
|
||||
default_client: AsyncClient, body, expected_status
|
||||
):
|
||||
resp = await default_client.put("/iam/group/user/invitation", json=body)
|
||||
|
||||
assert resp.status_code == expected_status
|
||||
|
||||
|
||||
@pytest.mark.parametrize(
|
||||
"body, expected_status",
|
||||
[
|
||||
({"jwt": "invalid"}, 401),
|
||||
({"jwt": ""}, 401),
|
||||
({"jwt": None}, 422),
|
||||
({"jwt": 42}, 422),
|
||||
],
|
||||
)
|
||||
@pytest.mark.anyio
|
||||
async def test_put_group_user_invitation_accept_status_checks(
|
||||
default_client: AsyncClient, body, expected_status
|
||||
):
|
||||
resp = await default_client.put("/iam/group/user/invitation/accept", json=body)
|
||||
|
||||
assert resp.status_code == expected_status
|
||||
|
||||
if resp.status_code == 401:
|
||||
assert resp.json()["detail"] == "Invalid JWS"
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue