Add unhappy paths tests

This commit is contained in:
Adria Navarro 2023-08-24 11:23:30 +02:00
parent 84a6f239a9
commit 8359185a22
2 changed files with 58 additions and 9 deletions

View File

@ -82,8 +82,14 @@ const resourceIdTranformers: Partial<
> = { > = {
[PermissionType.VIEW]: async ctx => { [PermissionType.VIEW]: async ctx => {
const { resourceId } = ctx const { resourceId } = ctx
if (!resourceId) {
ctx.throw(400, `Cannot obtain the view id`)
return
}
if (!isViewID(resourceId)) { if (!isViewID(resourceId)) {
ctx.throw(400, `"${resourceId}" is not a valid viewId`) ctx.throw(400, `"${resourceId}" is not a valid view id`)
return
} }
if (await features.isViewPermissionEnabled()) { if (await features.isViewPermissionEnabled()) {
@ -121,17 +127,17 @@ const authorized =
permLevel === PermissionLevel.READ permLevel === PermissionLevel.READ
? PermissionLevel.WRITE ? PermissionLevel.WRITE
: PermissionLevel.READ : PermissionLevel.READ
const appId = context.getAppId()
if (resourcePath) { if (resourcePath) {
// Reusing the existing middleware to extract the value // Reusing the existing middleware to extract the value
paramResource(resourcePath)(ctx, () => {}) paramResource(resourcePath)(ctx, () => {})
} }
if (appId && hasResource(ctx)) { if (resourceIdTranformers[permType]) {
if (resourceIdTranformers[permType]) { await resourceIdTranformers[permType]!(ctx)
await resourceIdTranformers[permType]!(ctx) }
}
if (hasResource(ctx)) {
resourceRoles = await roles.getRequiredResourceRole(permLevel!, ctx) resourceRoles = await roles.getRequiredResourceRole(permLevel!, ctx)
if (opts && opts.schema) { if (opts && opts.schema) {
otherLevelRoles = await roles.getRequiredResourceRole(otherLevel, ctx) otherLevelRoles = await roles.getRequiredResourceRole(otherLevel, ctx)

View File

@ -3,13 +3,16 @@ jest.mock("../../environment", () => ({
isTest: () => true, isTest: () => true,
// @ts-ignore // @ts-ignore
isProd: () => this.prod, isProd: () => this.prod,
_set: function (key: string, value: string) { _set: function (_key: string, value: string) {
this.prod = value === "production" this.prod = value === "production"
}, },
})) }))
import { PermissionType, PermissionLevel } from "@budibase/types"
import authorizedMiddleware from "../authorized" import authorizedMiddleware from "../authorized"
import env from "../../environment" import env from "../../environment"
import { PermissionType, PermissionLevel } from "@budibase/types" import { generateTableID, generateViewID } from "../../db/utils"
const APP_ID = "" const APP_ID = ""
@ -51,7 +54,7 @@ class TestConfiguration {
this.middleware = authorizedMiddleware(...perms) this.middleware = authorizedMiddleware(...perms)
} }
setResourceId(id: string) { setResourceId(id?: string) {
this.ctx.resourceId = id this.ctx.resourceId = id
} }
@ -85,6 +88,7 @@ describe("Authorization middleware", () => {
}) })
beforeEach(() => { beforeEach(() => {
jest.clearAllMocks()
config = new TestConfiguration() config = new TestConfiguration()
}) })
@ -172,5 +176,44 @@ describe("Authorization middleware", () => {
"User does not have permission" "User does not have permission"
) )
}) })
describe("view type", () => {
const tableId = generateTableID()
const viewId = generateViewID(tableId)
beforeEach(() => {
config.setMiddlewareRequiredPermission(
PermissionType.VIEW,
PermissionLevel.READ
)
config.setResourceId(viewId)
config.setUser({
role: {
_id: "",
},
})
})
it("throw an exception if the resource id is not provided", async () => {
config.setResourceId(undefined)
await config.executeMiddleware()
expect(config.throw).toHaveBeenNthCalledWith(
1,
400,
"Cannot obtain the view id"
)
})
it("throw an exception if the resource id is not a valid view id", async () => {
config.setResourceId(tableId)
await config.executeMiddleware()
expect(config.throw).toHaveBeenNthCalledWith(
1,
400,
`"${tableId}" is not a valid view id`
)
})
})
}) })
}) })