Skip to content

Commit

Permalink
build(fixture): mock server for modules and improved courses
Browse files Browse the repository at this point in the history
  • Loading branch information
leofvo committed Feb 15, 2023
1 parent c5b39bc commit f87de9b
Show file tree
Hide file tree
Showing 5 changed files with 154 additions and 22 deletions.
41 changes: 26 additions & 15 deletions packages/mock-server/fixtures/course.ts
Original file line number Diff line number Diff line change
Expand Up @@ -7,27 +7,20 @@ import {
FactoryDefinition,
ModelDefinition,
} from "miragejs/-types";
import { BaseModel } from "./generic";
import { Module, readableModule } from "./module";

export interface Watchtime {
videoId: string;
userId?: string;
watchedSeconds: number;
watchedPercent: number;
isWatched: boolean;
}

export interface Course {
id: string;
createdAt?: string;
updatedAt?: string;
export interface Course extends BaseModel {
visibility?: string;
draft?: boolean;
name: string;
slug: string;
description: string;
content: string;
user?: User;
modules?: any[]; // TODO
userId?: string;
__v?: number;
modules?: Module[]; // TODO
}

export class CourseMock implements Mock {
Expand All @@ -47,8 +40,8 @@ export class CourseMock implements Mock {
};
});

server.get("courses/:id", (schema) => {
return schema.first("course");
server.get("courses/:id", (schema, request) => {
return readableCourse;
});
}

Expand Down Expand Up @@ -98,3 +91,21 @@ export class CourseMock implements Mock {
return Model.extend({});
}
}

const readableCourse: Course = {
id: "a3497139-5174-4a62-83be-06d22bfa8486",
createdAt: "2022-06-09T13:11:05.062Z",
updatedAt: "2022-06-09T13:11:05.062Z",
description:
"Lorem ipsum dolor sit amet, consectetur adipiscing elit. Cras finibus mauris vitae risus vestibulum fermentum. Aliquam erat volutpat. Etiam aliquam congue nulla, ac efficitur elit iaculis id. Proin aliquet magna non nulla lacinia sagittis. Donec sed mi bibendum, convallis elit sed, accumsan erat. Vivamus a dolor sit amet eros ultricies ullamcorper. Sed nec sem ac nunc egestas malesuada nec id diam. Nunc aliquam, sem et interdum rhoncus, lacus est imperdiet velit, vitae mollis nunc elit sed nibh. Cras mollis semper justo, vel fermentum diam. Praesent eget nisl et lorem suscipit tristique. Vestibulum bibendum odio a sapien scelerisque tincidunt. Fusce consequat interdum mauris, eu placerat massa laoreet nec. Vivamus id orci porttitor, ultrices arcu quis, vestibulum erat. Cras condimentum nibh et ante facilisis, a laoreet nulla porta. Donec blandit nibh sagittis ligula tempor, id pharetra justo placerat. Class aptent taciti sociosqu ad litora torquent per conubia nostra, per inceptos himenaeos. Cras sed nisl vitae elit suscipit maximus. Cras semper, risus nec vestibulum finibus, lorem felis fermentum quam, ac tincidunt nisi dolor id nisl. Praesent nunc sem, ultricies nec bibendum sit amet, viverra vel lectus.",
draft: false,
visibility: "public",
modules: [readableModule, readableModule, readableModule],
name: "PolyCloud",
slug: "polycloud-dlv9vg",
user: BaseUsers[1],
userId: BaseUsers[1].id,
content:
"Lorem ipsum dolor sit amet, consectetur adipiscing elit. Cras finibus mauris vitae risus vestibulum fermentum. Aliquam erat volutpat. Etiam aliquam congue nulla, ac efficitur elit iaculis id. Proin aliquet magna non nulla lacinia sagittis. Donec sed mi bibendum, convallis elit sed, accumsan erat. Vivamus a dolor sit amet eros ultricies ullamcorper. Sed nec sem ac nunc egestas malesuada nec id diam. Nunc aliquam, sem et interdum rhoncus, lacus est imperdiet velit, vitae mollis nunc elit sed nibh. Cras mollis semper justo, vel fermentum diam. \nPraesent eget nisl et lorem suscipit tristique. Vestibulum bibendum odio a sapien scelerisque tincidunt. Fusce consequat interdum mauris, eu placerat massa laoreet nec. Vivamus id orci porttitor, ultrices arcu quis, vestibulum erat. Cras condimentum nibh et ante facilisis, a laoreet nulla porta. Donec blandit nibh sagittis ligula tempor, id pharetra justo placerat. Class aptent taciti sociosqu ad litora torquent per conubia nostra, per inceptos himenaeos. Cras sed nisl vitae elit suscipit maximus. Cras semper, risus nec vestibulum finibus, lorem felis fermentum quam, ac tincidunt nisi dolor id nisl. Praesent nunc sem, ultricies nec bibendum sit amet, viverra vel lectus. \nSed fermentum tempus sollicitudin. Nulla at augue efficitur, dapibus quam nec, consectetur nunc. Sed aliquet dictum efficitur. Morbi ut auctor sem. Phasellus rutrum, massa nec viverra luctus, eros purus pharetra sem, nec vulputate mi tellus sed sem. Vestibulum vitae mollis nunc. Nam gravida fermentum nisl, at porttitor eros sollicitudin id. Proin quis finibus dui. Maecenas ultricies diam tempus nibh egestas, sit amet euismod dui commodo. Fusce vitae nibh ultricies, vulputate urna et, vestibulum arcu. Cras dictum blandit eleifend. Etiam magna metus, scelerisque et tempus non, feugiat ut est. Donec molestie magna at diam dictum interdum. Morbi accumsan semper lacus at consequat.\n Donec nulla magna, rhoncus nec auctor a, feugiat a mi. Sed a mauris nec justo sodales suscipit. Nam semper non sapien eget iaculis. Aenean suscipit posuere tincidunt. Sed tristique mauris urna, ut vulputate metus iaculis et. Maecenas fermentum leo at est euismod vulputate. Nulla sapien felis, finibus eu purus nec, cursus vulputate ipsum. Nullam vulputate leo enim, a semper dolor ullamcorper tempus. Pellentesque habitant morbi tristique senectus et netus et malesuada fames ac turpis egestas. Pellentesque ut massa commodo, euismod nulla malesuada, posuere felis.\n Donec tempor tincidunt ex et facilisis. Donec massa magna, eleifend sed cursus ac, efficitur vitae arcu. Nulla et nunc euismod, ultricies velit vel, varius urna. Maecenas sit amet nisi sagittis, cursus risus non, tincidunt nulla. Sed fringilla, tortor vitae ornare pharetra, ante nulla vestibulum massa, nec fermentum libero nunc eget dolor. Proin tincidunt dui nisi, congue fringilla lectus lacinia et. Donec sodales mattis ante, quis lobortis nisi fringilla ac. Curabitur sed convallis sapien, pulvinar convallis libero.",
__v: 1,
};
7 changes: 7 additions & 0 deletions packages/mock-server/fixtures/generic.ts
Original file line number Diff line number Diff line change
@@ -1,6 +1,13 @@
import { Server } from "miragejs";
import { FactoryDefinition, ModelDefinition } from "miragejs/-types";

export interface BaseModel {
id: string;
createdAt?: string;
updatedAt?: string;
__v?: number;
}

export interface Mock {
name(): string;
/**
Expand Down
115 changes: 115 additions & 0 deletions packages/mock-server/fixtures/module.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,115 @@
import { Mock } from "./generic";
import { BaseUsers, User } from "./user";
import { faker } from "@faker-js/faker";
import { Factory, Model, Server } from "miragejs";
import {
AnyRegistry,
FactoryDefinition,
ModelDefinition,
} from "miragejs/-types";
import { BaseModel } from "./generic";
import { readableVideo, Video } from "./video";

export interface Module extends BaseModel {
description: string;
name: string;
slug: string;
elements?: Element[];
passwords?: string[];
user?: User;
userId?: string;
visibility?: string;
draft?: boolean;
}

export interface Element extends Video {
type: string;
order: number;
name: string;
}

export class ModuleMock implements Mock {
name(): string {
return "course";
}

routes(server: Server<AnyRegistry>): void {
server.timing = 1000;

server.get("modules", (schema, request) => {
const { pageSize } = request.queryParams;
const { models } = (schema as any).courses.all();
return {
data: models.slice(0, pageSize ?? 100),
total: models.length,
};
});

server.get("modules/:slug", (schema, request) => {
return readableModule;
});
}

factory(): FactoryDefinition<{}> {
return Factory.extend({
id() {
return faker.datatype.uuid();
},
slug() {
return faker.datatype.uuid();
},
name() {
return faker.name.jobTitle();
},
description() {
return faker.lorem.lines(5);
},
user() {
return BaseUsers[0];
},
visibility() {
return Math.random() > 0.2 ? "public" : "private";
},
draft() {
return Math.random() < 0.4;
},
createdAt() {
return faker.date.past(2);
},
updatedAt() {
return faker.date.recent(1);
},
});
}

seeds(server: Server<AnyRegistry>): void {
server.createList(this.name(), 20);
}

model(): ModelDefinition {
return Model.extend({});
}
}

export const readableModule: Module = {
createdAt: "2022-06-12T20:53:51.581Z",
description: "TODO",
draft: false,
elements: [
{ order: 0, type: "video", name: readableVideo.title, ...readableVideo },
{ order: 0, type: "quizz", name: readableVideo.title, ...readableVideo },
{ order: 0, type: "quizz", name: readableVideo.title, ...readableVideo },
{ order: 0, type: "video", name: readableVideo.title, ...readableVideo },
{ order: 0, type: "video", name: readableVideo.title, ...readableVideo },
{ order: 0, type: "video", name: readableVideo.title, ...readableVideo },
],
id: "644bcb05-5978-4fc9-93bf-6dfc2c0c9e77",
name: "Polycloud - Amphithéâtre Peytavin",
passwords: [],
slug: "polycloud-amphitheatre-peytavin--z5ubit",
updatedAt: "2022-06-12T20:53:51.581Z",
user: BaseUsers[0],
userId: BaseUsers[0].id,
visibility: "public",
__v: 1,
};
9 changes: 3 additions & 6 deletions packages/mock-server/fixtures/video.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { Mock } from "./generic";
import { BaseModel, Mock } from "./generic";
import { BaseUsers, User } from "./user";
import { faker } from "@faker-js/faker";
import { Factory, Model, Server } from "miragejs";
Expand All @@ -16,8 +16,7 @@ export interface Watchtime {
isWatched: boolean;
}

export interface Video {
id: string;
export interface Video extends BaseModel {
slug: string;
title: string;
description: string;
Expand All @@ -29,8 +28,6 @@ export interface Video {
source: string;
visibility?: string;
draft?: boolean;
createdAt?: string;
updatedAt?: string;
isLiked?: boolean;
watchtime?: Watchtime | undefined;
}
Expand Down Expand Up @@ -124,7 +121,7 @@ export class VideoMock implements Mock {
}
}

const readableVideo: Video = {
export const readableVideo: Video = {
id: "50d4ec43-4e66-48ff-9149-d6678243815c",
slug: "angular-in-100-seconds",
title: "Angular in 100 seconds",
Expand Down
4 changes: 3 additions & 1 deletion packages/mock-server/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@ import { createServer } from "miragejs";
import { FactoryDefinition, ModelDefinition } from "miragejs/-types";
import { CourseMock } from "./fixtures/course";
import { Mock } from "./fixtures/generic";
import { ModuleMock } from "./fixtures/module";
import { SearchMock } from "./fixtures/search";
import { UserMock } from "./fixtures/user";
import { VideoMock } from "./fixtures/video";
Expand All @@ -13,6 +14,7 @@ const mocks: Mock[] = [
new VideoMock(),
new SearchMock(),
new CourseMock(),
new ModuleMock(),
];

function initModels(): { [key: string]: ModelDefinition } {
Expand Down Expand Up @@ -40,7 +42,7 @@ export function initMockServer() {
mocks.forEach((mock) => mock.seeds(server));
},
routes() {
this.urlPrefix = 'http://localhost:4000';
this.urlPrefix = "http://localhost:4000";
mocks.forEach((mock) => mock.routes(this));
},
});
Expand Down

0 comments on commit f87de9b

Please sign in to comment.