pleroma/app/soapbox/jest/factory.ts

100 lines
2.3 KiB
TypeScript
Raw Normal View History

import { v4 as uuidv4 } from 'uuid';
2023-05-12 18:50:30 -07:00
import { normalizeStatus } from 'soapbox/normalizers';
import {
accountSchema,
2023-05-02 16:30:21 -07:00
adSchema,
cardSchema,
groupMemberSchema,
groupRelationshipSchema,
groupSchema,
groupTagSchema,
2023-05-02 16:49:13 -07:00
relationshipSchema,
type Account,
2023-05-02 16:30:21 -07:00
type Ad,
type Card,
type Group,
type GroupMember,
type GroupRelationship,
type GroupTag,
2023-05-02 16:49:13 -07:00
type Relationship,
2023-05-12 18:50:30 -07:00
type Status,
} from 'soapbox/schemas';
import { GroupRoles } from 'soapbox/schemas/group-member';
// TODO: there's probably a better way to create these factory functions.
// This looks promising but didn't work on my first attempt: https://github.com/anatine/zod-plugins/tree/main/packages/zod-mock
function buildAccount(props: Partial<Account> = {}): Account {
return accountSchema.parse(Object.assign({
id: uuidv4(),
}, props));
}
2023-05-02 16:30:21 -07:00
function buildCard(props: Partial<Card> = {}): Card {
return cardSchema.parse(Object.assign({
url: 'https://soapbox.test',
}, props));
}
function buildGroup(props: Partial<Group> = {}): Group {
return groupSchema.parse(Object.assign({
id: uuidv4(),
2023-05-31 05:57:43 -07:00
owner: {
id: uuidv4(),
},
}, props));
}
2023-05-02 16:30:21 -07:00
function buildGroupRelationship(props: Partial<GroupRelationship> = {}): GroupRelationship {
return groupRelationshipSchema.parse(Object.assign({
id: uuidv4(),
}, props));
}
2023-05-02 16:30:21 -07:00
function buildGroupTag(props: Partial<GroupTag> = {}): GroupTag {
return groupTagSchema.parse(Object.assign({
id: uuidv4(),
name: uuidv4(),
}, props));
}
function buildGroupMember(
props: Partial<GroupMember> = {},
accountProps: Partial<Account> = {},
): GroupMember {
return groupMemberSchema.parse(Object.assign({
id: uuidv4(),
account: buildAccount(accountProps),
role: GroupRoles.USER,
}, props));
}
2023-05-02 16:30:21 -07:00
function buildAd(props: Partial<Ad> = {}): Ad {
return adSchema.parse(Object.assign({
card: buildCard(),
}, props));
}
2023-05-02 16:49:13 -07:00
function buildRelationship(props: Partial<Relationship> = {}): Relationship {
return relationshipSchema.parse(Object.assign({
id: uuidv4(),
}, props));
}
2023-05-12 19:46:36 -07:00
function buildStatus(props: Partial<Status> = {}) {
2023-05-12 18:50:30 -07:00
return normalizeStatus(Object.assign({
2023-05-08 10:29:11 -07:00
id: uuidv4(),
}, props));
}
2023-05-02 16:49:13 -07:00
export {
buildAd,
2023-05-02 16:49:13 -07:00
buildCard,
buildGroup,
buildGroupMember,
2023-05-02 16:49:13 -07:00
buildGroupRelationship,
buildGroupTag,
buildRelationship,
2023-05-08 10:29:11 -07:00
buildStatus,
2023-05-02 16:49:13 -07:00
};