Add a simpler test.

This commit is contained in:
Sam Rose 2024-03-05 10:05:05 +00:00
parent 4c6745ad20
commit aa124524d4
No known key found for this signature in database
4 changed files with 44 additions and 6 deletions

View File

@ -6,7 +6,7 @@ import env from "../environment"
import * as accounts from "../accounts" import * as accounts from "../accounts"
import { UserDB } from "../users" import { UserDB } from "../users"
import { sdk } from "@budibase/shared-core" import { sdk } from "@budibase/shared-core"
import { User } from "@budibase/types" import { User, UserMetadata } from "@budibase/types"
const EXPIRY_SECONDS = 3600 const EXPIRY_SECONDS = 3600
@ -15,7 +15,7 @@ const EXPIRY_SECONDS = 3600
*/ */
async function populateFromDB(userId: string, tenantId: string) { async function populateFromDB(userId: string, tenantId: string) {
const db = tenancy.getTenantDB(tenantId) const db = tenancy.getTenantDB(tenantId)
const user = await db.get<any>(userId) const user = await db.get<UserMetadata>(userId)
user.budibaseAccess = true user.budibaseAccess = true
if (!env.SELF_HOSTED && !env.DISABLE_ACCOUNT_PORTAL) { if (!env.SELF_HOSTED && !env.DISABLE_ACCOUNT_PORTAL) {
const account = await accounts.getAccount(user.email) const account = await accounts.getAccount(user.email)

View File

@ -1,6 +1,6 @@
import { generateUserFlagID, InternalTables } from "../../db/utils" import { generateUserFlagID, InternalTables } from "../../db/utils"
import { getFullUser } from "../../utilities/users" import { getFullUser } from "../../utilities/users"
import { context } from "@budibase/backend-core" import { cache, context } from "@budibase/backend-core"
import { import {
ContextUserMetadata, ContextUserMetadata,
Ctx, Ctx,
@ -42,6 +42,7 @@ export async function updateMetadata(
// this isn't applicable to the user // this isn't applicable to the user
delete metadata.roles delete metadata.roles
ctx.body = await db.put(metadata) ctx.body = await db.put(metadata)
await cache.user.invalidateUser(user._id!)
} }
export async function destroyMetadata(ctx: UserCtx<void, { message: string }>) { export async function destroyMetadata(ctx: UserCtx<void, { message: string }>) {

View File

@ -256,7 +256,44 @@ describe("/applications", () => {
}) })
describe("permissions", () => { describe("permissions", () => {
it("should only return apps a user has access to", async () => { it.only("should only return apps a user has access to", async () => {
const user = await config.createUser({
builder: { global: false },
admin: { global: false },
})
const table = await config.api.table.save({
name: "table",
type: "table",
sourceId: INTERNAL_TABLE_SOURCE_ID,
sourceType: TableSourceType.INTERNAL,
schema: {
name: {
type: FieldType.STRING,
name: "name",
},
},
})
await config.withUser(user, async () => {
const apps = await config.api.application.fetch()
expect(apps).toHaveLength(0)
})
await config.api.user.update({
...user,
builder: {
[config.getAppId()]: true,
},
})
await config.withUser(user, async () => {
const apps = await config.api.application.fetch()
expect(apps).toHaveLength(1)
})
})
it("should only return apps a user has access to through a custom role on a group", async () => {
const user = await config.createUser({ const user = await config.createUser({
builder: { global: false }, builder: { global: false },
admin: { global: false }, admin: { global: false },

View File

@ -299,11 +299,11 @@ export default class TestConfiguration {
} }
} }
withUser(user: User, f: () => Promise<void>) { async withUser(user: User, f: () => Promise<void>) {
const oldUser = this.user const oldUser = this.user
this.user = user this.user = user
try { try {
return f() return await f()
} finally { } finally {
this.user = oldUser this.user = oldUser
} }