Add find endpoint tests

This commit is contained in:
adrinr 2023-03-13 17:44:29 +01:00
parent f62647f284
commit afdefce55d
2 changed files with 86 additions and 26 deletions

View File

@ -1,8 +1,49 @@
import tk from "timekeeper" import tk from "timekeeper"
import { mocks, structures } from "@budibase/backend-core/tests" import { mocks, structures } from "@budibase/backend-core/tests"
import { ScimCreateUserRequest } from "@budibase/types" import { ScimCreateUserRequest, ScimUserResponse } from "@budibase/types"
import { TestConfiguration } from "../../../../../tests" import { TestConfiguration } from "../../../../../tests"
function createScimCreateUserRequest(userData?: {
externalId?: string
email?: string
firstName?: string
lastName?: string
}) {
const {
externalId = structures.uuid(),
email = structures.generator.email(),
firstName = structures.generator.first(),
lastName = structures.generator.last(),
} = userData || {}
const user: ScimCreateUserRequest = {
schemas: [
"urn:ietf:params:scim:schemas:core:2.0:User",
"urn:ietf:params:scim:schemas:extension:enterprise:2.0:User",
],
externalId,
userName: structures.generator.name(),
active: true,
emails: [
{
primary: true,
type: "work",
value: email,
},
],
meta: {
resourceType: "User",
},
name: {
formatted: structures.generator.name(),
familyName: lastName,
givenName: firstName,
},
roles: [],
}
return user
}
describe("/api/global/scim/v2/users", () => { describe("/api/global/scim/v2/users", () => {
let mockedTime = new Date(structures.generator.timestamp()) let mockedTime = new Date(structures.generator.timestamp())
@ -102,31 +143,7 @@ describe("/api/global/scim/v2/users", () => {
firstName: structures.generator.first(), firstName: structures.generator.first(),
lastName: structures.generator.last(), lastName: structures.generator.last(),
} }
const body: ScimCreateUserRequest = { const body = createScimCreateUserRequest(userData)
schemas: [
"urn:ietf:params:scim:schemas:core:2.0:User",
"urn:ietf:params:scim:schemas:extension:enterprise:2.0:User",
],
externalId: userData.externalId,
userName: structures.generator.name(),
active: true,
emails: [
{
primary: true,
type: "work",
value: userData.email,
},
],
meta: {
resourceType: "User",
},
name: {
formatted: structures.generator.name(),
familyName: userData.lastName,
givenName: userData.firstName,
},
roles: [],
}
const response = await postScimUser({ body }) const response = await postScimUser({ body })
@ -166,4 +183,38 @@ describe("/api/global/scim/v2/users", () => {
}) })
}) })
}) })
describe("GET /api/global/scim/v2/users/:id", () => {
let user: ScimUserResponse
beforeEach(async () => {
const body = createScimCreateUserRequest()
user = await config.api.scimUsersAPI.post({ body })
})
const findScimUser = config.api.scimUsersAPI.find
it("unauthorised calls are not allowed", async () => {
const response = await findScimUser(user.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 findScimUser(user.id, { expect: 400 })
expect(response).toEqual(featureDisabledResponse)
})
it("should return existing user", async () => {
const response = await findScimUser(user.id)
expect(response).toEqual(user)
})
})
}) })

View File

@ -48,6 +48,15 @@ export class ScimUsersAPI extends TestAPI {
return res.body as ScimUserListResponse return res.body as ScimUserListResponse
} }
find = async (id: string, requestSettings?: Partial<RequestSettings>) => {
const res = await this.#createRequest(
`/api/global/scim/v2/users/${id}`,
"get",
requestSettings
)
return res.body as ScimUserResponse
}
post = async ( post = async (
{ {
body, body,