1
0
Fork 0
mirror of synced 2024-07-07 15:25:52 +12:00

Implement delete endpoint

This commit is contained in:
adrinr 2023-03-17 12:23:24 +01:00
parent 6de4588fc1
commit baca156a17
2 changed files with 49 additions and 0 deletions

View file

@ -222,4 +222,44 @@ describe("/api/global/scim/v2/groups", () => {
})
})
})
describe("DELETE /api/global/scim/v2/groups/:id", () => {
const deleteScimGroup = config.api.scimGroupsAPI.delete
let group: ScimGroupResponse
beforeEach(async () => {
const body = createScimCreateGroupRequest()
group = await config.api.scimGroupsAPI.post({ body })
})
it("unauthorised calls are not allowed", async () => {
const response = await deleteScimGroup(group.id, {
setHeaders: false,
expect: 403,
})
expect(response).toEqual({ message: "Tenant id not set", status: 403 })
})
it("cannot be called when feature is disabled", async () => {
mocks.licenses.useCloudFree()
const response = await deleteScimGroup(group.id, { expect: 400 })
expect(response).toEqual(featureDisabledResponse)
})
it("an existing group can be deleted", async () => {
const response = await deleteScimGroup(group.id, { expect: 204 })
expect(response).toEqual({})
await config.api.scimGroupsAPI.find(group.id, { expect: 404 })
})
it("an non existing group can not be deleted", async () => {
await deleteScimGroup(structures.uuid(), { expect: 404 })
})
})
})

View file

@ -61,4 +61,13 @@ export class ScimGroupsAPI extends ScimTestAPI {
)
return res.body as ScimGroupResponse
}
delete = async (id: string, requestSettings?: Partial<RequestSettings>) => {
const res = await this.call(
`/api/global/scim/v2/groups/${id}`,
"delete",
requestSettings
)
return res.body as ScimGroupResponse
}
}