mirror of
https://github.com/LemmyNet/lemmy.git
synced 2024-12-28 22:01:33 +00:00
9c3efe32e7
* First pass at adding comment trees. - Extracted comment replies into its own table. - Added ltree column to comment - Added parent_id param to GetComments to fetch a tree branch - No paging / limiting yet * Adding child_count to comment_aggregates. * Adding parent comment update counts * Fix unit tests. * Comment tree paging mostly done. * Fix clippy * Fix drone tests wrong postgres version. * Fix unit tests. * Add back in delete in unit test. * Add postgres upgrade script. * Fixing some PR comments. * Move update ltree into Comment::create * Updating based on comments. * Fix send soft fail.
81 lines
2.9 KiB
TypeScript
81 lines
2.9 KiB
TypeScript
jest.setTimeout(120000);
|
|
import {None} from '@sniptt/monads';
|
|
import {
|
|
PersonViewSafe,
|
|
} from 'lemmy-js-client';
|
|
|
|
import {
|
|
alpha,
|
|
beta,
|
|
registerUser,
|
|
resolvePerson,
|
|
getSite,
|
|
createPost,
|
|
resolveCommunity,
|
|
createComment,
|
|
resolveBetaCommunity,
|
|
deleteUser,
|
|
resolvePost,
|
|
API,
|
|
resolveComment,
|
|
saveUserSettingsFederated,
|
|
} from './shared';
|
|
|
|
let apShortname: string;
|
|
|
|
function assertUserFederation(userOne: PersonViewSafe, userTwo: PersonViewSafe) {
|
|
expect(userOne.person.name).toBe(userTwo.person.name);
|
|
expect(userOne.person.display_name.unwrapOr("none")).toBe(userTwo.person.display_name.unwrapOr("none"));
|
|
expect(userOne.person.bio.unwrapOr("none")).toBe(userTwo.person.bio.unwrapOr("none"));
|
|
expect(userOne.person.actor_id).toBe(userTwo.person.actor_id);
|
|
expect(userOne.person.avatar.unwrapOr("none")).toBe(userTwo.person.avatar.unwrapOr("none"));
|
|
expect(userOne.person.banner.unwrapOr("none")).toBe(userTwo.person.banner.unwrapOr("none"));
|
|
expect(userOne.person.published).toBe(userTwo.person.published);
|
|
}
|
|
|
|
test('Create user', async () => {
|
|
let userRes = await registerUser(alpha);
|
|
expect(userRes.jwt).toBeDefined();
|
|
alpha.auth = userRes.jwt;
|
|
|
|
let site = await getSite(alpha);
|
|
expect(site.my_user).toBeDefined();
|
|
apShortname = `@${site.my_user.unwrap().local_user_view.person.name}@lemmy-alpha:8541`;
|
|
});
|
|
|
|
test('Set some user settings, check that they are federated', async () => {
|
|
await saveUserSettingsFederated(alpha);
|
|
let alphaPerson = (await resolvePerson(alpha, apShortname)).person.unwrap();
|
|
let betaPerson = (await resolvePerson(beta, apShortname)).person.unwrap();
|
|
assertUserFederation(alphaPerson, betaPerson);
|
|
});
|
|
|
|
test('Delete user', async () => {
|
|
let userRes = await registerUser(alpha);
|
|
expect(userRes.jwt).toBeDefined();
|
|
let user: API = {
|
|
client: alpha.client,
|
|
auth: userRes.jwt
|
|
}
|
|
|
|
// make a local post and comment
|
|
let alphaCommunity = (await resolveCommunity(user, '!main@lemmy-alpha:8541')).community.unwrap();
|
|
let localPost = (await createPost(user, alphaCommunity.community.id)).post_view.post;
|
|
expect(localPost).toBeDefined();
|
|
let localComment = (await createComment(user, localPost.id, None)).comment_view.comment;
|
|
expect(localComment).toBeDefined();
|
|
|
|
// make a remote post and comment
|
|
let betaCommunity = (await resolveBetaCommunity(user)).community.unwrap();
|
|
let remotePost = (await createPost(user, betaCommunity.community.id)).post_view.post;
|
|
expect(remotePost).toBeDefined();
|
|
let remoteComment = (await createComment(user, remotePost.id, None)).comment_view.comment;
|
|
expect(remoteComment).toBeDefined();
|
|
|
|
await deleteUser(user);
|
|
|
|
expect((await resolvePost(alpha, localPost)).post.isNone()).toBe(true);
|
|
expect((await resolveComment(alpha, localComment)).comment.isNone()).toBe(true)
|
|
expect((await resolvePost(alpha, remotePost)).post.isNone()).toBe(true)
|
|
expect((await resolveComment(alpha, remoteComment)).comment.isNone()).toBe(true)
|
|
});
|