mirror of
https://github.com/hay-kot/homebox.git
synced 2025-08-04 00:30:27 +00:00
add additional factories
This commit is contained in:
parent
acd91f9fb0
commit
0120e197ca
3 changed files with 55 additions and 26 deletions
|
@ -1,5 +1,10 @@
|
||||||
import { faker } from "@faker-js/faker";
|
import { faker } from "@faker-js/faker";
|
||||||
|
import { overrideParts } from "../../base/urls";
|
||||||
|
import { PublicApi } from "../../public";
|
||||||
import { LabelCreate, LocationCreate, UserRegistration } from "../../types/data-contracts";
|
import { LabelCreate, LocationCreate, UserRegistration } from "../../types/data-contracts";
|
||||||
|
import * as config from "../../../../test/config";
|
||||||
|
import { UserClient } from "../../user";
|
||||||
|
import { Requests } from "../../../requests";
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns a random user registration object that can be
|
* Returns a random user registration object that can be
|
||||||
|
@ -29,4 +34,43 @@ function label(): LabelCreate {
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
export const factories = { user, location, label };
|
function publicClient(): PublicApi {
|
||||||
|
overrideParts(config.BASE_URL, "/api/v1");
|
||||||
|
const requests = new Requests("");
|
||||||
|
return new PublicApi(requests);
|
||||||
|
}
|
||||||
|
|
||||||
|
function userClient(token: string): UserClient {
|
||||||
|
overrideParts(config.BASE_URL, "/api/v1");
|
||||||
|
const requests = new Requests("", token);
|
||||||
|
return new UserClient(requests);
|
||||||
|
}
|
||||||
|
|
||||||
|
type TestUser = {
|
||||||
|
client: UserClient;
|
||||||
|
user: UserRegistration;
|
||||||
|
};
|
||||||
|
|
||||||
|
async function userSingleUse(): Promise<TestUser> {
|
||||||
|
const usr = user();
|
||||||
|
|
||||||
|
const pub = publicClient();
|
||||||
|
pub.register(usr);
|
||||||
|
const result = await pub.login(usr.name, usr.password);
|
||||||
|
|
||||||
|
return {
|
||||||
|
client: new UserClient(new Requests("", result.data.token)),
|
||||||
|
user: usr,
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
export const factories = {
|
||||||
|
user,
|
||||||
|
location,
|
||||||
|
label,
|
||||||
|
client: {
|
||||||
|
public: publicClient,
|
||||||
|
user: userClient,
|
||||||
|
singleUse: userSingleUse,
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
|
@ -1,10 +1,10 @@
|
||||||
import { describe, test, expect } from "vitest";
|
import { describe, test, expect } from "vitest";
|
||||||
import { factories } from "./factories";
|
import { factories } from "./factories";
|
||||||
import { client, sharedUserClient, userClient } from "./test-utils";
|
import { sharedUserClient } from "./test-utils";
|
||||||
|
|
||||||
describe("[GET] /api/v1/status", () => {
|
describe("[GET] /api/v1/status", () => {
|
||||||
test("server should respond", async () => {
|
test("server should respond", async () => {
|
||||||
const api = client();
|
const api = factories.client.public();
|
||||||
const { response, data } = await api.status();
|
const { response, data } = await api.status();
|
||||||
expect(response.status).toBe(200);
|
expect(response.status).toBe(200);
|
||||||
expect(data.health).toBe(true);
|
expect(data.health).toBe(true);
|
||||||
|
@ -12,7 +12,7 @@ describe("[GET] /api/v1/status", () => {
|
||||||
});
|
});
|
||||||
|
|
||||||
describe("first time user workflow (register, login, join group)", () => {
|
describe("first time user workflow (register, login, join group)", () => {
|
||||||
const api = client();
|
const api = factories.client.public();
|
||||||
const userData = factories.user();
|
const userData = factories.user();
|
||||||
|
|
||||||
test("user should be able to register", async () => {
|
test("user should be able to register", async () => {
|
||||||
|
@ -26,7 +26,7 @@ describe("first time user workflow (register, login, join group)", () => {
|
||||||
expect(data.token).toBeTruthy();
|
expect(data.token).toBeTruthy();
|
||||||
|
|
||||||
// Cleanup
|
// Cleanup
|
||||||
const userApi = userClient(data.token);
|
const userApi = factories.client.user(data.token);
|
||||||
{
|
{
|
||||||
const { response } = await userApi.user.delete();
|
const { response } = await userApi.user.delete();
|
||||||
expect(response.status).toBe(204);
|
expect(response.status).toBe(204);
|
||||||
|
@ -60,7 +60,7 @@ describe("first time user workflow (register, login, join group)", () => {
|
||||||
|
|
||||||
// Get Self and Assert
|
// Get Self and Assert
|
||||||
|
|
||||||
const client2 = userClient(loginData.token);
|
const client2 = factories.client.user(loginData.token);
|
||||||
|
|
||||||
const { data: user2 } = await client2.user.self();
|
const { data: user2 } = await client2.user.self();
|
||||||
|
|
||||||
|
|
|
@ -1,21 +1,6 @@
|
||||||
import { beforeAll, expect } from "vitest";
|
import { beforeAll, expect } from "vitest";
|
||||||
import { Requests } from "../../requests";
|
|
||||||
import { overrideParts } from "../base/urls";
|
|
||||||
import { PublicApi } from "../public";
|
|
||||||
import * as config from "../../../test/config";
|
|
||||||
import { UserClient } from "../user";
|
import { UserClient } from "../user";
|
||||||
|
import { factories } from "./factories";
|
||||||
export function client() {
|
|
||||||
overrideParts(config.BASE_URL, "/api/v1");
|
|
||||||
const requests = new Requests("");
|
|
||||||
return new PublicApi(requests);
|
|
||||||
}
|
|
||||||
|
|
||||||
export function userClient(token: string) {
|
|
||||||
overrideParts(config.BASE_URL, "/api/v1");
|
|
||||||
const requests = new Requests("", token);
|
|
||||||
return new UserClient(requests);
|
|
||||||
}
|
|
||||||
|
|
||||||
const cache = {
|
const cache = {
|
||||||
token: "",
|
token: "",
|
||||||
|
@ -27,7 +12,7 @@ const cache = {
|
||||||
*/
|
*/
|
||||||
export async function sharedUserClient(): Promise<UserClient> {
|
export async function sharedUserClient(): Promise<UserClient> {
|
||||||
if (cache.token) {
|
if (cache.token) {
|
||||||
return userClient(cache.token);
|
return factories.client.user(cache.token);
|
||||||
}
|
}
|
||||||
const testUser = {
|
const testUser = {
|
||||||
email: "__test__@__test__.com",
|
email: "__test__@__test__.com",
|
||||||
|
@ -36,12 +21,12 @@ export async function sharedUserClient(): Promise<UserClient> {
|
||||||
token: "",
|
token: "",
|
||||||
};
|
};
|
||||||
|
|
||||||
const api = client();
|
const api = factories.client.public();
|
||||||
const { response: tryLoginResp, data } = await api.login(testUser.email, testUser.password);
|
const { response: tryLoginResp, data } = await api.login(testUser.email, testUser.password);
|
||||||
|
|
||||||
if (tryLoginResp.status === 200) {
|
if (tryLoginResp.status === 200) {
|
||||||
cache.token = data.token;
|
cache.token = data.token;
|
||||||
return userClient(cache.token);
|
return factories.client.user(cache.token);
|
||||||
}
|
}
|
||||||
|
|
||||||
const { response: registerResp } = await api.register(testUser);
|
const { response: registerResp } = await api.register(testUser);
|
||||||
|
@ -51,7 +36,7 @@ export async function sharedUserClient(): Promise<UserClient> {
|
||||||
expect(loginResp.status).toBe(200);
|
expect(loginResp.status).toBe(200);
|
||||||
|
|
||||||
cache.token = loginData.token;
|
cache.token = loginData.token;
|
||||||
return userClient(data.token);
|
return factories.client.user(data.token);
|
||||||
}
|
}
|
||||||
|
|
||||||
beforeAll(async () => {
|
beforeAll(async () => {
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue