Page MenuHomeSealhub

users-who-can.subtest.ts
No OneTemporary

users-who-can.subtest.ts

import assert from "assert";
import {
TestAppConstructor,
withRunningApp,
} from "../../test_utils/with-test-app";
import { assertThrowsAsync } from "../../test_utils/assert-throws-async";
import axios from "axios";
import { Collection, FieldTypes, Policies } from "../../main";
import { TestApp } from "../../test_utils/test-app";
const extend = (bricks_allowed: boolean) =>
function (t: TestAppConstructor) {
return class extends t {
collections = {
...TestApp.BaseCollections,
bricks: new (class extends Collection {
fields = {
number: new FieldTypes.Int(),
};
policies = {
create: bricks_allowed
? new Policies.Public()
: new Policies.Noone(),
};
})(),
houses: new (class extends Collection {
fields = {
number: new FieldTypes.Int(),
};
policies = {
create: new Policies.UsersWhoCan(["create", "bricks"]),
};
})(),
};
};
};
describe("users-who-can", () => {
it("should deny if the user can't perform the action", async () =>
withRunningApp(extend(false), async ({ app, base_url }) => {
await assertThrowsAsync(
async () =>
axios
.post(`${base_url}/api/v1/collections/houses`, {
address: "any",
})
.then(),
(e: any) => {
assert.equal(e.response.status, 401);
assert.equal(
e.response.data.message,
app.i18n("policy_users_who_can_deny", [
"create",
"bricks",
app.i18n("policy_noone_deny"),
])
);
}
);
}));
it("should allow if the user can't perform the action", async () =>
withRunningApp(extend(true), async ({ base_url }) => {
await axios.post(`${base_url}/api/v1/collections/houses`, {
address: "any",
});
}));
});

File Metadata

Mime Type
text/x-java
Expires
Tue, Dec 24, 01:55 (22 h, 4 m)
Storage Engine
blob
Storage Format
Raw Data
Storage Handle
553031
Default Alt Text
users-who-can.subtest.ts (1 KB)

Event Timeline