Changing unit tests to api v2.

pull/1335/head
Dessalines 4 years ago
parent a27b7f8d1f
commit 5af8257e19

@ -0,0 +1,51 @@
{
"root": true,
"env": {
"browser": true
},
"plugins": [
"jane"
],
"extends": [
"plugin:jane/recommended",
"plugin:jane/typescript"
],
"parser": "@typescript-eslint/parser",
"parserOptions": {
"project": "./tsconfig.json",
"warnOnUnsupportedTypeScriptVersion": false
},
"rules": {
"@typescript-eslint/camelcase": 0,
"@typescript-eslint/member-delimiter-style": 0,
"@typescript-eslint/no-empty-interface": 0,
"@typescript-eslint/no-explicit-any": 0,
"@typescript-eslint/no-this-alias": 0,
"@typescript-eslint/no-unused-vars": 0,
"@typescript-eslint/no-use-before-define": 0,
"@typescript-eslint/no-useless-constructor": 0,
"arrow-body-style": 0,
"curly": 0,
"eol-last": 0,
"eqeqeq": 0,
"func-style": 0,
"import/no-duplicates": 0,
"max-statements": 0,
"max-params": 0,
"new-cap": 0,
"no-console": 0,
"no-duplicate-imports": 0,
"no-extra-parens": 0,
"no-return-assign": 0,
"no-throw-literal": 0,
"no-trailing-spaces": 0,
"no-unused-expressions": 0,
"no-useless-constructor": 0,
"no-useless-escape": 0,
"no-var": 0,
"prefer-const": 0,
"prefer-rest-params": 0,
"quote-props": 0,
"unicorn/filename-case": 0
}
}

@ -0,0 +1,4 @@
module.exports = Object.assign(require('eslint-plugin-jane/prettier-ts'), {
arrowParens: 'avoid',
semi: true,
});

@ -7,14 +7,19 @@
"author": "Dessalines", "author": "Dessalines",
"license": "AGPL-3.0", "license": "AGPL-3.0",
"scripts": { "scripts": {
"lint": "tsc --noEmit && eslint --report-unused-disable-directives --ext .js,.ts,.tsx src",
"fix": "prettier --write src && eslint --fix src",
"api-test": "jest src/ -i --verbose" "api-test": "jest src/ -i --verbose"
}, },
"devDependencies": { "devDependencies": {
"@types/jest": "^26.0.14", "@types/jest": "^26.0.19",
"jest": "^26.4.2", "jest": "^26.6.3",
"lemmy-js-client": "^1.0.14", "lemmy-js-client": "1.0.17-beta3",
"node-fetch": "^2.6.1", "node-fetch": "^2.6.1",
"ts-jest": "^26.4.1", "ts-jest": "^26.4.4",
"typescript": "^4.0.3" "prettier": "^2.1.2",
"eslint": "^7.10.0",
"eslint-plugin-jane": "^9.0.3",
"typescript": "^4.1.3"
} }
} }

@ -11,7 +11,7 @@ import {
followBeta, followBeta,
searchForBetaCommunity, searchForBetaCommunity,
createComment, createComment,
updateComment, editComment,
deleteComment, deleteComment,
removeComment, removeComment,
getMentions, getMentions,
@ -23,9 +23,7 @@ import {
delay, delay,
longDelay, longDelay,
} from './shared'; } from './shared';
import { import { CommentView } from 'lemmy-js-client';
Comment,
} from 'lemmy-js-client';
import { PostResponse } from 'lemmy-js-client'; import { PostResponse } from 'lemmy-js-client';
@ -39,7 +37,7 @@ beforeAll(async () => {
await longDelay(); await longDelay();
postRes = await createPost( postRes = await createPost(
alpha, alpha,
search.communities.filter(c => c.local == false)[0].id search.communities.find(c => c.community.local == false).community.id
); );
}); });
@ -49,34 +47,35 @@ afterAll(async () => {
}); });
function assertCommentFederation( function assertCommentFederation(
commentOne: Comment, commentOne: CommentView,
commentTwo: Comment) { commentTwo: CommentView
expect(commentOne.ap_id).toBe(commentOne.ap_id); ) {
expect(commentOne.content).toBe(commentTwo.content); expect(commentOne.comment.ap_id).toBe(commentOne.comment.ap_id);
expect(commentOne.creator_name).toBe(commentTwo.creator_name); expect(commentOne.comment.content).toBe(commentTwo.comment.content);
expect(commentOne.community_actor_id).toBe(commentTwo.community_actor_id); expect(commentOne.creator.name).toBe(commentTwo.creator.name);
expect(commentOne.published).toBe(commentTwo.published); expect(commentOne.community.actor_id).toBe(commentTwo.community.actor_id);
expect(commentOne.updated).toBe(commentOne.updated); expect(commentOne.comment.published).toBe(commentTwo.comment.published);
expect(commentOne.deleted).toBe(commentOne.deleted); expect(commentOne.comment.updated).toBe(commentOne.comment.updated);
expect(commentOne.removed).toBe(commentOne.removed); expect(commentOne.comment.deleted).toBe(commentOne.comment.deleted);
expect(commentOne.comment.removed).toBe(commentOne.comment.removed);
} }
test('Create a comment', async () => { test('Create a comment', async () => {
let commentRes = await createComment(alpha, postRes.post.id); let commentRes = await createComment(alpha, postRes.post_view.post.id);
expect(commentRes.comment.content).toBeDefined(); expect(commentRes.comment_view.comment.content).toBeDefined();
expect(commentRes.comment.community_local).toBe(false); expect(commentRes.comment_view.community.local).toBe(false);
expect(commentRes.comment.creator_local).toBe(true); expect(commentRes.comment_view.creator.local).toBe(true);
expect(commentRes.comment.score).toBe(1); expect(commentRes.comment_view.counts.score).toBe(1);
await longDelay(); await longDelay();
// Make sure that comment is liked on beta // Make sure that comment is liked on beta
let searchBeta = await searchComment(beta, commentRes.comment); let searchBeta = await searchComment(beta, commentRes.comment_view.comment);
let betaComment = searchBeta.comments[0]; let betaComment = searchBeta.comments[0];
expect(betaComment).toBeDefined(); expect(betaComment).toBeDefined();
expect(betaComment.community_local).toBe(true); expect(betaComment.community.local).toBe(true);
expect(betaComment.creator_local).toBe(false); expect(betaComment.creator.local).toBe(false);
expect(betaComment.score).toBe(1); expect(betaComment.counts.score).toBe(1);
assertCommentFederation(betaComment, commentRes.comment); assertCommentFederation(betaComment, commentRes.comment_view);
}); });
test('Create a comment in a non-existent post', async () => { test('Create a comment in a non-existent post', async () => {
@ -85,39 +84,48 @@ test('Create a comment in a non-existent post', async () => {
}); });
test('Update a comment', async () => { test('Update a comment', async () => {
let commentRes = await createComment(alpha, postRes.post.id); let commentRes = await createComment(alpha, postRes.post_view.post.id);
// Federate the comment first // Federate the comment first
let searchBeta = await searchComment(beta, commentRes.comment); let searchBeta = await searchComment(beta, commentRes.comment_view.comment);
assertCommentFederation(searchBeta.comments[0], commentRes.comment); assertCommentFederation(searchBeta.comments[0], commentRes.comment_view);
await delay(); await delay();
let updateCommentRes = await updateComment(alpha, commentRes.comment.id); let updateCommentRes = await editComment(
expect(updateCommentRes.comment.content).toBe( alpha,
commentRes.comment_view.comment.id
);
expect(updateCommentRes.comment_view.comment.content).toBe(
'A jest test federated comment update' 'A jest test federated comment update'
); );
expect(updateCommentRes.comment.community_local).toBe(false); expect(updateCommentRes.comment_view.community.local).toBe(false);
expect(updateCommentRes.comment.creator_local).toBe(true); expect(updateCommentRes.comment_view.creator.local).toBe(true);
await delay(); await delay();
// Make sure that post is updated on beta // Make sure that post is updated on beta
let searchBetaUpdated = await searchComment(beta, commentRes.comment); let searchBetaUpdated = await searchComment(
assertCommentFederation(searchBetaUpdated.comments[0], updateCommentRes.comment); beta,
commentRes.comment_view.comment
);
assertCommentFederation(
searchBetaUpdated.comments[0],
updateCommentRes.comment_view
);
}); });
test('Delete a comment', async () => { test('Delete a comment', async () => {
let commentRes = await createComment(alpha, postRes.post.id); let commentRes = await createComment(alpha, postRes.post_view.post.id);
await delay(); await delay();
let deleteCommentRes = await deleteComment( let deleteCommentRes = await deleteComment(
alpha, alpha,
true, true,
commentRes.comment.id commentRes.comment_view.comment.id
); );
expect(deleteCommentRes.comment.deleted).toBe(true); expect(deleteCommentRes.comment_view.comment.deleted).toBe(true);
await delay(); await delay();
// Make sure that comment is undefined on beta // Make sure that comment is undefined on beta
let searchBeta = await searchComment(beta, commentRes.comment); let searchBeta = await searchComment(beta, commentRes.comment_view.comment);
let betaComment = searchBeta.comments[0]; let betaComment = searchBeta.comments[0];
expect(betaComment).toBeUndefined(); expect(betaComment).toBeUndefined();
await delay(); await delay();
@ -125,43 +133,50 @@ test('Delete a comment', async () => {
let undeleteCommentRes = await deleteComment( let undeleteCommentRes = await deleteComment(
alpha, alpha,
false, false,
commentRes.comment.id commentRes.comment_view.comment.id
); );
expect(undeleteCommentRes.comment.deleted).toBe(false); expect(undeleteCommentRes.comment_view.comment.deleted).toBe(false);
await delay(); await delay();
// Make sure that comment is undeleted on beta // Make sure that comment is undeleted on beta
let searchBeta2 = await searchComment(beta, commentRes.comment); let searchBeta2 = await searchComment(beta, commentRes.comment_view.comment);
let betaComment2 = searchBeta2.comments[0]; let betaComment2 = searchBeta2.comments[0];
expect(betaComment2.deleted).toBe(false); expect(betaComment2.comment.deleted).toBe(false);
assertCommentFederation(searchBeta2.comments[0], undeleteCommentRes.comment); assertCommentFederation(
searchBeta2.comments[0],
undeleteCommentRes.comment_view
);
}); });
test('Remove a comment from admin and community on the same instance', async () => { test('Remove a comment from admin and community on the same instance', async () => {
let commentRes = await createComment(alpha, postRes.post.id); let commentRes = await createComment(alpha, postRes.post_view.post.id);
await delay(); await delay();
// Get the id for beta // Get the id for beta
let betaCommentId = (await searchComment(beta, commentRes.comment)) let betaCommentId = (
.comments[0].id; await searchComment(beta, commentRes.comment_view.comment)
).comments[0].comment.id;
// The beta admin removes it (the community lives on beta) // The beta admin removes it (the community lives on beta)
let removeCommentRes = await removeComment(beta, true, betaCommentId); let removeCommentRes = await removeComment(beta, true, betaCommentId);
expect(removeCommentRes.comment.removed).toBe(true); expect(removeCommentRes.comment_view.comment.removed).toBe(true);
await longDelay(); await longDelay();
// Make sure that comment is removed on alpha (it gets pushed since an admin from beta removed it) // Make sure that comment is removed on alpha (it gets pushed since an admin from beta removed it)
let refetchedPost = await getPost(alpha, postRes.post.id); let refetchedPost = await getPost(alpha, postRes.post_view.post.id);
expect(refetchedPost.comments[0].removed).toBe(true); expect(refetchedPost.comments[0].comment.removed).toBe(true);
let unremoveCommentRes = await removeComment(beta, false, betaCommentId); let unremoveCommentRes = await removeComment(beta, false, betaCommentId);
expect(unremoveCommentRes.comment.removed).toBe(false); expect(unremoveCommentRes.comment_view.comment.removed).toBe(false);
await longDelay(); await longDelay();
// Make sure that comment is unremoved on beta // Make sure that comment is unremoved on beta
let refetchedPost2 = await getPost(alpha, postRes.post.id); let refetchedPost2 = await getPost(alpha, postRes.post_view.post.id);
expect(refetchedPost2.comments[0].removed).toBe(false); expect(refetchedPost2.comments[0].comment.removed).toBe(false);
assertCommentFederation(refetchedPost2.comments[0], unremoveCommentRes.comment); assertCommentFederation(
refetchedPost2.comments[0],
unremoveCommentRes.comment_view
);
}); });
test('Remove a comment from admin and community on different instance', async () => { test('Remove a comment from admin and community on different instance', async () => {
@ -174,159 +189,170 @@ test('Remove a comment from admin and community on different instance', async ()
// New alpha user creates a community, post, and comment. // New alpha user creates a community, post, and comment.
let newCommunity = await createCommunity(newAlphaApi); let newCommunity = await createCommunity(newAlphaApi);
await delay(); await delay();
let newPost = await createPost(newAlphaApi, newCommunity.community.id); let newPost = await createPost(
newAlphaApi,
newCommunity.community_view.community.id
);
await delay(); await delay();
let commentRes = await createComment(newAlphaApi, newPost.post.id); let commentRes = await createComment(newAlphaApi, newPost.post_view.post.id);
expect(commentRes.comment.content).toBeDefined(); expect(commentRes.comment_view.comment.content).toBeDefined();
await delay(); await delay();
// Beta searches that to cache it, then removes it // Beta searches that to cache it, then removes it
let searchBeta = await searchComment(beta, commentRes.comment); let searchBeta = await searchComment(beta, commentRes.comment_view.comment);
let betaComment = searchBeta.comments[0]; let betaComment = searchBeta.comments[0];
let removeCommentRes = await removeComment(beta, true, betaComment.id); let removeCommentRes = await removeComment(
expect(removeCommentRes.comment.removed).toBe(true); beta,
true,
betaComment.comment.id
);
expect(removeCommentRes.comment_view.comment.removed).toBe(true);
await delay(); await delay();
// Make sure its not removed on alpha // Make sure its not removed on alpha
let refetchedPost = await getPost(newAlphaApi, newPost.post.id); let refetchedPost = await getPost(newAlphaApi, newPost.post_view.post.id);
expect(refetchedPost.comments[0].removed).toBe(false); expect(refetchedPost.comments[0].comment.removed).toBe(false);
assertCommentFederation(refetchedPost.comments[0], commentRes.comment); assertCommentFederation(refetchedPost.comments[0], commentRes.comment_view);
}); });
test('Unlike a comment', async () => { test('Unlike a comment', async () => {
let commentRes = await createComment(alpha, postRes.post.id); let commentRes = await createComment(alpha, postRes.post_view.post.id);
await delay(); await delay();
let unlike = await likeComment(alpha, 0, commentRes.comment); let unlike = await likeComment(alpha, 0, commentRes.comment_view.comment);
expect(unlike.comment.score).toBe(0); expect(unlike.comment_view.counts.score).toBe(0);
await delay(); await delay();
// Make sure that post is unliked on beta // Make sure that post is unliked on beta
let searchBeta = await searchComment(beta, commentRes.comment); let searchBeta = await searchComment(beta, commentRes.comment_view.comment);
let betaComment = searchBeta.comments[0]; let betaComment = searchBeta.comments[0];
expect(betaComment).toBeDefined(); expect(betaComment).toBeDefined();
expect(betaComment.community_local).toBe(true); expect(betaComment.community.local).toBe(true);
expect(betaComment.creator_local).toBe(false); expect(betaComment.creator.local).toBe(false);
expect(betaComment.score).toBe(0); expect(betaComment.counts.score).toBe(0);
}); });
test('Federated comment like', async () => { test('Federated comment like', async () => {
let commentRes = await createComment(alpha, postRes.post.id); let commentRes = await createComment(alpha, postRes.post_view.post.id);
await longDelay(); await longDelay();
// Find the comment on beta // Find the comment on beta
let searchBeta = await searchComment(beta, commentRes.comment); let searchBeta = await searchComment(beta, commentRes.comment_view.comment);
let betaComment = searchBeta.comments[0]; let betaComment = searchBeta.comments[0];
let like = await likeComment(beta, 1, betaComment); let like = await likeComment(beta, 1, betaComment.comment);
expect(like.comment.score).toBe(2); expect(like.comment_view.counts.score).toBe(2);
await longDelay(); await longDelay();
// Get the post from alpha, check the likes // Get the post from alpha, check the likes
let post = await getPost(alpha, postRes.post.id); let post = await getPost(alpha, postRes.post_view.post.id);
expect(post.comments[0].score).toBe(2); expect(post.comments[0].counts.score).toBe(2);
}); });
test('Reply to a comment', async () => { test('Reply to a comment', async () => {
// Create a comment on alpha, find it on beta // Create a comment on alpha, find it on beta
let commentRes = await createComment(alpha, postRes.post.id); let commentRes = await createComment(alpha, postRes.post_view.post.id);
await delay(); await delay();
let searchBeta = await searchComment(beta, commentRes.comment); let searchBeta = await searchComment(beta, commentRes.comment_view.comment);
let betaComment = searchBeta.comments[0]; let betaComment = searchBeta.comments[0];
// find that comment id on beta // find that comment id on beta
// Reply from beta // Reply from beta
let replyRes = await createComment(beta, betaComment.post_id, betaComment.id); let replyRes = await createComment(
expect(replyRes.comment.content).toBeDefined(); beta,
expect(replyRes.comment.community_local).toBe(true); betaComment.post.id,
expect(replyRes.comment.creator_local).toBe(true); betaComment.comment.id
expect(replyRes.comment.parent_id).toBe(betaComment.id); );
expect(replyRes.comment.score).toBe(1); expect(replyRes.comment_view.comment.content).toBeDefined();
expect(replyRes.comment_view.community.local).toBe(true);
expect(replyRes.comment_view.creator.local).toBe(true);
expect(replyRes.comment_view.comment.parent_id).toBe(betaComment.comment.id);
expect(replyRes.comment_view.counts.score).toBe(1);
await longDelay(); await longDelay();
// Make sure that comment is seen on alpha // Make sure that comment is seen on alpha
// TODO not sure why, but a searchComment back to alpha, for the ap_id of betas // TODO not sure why, but a searchComment back to alpha, for the ap_id of betas
// comment, isn't working. // comment, isn't working.
// let searchAlpha = await searchComment(alpha, replyRes.comment); // let searchAlpha = await searchComment(alpha, replyRes.comment);
let post = await getPost(alpha, postRes.post.id); let post = await getPost(alpha, postRes.post_view.post.id);
let alphaComment = post.comments[0]; let alphaComment = post.comments[0];
expect(alphaComment.content).toBeDefined(); expect(alphaComment.comment.content).toBeDefined();
expect(alphaComment.parent_id).toBe(post.comments[1].id); expect(alphaComment.comment.parent_id).toBe(post.comments[1].comment.id);
expect(alphaComment.community_local).toBe(false); expect(alphaComment.community.local).toBe(false);
expect(alphaComment.creator_local).toBe(false); expect(alphaComment.creator.local).toBe(false);
expect(alphaComment.score).toBe(1); expect(alphaComment.counts.score).toBe(1);
assertCommentFederation(alphaComment, replyRes.comment); assertCommentFederation(alphaComment, replyRes.comment_view);
}); });
test('Mention beta', async () => { test('Mention beta', async () => {
// Create a mention on alpha // Create a mention on alpha
let mentionContent = 'A test mention of @lemmy_beta@lemmy-beta:8551'; let mentionContent = 'A test mention of @lemmy_beta@lemmy-beta:8551';
let commentRes = await createComment(alpha, postRes.post.id); let commentRes = await createComment(alpha, postRes.post_view.post.id);
await delay(); await delay();
let mentionRes = await createComment( let mentionRes = await createComment(
alpha, alpha,
postRes.post.id, postRes.post_view.post.id,
commentRes.comment.id, commentRes.comment_view.comment.id,
mentionContent mentionContent
); );
expect(mentionRes.comment.content).toBeDefined(); expect(mentionRes.comment_view.comment.content).toBeDefined();
expect(mentionRes.comment.community_local).toBe(false); expect(mentionRes.comment_view.community.local).toBe(false);
expect(mentionRes.comment.creator_local).toBe(true); expect(mentionRes.comment_view.creator.local).toBe(true);
expect(mentionRes.comment.score).toBe(1); expect(mentionRes.comment_view.counts.score).toBe(1);
await delay(); await delay();
let mentionsRes = await getMentions(beta); let mentionsRes = await getMentions(beta);
expect(mentionsRes.mentions[0].content).toBeDefined(); expect(mentionsRes.mentions[0].comment.content).toBeDefined();
expect(mentionsRes.mentions[0].community_local).toBe(true); expect(mentionsRes.mentions[0].community.local).toBe(true);
expect(mentionsRes.mentions[0].creator_local).toBe(false); expect(mentionsRes.mentions[0].creator.local).toBe(false);
expect(mentionsRes.mentions[0].score).toBe(1); expect(mentionsRes.mentions[0].counts.score).toBe(1);
}); });
test('Comment Search', async () => { test('Comment Search', async () => {
let commentRes = await createComment(alpha, postRes.post.id); let commentRes = await createComment(alpha, postRes.post_view.post.id);
await delay(); await delay();
let searchBeta = await searchComment(beta, commentRes.comment); let searchBeta = await searchComment(beta, commentRes.comment_view.comment);
assertCommentFederation(searchBeta.comments[0], commentRes.comment); assertCommentFederation(searchBeta.comments[0], commentRes.comment_view);
}); });
test('A and G subscribe to B (center) A posts, G mentions B, it gets announced to A', async () => { test('A and G subscribe to B (center) A posts, G mentions B, it gets announced to A', async () => {
// Create a local post // Create a local post
let alphaPost = await createPost(alpha, 2); let alphaPost = await createPost(alpha, 2);
expect(alphaPost.post.community_local).toBe(true); expect(alphaPost.post_view.community.local).toBe(true);
await delay(); await delay();
// Make sure gamma sees it // Make sure gamma sees it
let search = await searchPost(gamma, alphaPost.post); let search = await searchPost(gamma, alphaPost.post_view.post);
let gammaPost = search.posts[0]; let gammaPost = search.posts[0];
let commentContent = let commentContent =
'A jest test federated comment announce, lets mention @lemmy_beta@lemmy-beta:8551'; 'A jest test federated comment announce, lets mention @lemmy_beta@lemmy-beta:8551';
let commentRes = await createComment( let commentRes = await createComment(
gamma, gamma,
gammaPost.id, gammaPost.post.id,
undefined, undefined,
commentContent commentContent
); );
expect(commentRes.comment.content).toBe(commentContent); expect(commentRes.comment_view.comment.content).toBe(commentContent);
expect(commentRes.comment.community_local).toBe(false); expect(commentRes.comment_view.community.local).toBe(false);
expect(commentRes.comment.creator_local).toBe(true); expect(commentRes.comment_view.creator.local).toBe(true);
expect(commentRes.comment.score).toBe(1); expect(commentRes.comment_view.counts.score).toBe(1);
await longDelay(); await longDelay();
// Make sure alpha sees it // Make sure alpha sees it
let alphaPost2 = await getPost(alpha, alphaPost.post.id); let alphaPost2 = await getPost(alpha, alphaPost.post_view.post.id);
expect(alphaPost2.comments[0].content).toBe(commentContent); expect(alphaPost2.comments[0].comment.content).toBe(commentContent);
expect(alphaPost2.comments[0].community_local).toBe(true); expect(alphaPost2.comments[0].community.local).toBe(true);
expect(alphaPost2.comments[0].creator_local).toBe(false); expect(alphaPost2.comments[0].creator.local).toBe(false);
expect(alphaPost2.comments[0].score).toBe(1); expect(alphaPost2.comments[0].counts.score).toBe(1);
assertCommentFederation(alphaPost2.comments[0], commentRes.comment); assertCommentFederation(alphaPost2.comments[0], commentRes.comment_view);
await delay(); await delay();
// Make sure beta has mentions // Make sure beta has mentions
let mentionsRes = await getMentions(beta); let mentionsRes = await getMentions(beta);
expect(mentionsRes.mentions[0].content).toBe(commentContent); expect(mentionsRes.mentions[0].comment.content).toBe(commentContent);
expect(mentionsRes.mentions[0].community_local).toBe(false); expect(mentionsRes.mentions[0].community.local).toBe(false);
expect(mentionsRes.mentions[0].creator_local).toBe(false); expect(mentionsRes.mentions[0].creator.local).toBe(false);
// TODO this is failing because fetchInReplyTos aren't getting score // TODO this is failing because fetchInReplyTos aren't getting score
// expect(mentionsRes.mentions[0].score).toBe(1); // expect(mentionsRes.mentions[0].score).toBe(1);
}); });
@ -335,60 +361,64 @@ test('Fetch in_reply_tos: A is unsubbed from B, B makes a post, and some embedde
// Unfollow all remote communities // Unfollow all remote communities
let followed = await unfollowRemotes(alpha); let followed = await unfollowRemotes(alpha);
expect( expect(
followed.communities.filter(c => c.community_local == false).length followed.communities.filter(c => c.community.local == false).length
).toBe(0); ).toBe(0);
// B creates a post, and two comments, should be invisible to A // B creates a post, and two comments, should be invisible to A
let postRes = await createPost(beta, 2); let postRes = await createPost(beta, 2);
expect(postRes.post.name).toBeDefined(); expect(postRes.post_view.post.name).toBeDefined();
await delay(); await delay();
let parentCommentContent = 'An invisible top level comment from beta'; let parentCommentContent = 'An invisible top level comment from beta';
let parentCommentRes = await createComment( let parentCommentRes = await createComment(
beta, beta,
postRes.post.id, postRes.post_view.post.id,
undefined, undefined,
parentCommentContent parentCommentContent
); );
expect(parentCommentRes.comment.content).toBe(parentCommentContent); expect(parentCommentRes.comment_view.comment.content).toBe(
parentCommentContent
);
await delay(); await delay();
// B creates a comment, then a child one of that. // B creates a comment, then a child one of that.
let childCommentContent = 'An invisible child comment from beta'; let childCommentContent = 'An invisible child comment from beta';
let childCommentRes = await createComment( let childCommentRes = await createComment(
beta, beta,
postRes.post.id, postRes.post_view.post.id,
parentCommentRes.comment.id, parentCommentRes.comment_view.comment.id,
childCommentContent
);
expect(childCommentRes.comment_view.comment.content).toBe(
childCommentContent childCommentContent
); );
expect(childCommentRes.comment.content).toBe(childCommentContent);
await delay(); await delay();
// Follow beta again // Follow beta again
let follow = await followBeta(alpha); let follow = await followBeta(alpha);
expect(follow.community.local).toBe(false); expect(follow.community_view.community.local).toBe(false);
expect(follow.community.name).toBe('main'); expect(follow.community_view.community.name).toBe('main');
await delay(); await delay();
// An update to the child comment on beta, should push the post, parent, and child to alpha now // An update to the child comment on beta, should push the post, parent, and child to alpha now
let updatedCommentContent = 'An update child comment from beta'; let updatedCommentContent = 'An update child comment from beta';
let updateRes = await updateComment( let updateRes = await editComment(
beta, beta,
childCommentRes.comment.id, childCommentRes.comment_view.comment.id,
updatedCommentContent updatedCommentContent
); );
expect(updateRes.comment.content).toBe(updatedCommentContent); expect(updateRes.comment_view.comment.content).toBe(updatedCommentContent);
await delay(); await delay();
// Get the post from alpha // Get the post from alpha
let search = await searchPost(alpha, postRes.post); let search = await searchPost(alpha, postRes.post_view.post);
let alphaPostB = search.posts[0]; let alphaPostB = search.posts[0];
await longDelay(); await longDelay();
let alphaPost = await getPost(alpha, alphaPostB.id); let alphaPost = await getPost(alpha, alphaPostB.post.id);
expect(alphaPost.post.name).toBeDefined(); expect(alphaPost.post_view.post.name).toBeDefined();
assertCommentFederation(alphaPost.comments[1], parentCommentRes.comment); assertCommentFederation(alphaPost.comments[1], parentCommentRes.comment_view);
assertCommentFederation(alphaPost.comments[0], updateRes.comment); assertCommentFederation(alphaPost.comments[0], updateRes.comment_view);
expect(alphaPost.post.community_local).toBe(false); expect(alphaPost.post_view.community.local).toBe(false);
expect(alphaPost.post.creator_local).toBe(false); expect(alphaPost.post_view.creator.local).toBe(false);
}); });

@ -3,7 +3,6 @@ import {
alpha, alpha,
beta, beta,
setupLogins, setupLogins,
searchForBetaCommunity,
searchForCommunity, searchForCommunity,
createCommunity, createCommunity,
deleteCommunity, deleteCommunity,
@ -11,40 +10,44 @@ import {
getCommunity, getCommunity,
followCommunity, followCommunity,
delay, delay,
longDelay,
} from './shared'; } from './shared';
import { import { CommunityView } from 'lemmy-js-client';
Community,
} from 'lemmy-js-client';
beforeAll(async () => { beforeAll(async () => {
await setupLogins(); await setupLogins();
}); });
function assertCommunityFederation( function assertCommunityFederation(
communityOne: Community, communityOne: CommunityView,
communityTwo: Community) { communityTwo: CommunityView
expect(communityOne.actor_id).toBe(communityTwo.actor_id); ) {
expect(communityOne.name).toBe(communityTwo.name); expect(communityOne.community.actor_id).toBe(communityTwo.community.actor_id);
expect(communityOne.title).toBe(communityTwo.title); expect(communityOne.community.name).toBe(communityTwo.community.name);
expect(communityOne.description).toBe(communityTwo.description); expect(communityOne.community.title).toBe(communityTwo.community.title);
expect(communityOne.icon).toBe(communityTwo.icon); expect(communityOne.community.description).toBe(
expect(communityOne.banner).toBe(communityTwo.banner); communityTwo.community.description
expect(communityOne.published).toBe(communityTwo.published); );
expect(communityOne.creator_actor_id).toBe(communityTwo.creator_actor_id); expect(communityOne.community.icon).toBe(communityTwo.community.icon);
expect(communityOne.nsfw).toBe(communityTwo.nsfw); expect(communityOne.community.banner).toBe(communityTwo.community.banner);
expect(communityOne.category_id).toBe(communityTwo.category_id); expect(communityOne.community.published).toBe(
expect(communityOne.removed).toBe(communityTwo.removed); communityTwo.community.published
expect(communityOne.deleted).toBe(communityTwo.deleted); );
expect(communityOne.creator.actor_id).toBe(communityTwo.creator.actor_id);
expect(communityOne.community.nsfw).toBe(communityTwo.community.nsfw);
expect(communityOne.community.category_id).toBe(
communityTwo.community.category_id
);
expect(communityOne.community.removed).toBe(communityTwo.community.removed);
expect(communityOne.community.deleted).toBe(communityTwo.community.deleted);
} }
test('Create community', async () => { test('Create community', async () => {
let communityRes = await createCommunity(alpha); let communityRes = await createCommunity(alpha);
expect(communityRes.community.name).toBeDefined(); expect(communityRes.community_view.community.name).toBeDefined();
// A dupe check // A dupe check
let prevName = communityRes.community.name; let prevName = communityRes.community_view.community.name;
let communityRes2 = await createCommunity(alpha, prevName); let communityRes2: any = await createCommunity(alpha, prevName);
expect(communityRes2['error']).toBe('community_already_exists'); expect(communityRes2['error']).toBe('community_already_exists');
await delay(); await delay();
@ -52,7 +55,7 @@ test('Create community', async () => {
let searchShort = `!${prevName}@lemmy-alpha:8541`; let searchShort = `!${prevName}@lemmy-alpha:8541`;
let search = await searchForCommunity(beta, searchShort); let search = await searchForCommunity(beta, searchShort);
let communityOnBeta = search.communities[0]; let communityOnBeta = search.communities[0];
assertCommunityFederation(communityOnBeta, communityRes.community); assertCommunityFederation(communityOnBeta, communityRes.community_view);
}); });
test('Delete community', async () => { test('Delete community', async () => {
@ -60,44 +63,56 @@ test('Delete community', async () => {
await delay(); await delay();
// Cache the community on Alpha // Cache the community on Alpha
let searchShort = `!${communityRes.community.name}@lemmy-beta:8551`; let searchShort = `!${communityRes.community_view.community.name}@lemmy-beta:8551`;
let search = await searchForCommunity(alpha, searchShort); let search = await searchForCommunity(alpha, searchShort);
let communityOnAlpha = search.communities[0]; let communityOnAlpha = search.communities[0];
assertCommunityFederation(communityOnAlpha, communityRes.community); assertCommunityFederation(communityOnAlpha, communityRes.community_view);
await delay(); await delay();
// Follow the community from alpha // Follow the community from alpha
let follow = await followCommunity(alpha, true, communityOnAlpha.id); let follow = await followCommunity(
alpha,
true,
communityOnAlpha.community.id
);
// Make sure the follow response went through // Make sure the follow response went through
expect(follow.community.local).toBe(false); expect(follow.community_view.community.local).toBe(false);
await delay(); await delay();
let deleteCommunityRes = await deleteCommunity( let deleteCommunityRes = await deleteCommunity(
beta, beta,
true, true,
communityRes.community.id communityRes.community_view.community.id
); );
expect(deleteCommunityRes.community.deleted).toBe(true); expect(deleteCommunityRes.community_view.community.deleted).toBe(true);
await delay(); await delay();
// Make sure it got deleted on A // Make sure it got deleted on A
let communityOnAlphaDeleted = await getCommunity(alpha, communityOnAlpha.id); let communityOnAlphaDeleted = await getCommunity(
expect(communityOnAlphaDeleted.community.deleted).toBe(true); alpha,
communityOnAlpha.community.id
);
expect(communityOnAlphaDeleted.community_view.community.deleted).toBe(true);
await delay(); await delay();
// Undelete // Undelete
let undeleteCommunityRes = await deleteCommunity( let undeleteCommunityRes = await deleteCommunity(
beta, beta,
false, false,
communityRes.community.id communityRes.community_view.community.id
); );
expect(undeleteCommunityRes.community.deleted).toBe(false); expect(undeleteCommunityRes.community_view.community.deleted).toBe(false);
await delay(); await delay();
// Make sure it got undeleted on A // Make sure it got undeleted on A
let communityOnAlphaUnDeleted = await getCommunity(alpha, communityOnAlpha.id); let communityOnAlphaUnDeleted = await getCommunity(
expect(communityOnAlphaUnDeleted.community.deleted).toBe(false); alpha,
communityOnAlpha.community.id
);
expect(communityOnAlphaUnDeleted.community_view.community.deleted).toBe(
false
);
}); });
test('Remove community', async () => { test('Remove community', async () => {
@ -105,53 +120,65 @@ test('Remove community', async () => {
await delay(); await delay();
// Cache the community on Alpha // Cache the community on Alpha
let searchShort = `!${communityRes.community.name}@lemmy-beta:8551`; let searchShort = `!${communityRes.community_view.community.name}@lemmy-beta:8551`;
let search = await searchForCommunity(alpha, searchShort); let search = await searchForCommunity(alpha, searchShort);
let communityOnAlpha = search.communities[0]; let communityOnAlpha = search.communities[0];
assertCommunityFederation(communityOnAlpha, communityRes.community); assertCommunityFederation(communityOnAlpha, communityRes.community_view);
await delay(); await delay();
// Follow the community from alpha // Follow the community from alpha
let follow = await followCommunity(alpha, true, communityOnAlpha.id); let follow = await followCommunity(
alpha,
true,
communityOnAlpha.community.id
);
// Make sure the follow response went through // Make sure the follow response went through
expect(follow.community.local).toBe(false); expect(follow.community_view.community.local).toBe(false);
await delay(); await delay();
let removeCommunityRes = await removeCommunity( let removeCommunityRes = await removeCommunity(
beta, beta,
true, true,
communityRes.community.id communityRes.community_view.community.id
); );
expect(removeCommunityRes.community.removed).toBe(true); expect(removeCommunityRes.community_view.community.removed).toBe(true);
await delay(); await delay();
// Make sure it got Removed on A // Make sure it got Removed on A
let communityOnAlphaRemoved = await getCommunity(alpha, communityOnAlpha.id); let communityOnAlphaRemoved = await getCommunity(
expect(communityOnAlphaRemoved.community.removed).toBe(true); alpha,
communityOnAlpha.community.id
);
expect(communityOnAlphaRemoved.community_view.community.removed).toBe(true);
await delay(); await delay();
// unremove // unremove
let unremoveCommunityRes = await removeCommunity( let unremoveCommunityRes = await removeCommunity(
beta, beta,
false, false,
communityRes.community.id communityRes.community_view.community.id
); );
expect(unremoveCommunityRes.community.removed).toBe(false); expect(unremoveCommunityRes.community_view.community.removed).toBe(false);
await delay(); await delay();
// Make sure it got undeleted on A // Make sure it got undeleted on A
let communityOnAlphaUnRemoved = await getCommunity(alpha, communityOnAlpha.id); let communityOnAlphaUnRemoved = await getCommunity(
expect(communityOnAlphaUnRemoved.community.removed).toBe(false); alpha,
communityOnAlpha.community.id
);
expect(communityOnAlphaUnRemoved.community_view.community.removed).toBe(
false
);
}); });
test('Search for beta community', async () => { test('Search for beta community', async () => {
let communityRes = await createCommunity(beta); let communityRes = await createCommunity(beta);
expect(communityRes.community.name).toBeDefined(); expect(communityRes.community_view.community.name).toBeDefined();
await delay(); await delay();
let searchShort = `!${communityRes.community.name}@lemmy-beta:8551`; let searchShort = `!${communityRes.community_view.community.name}@lemmy-beta:8551`;
let search = await searchForCommunity(alpha, searchShort); let search = await searchForCommunity(alpha, searchShort);
let communityOnAlpha = search.communities[0]; let communityOnAlpha = search.communities[0];
assertCommunityFederation(communityOnAlpha, communityRes.community); assertCommunityFederation(communityOnAlpha, communityRes.community_view);
}); });

@ -20,24 +20,28 @@ afterAll(async () => {
test('Follow federated community', async () => { test('Follow federated community', async () => {
let search = await searchForBetaCommunity(alpha); // TODO sometimes this is returning null? let search = await searchForBetaCommunity(alpha); // TODO sometimes this is returning null?
let follow = await followCommunity(alpha, true, search.communities[0].id); let follow = await followCommunity(
alpha,
true,
search.communities[0].community.id
);
// Make sure the follow response went through // Make sure the follow response went through
expect(follow.community.local).toBe(false); expect(follow.community_view.community.local).toBe(false);
expect(follow.community.name).toBe('main'); expect(follow.community_view.community.name).toBe('main');
await longDelay(); await longDelay();
// Check it from local // Check it from local
let followCheck = await checkFollowedCommunities(alpha); let followCheck = await checkFollowedCommunities(alpha);
await delay(); await delay();
let remoteCommunityId = followCheck.communities.filter( let remoteCommunityId = followCheck.communities.find(
c => c.community_local == false c => c.community.local == false
)[0].community_id; ).community.id;
expect(remoteCommunityId).toBeDefined(); expect(remoteCommunityId).toBeDefined();
// Test an unfollow // Test an unfollow
let unfollow = await followCommunity(alpha, false, remoteCommunityId); let unfollow = await followCommunity(alpha, false, remoteCommunityId);
expect(unfollow.community.local).toBe(false); expect(unfollow.community_view.community.local).toBe(false);
await delay(); await delay();
// Make sure you are unsubbed locally // Make sure you are unsubbed locally

@ -7,7 +7,7 @@ import {
epsilon, epsilon,
setupLogins, setupLogins,
createPost, createPost,
updatePost, editPost,
stickyPost, stickyPost,
lockPost, lockPost,
searchPost, searchPost,
@ -26,9 +26,7 @@ import {
searchPostLocal, searchPostLocal,
banUserFromCommunity, banUserFromCommunity,
} from './shared'; } from './shared';
import { import { PostView } from 'lemmy-js-client';
Post,
} from 'lemmy-js-client';
beforeAll(async () => { beforeAll(async () => {
await setupLogins(); await setupLogins();
@ -46,50 +44,48 @@ afterAll(async () => {
await unfollowRemotes(epsilon); await unfollowRemotes(epsilon);
}); });
function assertPostFederation( function assertPostFederation(postOne: PostView, postTwo: PostView) {
postOne: Post, expect(postOne.post.ap_id).toBe(postTwo.post.ap_id);
postTwo: Post) { expect(postOne.post.name).toBe(postTwo.post.name);
expect(postOne.ap_id).toBe(postTwo.ap_id); expect(postOne.post.body).toBe(postTwo.post.body);
expect(postOne.name).toBe(postTwo.name); expect(postOne.post.url).toBe(postTwo.post.url);
expect(postOne.body).toBe(postTwo.body); expect(postOne.post.nsfw).toBe(postTwo.post.nsfw);
expect(postOne.url).toBe(postTwo.url); expect(postOne.post.embed_title).toBe(postTwo.post.embed_title);
expect(postOne.nsfw).toBe(postTwo.nsfw); expect(postOne.post.embed_description).toBe(postTwo.post.embed_description);
expect(postOne.embed_title).toBe(postTwo.embed_title); expect(postOne.post.embed_html).toBe(postTwo.post.embed_html);
expect(postOne.embed_description).toBe(postTwo.embed_description); expect(postOne.post.published).toBe(postTwo.post.published);
expect(postOne.embed_html).toBe(postTwo.embed_html); expect(postOne.community.actor_id).toBe(postTwo.community.actor_id);
expect(postOne.published).toBe(postTwo.published); expect(postOne.post.locked).toBe(postTwo.post.locked);
expect(postOne.community_actor_id).toBe(postTwo.community_actor_id); expect(postOne.post.removed).toBe(postTwo.post.removed);
expect(postOne.locked).toBe(postTwo.locked); expect(postOne.post.deleted).toBe(postTwo.post.deleted);
expect(postOne.removed).toBe(postTwo.removed);
expect(postOne.deleted).toBe(postTwo.deleted);
} }
test('Create a post', async () => { test('Create a post', async () => {
let search = await searchForBetaCommunity(alpha); let search = await searchForBetaCommunity(alpha);
await delay(); await delay();
let postRes = await createPost(alpha, search.communities[0].id); let postRes = await createPost(alpha, search.communities[0].community.id);
expect(postRes.post).toBeDefined(); expect(postRes.post_view.post).toBeDefined();
expect(postRes.post.community_local).toBe(false); expect(postRes.post_view.community.local).toBe(false);
expect(postRes.post.creator_local).toBe(true); expect(postRes.post_view.creator.local).toBe(true);
expect(postRes.post.score).toBe(1); expect(postRes.post_view.counts.score).toBe(1);
await longDelay(); await longDelay();
// Make sure that post is liked on beta // Make sure that post is liked on beta
let searchBeta = await searchPost(beta, postRes.post); let searchBeta = await searchPost(beta, postRes.post_view.post);
let betaPost = searchBeta.posts[0]; let betaPost = searchBeta.posts[0];
expect(betaPost).toBeDefined(); expect(betaPost).toBeDefined();
expect(betaPost.community_local).toBe(true); expect(betaPost.community.local).toBe(true);
expect(betaPost.creator_local).toBe(false); expect(betaPost.creator.local).toBe(false);
expect(betaPost.score).toBe(1); expect(betaPost.counts.score).toBe(1);
assertPostFederation(betaPost, postRes.post); assertPostFederation(betaPost, postRes.post_view);
// Delta only follows beta, so it should not see an alpha ap_id // Delta only follows beta, so it should not see an alpha ap_id
let searchDelta = await searchPost(delta, postRes.post); let searchDelta = await searchPost(delta, postRes.post_view.post);
expect(searchDelta.posts[0]).toBeUndefined(); expect(searchDelta.posts[0]).toBeUndefined();
// Epsilon has alpha blocked, it should not see the alpha post // Epsilon has alpha blocked, it should not see the alpha post
let searchEpsilon = await searchPost(epsilon, postRes.post); let searchEpsilon = await searchPost(epsilon, postRes.post_view.post);
expect(searchEpsilon.posts[0]).toBeUndefined(); expect(searchEpsilon.posts[0]).toBeUndefined();
}); });
@ -100,245 +96,244 @@ test('Create a post in a non-existent community', async () => {
test('Unlike a post', async () => { test('Unlike a post', async () => {
let search = await searchForBetaCommunity(alpha); let search = await searchForBetaCommunity(alpha);
let postRes = await createPost(alpha, search.communities[0].id); let postRes = await createPost(alpha, search.communities[0].community.id);
await delay(); await delay();
let unlike = await likePost(alpha, 0, postRes.post); let unlike = await likePost(alpha, 0, postRes.post_view.post);
expect(unlike.post.score).toBe(0); expect(unlike.post_view.counts.score).toBe(0);
await delay(); await delay();
// Try to unlike it again, make sure it stays at 0 // Try to unlike it again, make sure it stays at 0
let unlike2 = await likePost(alpha, 0, postRes.post); let unlike2 = await likePost(alpha, 0, postRes.post_view.post);
expect(unlike2.post.score).toBe(0); expect(unlike2.post_view.counts.score).toBe(0);
await longDelay(); await longDelay();
// Make sure that post is unliked on beta // Make sure that post is unliked on beta
let searchBeta = await searchPost(beta, postRes.post); let searchBeta = await searchPost(beta, postRes.post_view.post);
let betaPost = searchBeta.posts[0]; let betaPost = searchBeta.posts[0];
expect(betaPost).toBeDefined(); expect(betaPost).toBeDefined();
expect(betaPost.community_local).toBe(true); expect(betaPost.community.local).toBe(true);
expect(betaPost.creator_local).toBe(false); expect(betaPost.creator.local).toBe(false);
expect(betaPost.score).toBe(0); expect(betaPost.counts.score).toBe(0);
assertPostFederation(betaPost, postRes.post); assertPostFederation(betaPost, postRes.post_view);
}); });
test('Update a post', async () => { test('Update a post', async () => {
let search = await searchForBetaCommunity(alpha); let search = await searchForBetaCommunity(alpha);
let postRes = await createPost(alpha, search.communities[0].id); let postRes = await createPost(alpha, search.communities[0].community.id);
await delay(); await delay();
let updatedName = 'A jest test federated post, updated'; let updatedName = 'A jest test federated post, updated';
let updatedPost = await updatePost(alpha, postRes.post); let updatedPost = await editPost(alpha, postRes.post_view.post);
expect(updatedPost.post.name).toBe(updatedName); expect(updatedPost.post_view.post.name).toBe(updatedName);
expect(updatedPost.post.community_local).toBe(false); expect(updatedPost.post_view.community.local).toBe(false);
expect(updatedPost.post.creator_local).toBe(true); expect(updatedPost.post_view.creator.local).toBe(true);
await delay(); await delay();
// Make sure that post is updated on beta // Make sure that post is updated on beta
let searchBeta = await searchPost(beta, postRes.post); let searchBeta = await searchPost(beta, postRes.post_view.post);
let betaPost = searchBeta.posts[0]; let betaPost = searchBeta.posts[0];
expect(betaPost.community_local).toBe(true); expect(betaPost.community.local).toBe(true);
expect(betaPost.creator_local).toBe(false); expect(betaPost.creator.local).toBe(false);
expect(betaPost.name).toBe(updatedName); expect(betaPost.post.name).toBe(updatedName);
assertPostFederation(betaPost, updatedPost.post); assertPostFederation(betaPost, updatedPost.post_view);
await delay(); await delay();
// Make sure lemmy beta cannot update the post // Make sure lemmy beta cannot update the post
let updatedPostBeta = await updatePost(beta, betaPost); let updatedPostBeta = await editPost(beta, betaPost.post);
expect(updatedPostBeta).toStrictEqual({ error: 'no_post_edit_allowed' }); expect(updatedPostBeta).toStrictEqual({ error: 'no_post_edit_allowed' });
}); });
test('Sticky a post', async () => { test('Sticky a post', async () => {
let search = await searchForBetaCommunity(alpha); let search = await searchForBetaCommunity(alpha);
let postRes = await createPost(alpha, search.communities[0].id); let postRes = await createPost(alpha, search.communities[0].community.id);
await delay(); await delay();
let stickiedPostRes = await stickyPost(alpha, true, postRes.post); let stickiedPostRes = await stickyPost(alpha, true, postRes.post_view.post);
expect(stickiedPostRes.post.stickied).toBe(true); expect(stickiedPostRes.post_view.post.stickied).toBe(true);
await delay(); await delay();
// Make sure that post is stickied on beta // Make sure that post is stickied on beta
let searchBeta = await searchPost(beta, postRes.post); let searchBeta = await searchPost(beta, postRes.post_view.post);
let betaPost = searchBeta.posts[0]; let betaPost = searchBeta.posts[0];
expect(betaPost.community_local).toBe(true); expect(betaPost.community.local).toBe(true);
expect(betaPost.creator_local).toBe(false); expect(betaPost.creator.local).toBe(false);
expect(betaPost.stickied).toBe(true); expect(betaPost.post.stickied).toBe(true);
// Unsticky a post // Unsticky a post
let unstickiedPost = await stickyPost(alpha, false, postRes.post); let unstickiedPost = await stickyPost(alpha, false, postRes.post_view.post);
expect(unstickiedPost.post.stickied).toBe(false); expect(unstickiedPost.post_view.post.stickied).toBe(false);
await delay(); await delay();
// Make sure that post is unstickied on beta // Make sure that post is unstickied on beta
let searchBeta2 = await searchPost(beta, postRes.post); let searchBeta2 = await searchPost(beta, postRes.post_view.post);
let betaPost2 = searchBeta2.posts[0]; let betaPost2 = searchBeta2.posts[0];
expect(betaPost2.community_local).toBe(true); expect(betaPost2.community.local).toBe(true);
expect(betaPost2.creator_local).toBe(false); expect(betaPost2.creator.local).toBe(false);
expect(betaPost2.stickied).toBe(false); expect(betaPost2.post.stickied).toBe(false);
// Make sure that gamma cannot sticky the post on beta // Make sure that gamma cannot sticky the post on beta
let searchGamma = await searchPost(gamma, postRes.post); let searchGamma = await searchPost(gamma, postRes.post_view.post);
let gammaPost = searchGamma.posts[0]; let gammaPost = searchGamma.posts[0];
let gammaTrySticky = await stickyPost(gamma, true, gammaPost); let gammaTrySticky = await stickyPost(gamma, true, gammaPost.post);
await delay(); await delay();
let searchBeta3 = await searchPost(beta, postRes.post); let searchBeta3 = await searchPost(beta, postRes.post_view.post);
let betaPost3 = searchBeta3.posts[0]; let betaPost3 = searchBeta3.posts[0];
expect(gammaTrySticky.post.stickied).toBe(true); expect(gammaTrySticky.post_view.post.stickied).toBe(true);
expect(betaPost3.stickied).toBe(false); expect(betaPost3.post.stickied).toBe(false);
}); });
test('Lock a post', async () => { test('Lock a post', async () => {
let search = await searchForBetaCommunity(alpha); let search = await searchForBetaCommunity(alpha);
await delay(); await delay();
let postRes = await createPost(alpha, search.communities[0].id); let postRes = await createPost(alpha, search.communities[0].community.id);
await delay(); await delay();
// Lock the post // Lock the post
let lockedPostRes = await lockPost(alpha, true, postRes.post); let lockedPostRes = await lockPost(alpha, true, postRes.post_view.post);
expect(lockedPostRes.post.locked).toBe(true); expect(lockedPostRes.post_view.post.locked).toBe(true);
await longDelay(); await longDelay();
// Make sure that post is locked on beta // Make sure that post is locked on beta
let searchBeta = await searchPostLocal(beta, postRes.post); let searchBeta = await searchPostLocal(beta, postRes.post_view.post);
let betaPost1 = searchBeta.posts[0]; let betaPost1 = searchBeta.posts[0];
expect(betaPost1.locked).toBe(true); expect(betaPost1.post.locked).toBe(true);
await delay(); await delay();
// Try to make a new comment there, on alpha // Try to make a new comment there, on alpha
let comment = await createComment(alpha, postRes.post.id); let comment: any = await createComment(alpha, postRes.post_view.post.id);
expect(comment['error']).toBe('locked'); expect(comment['error']).toBe('locked');
await delay(); await delay();
// Unlock a post // Unlock a post
let unlockedPost = await lockPost(alpha, false, postRes.post); let unlockedPost = await lockPost(alpha, false, postRes.post_view.post);
expect(unlockedPost.post.locked).toBe(false); expect(unlockedPost.post_view.post.locked).toBe(false);
await delay(); await delay();
// Make sure that post is unlocked on beta // Make sure that post is unlocked on beta
let searchBeta2 = await searchPost(beta, postRes.post); let searchBeta2 = await searchPost(beta, postRes.post_view.post);
let betaPost2 = searchBeta2.posts[0]; let betaPost2 = searchBeta2.posts[0];
expect(betaPost2.community_local).toBe(true); expect(betaPost2.community.local).toBe(true);
expect(betaPost2.creator_local).toBe(false); expect(betaPost2.creator.local).toBe(false);
expect(betaPost2.locked).toBe(false); expect(betaPost2.post.locked).toBe(false);
// Try to create a new comment, on beta // Try to create a new comment, on beta
let commentBeta = await createComment(beta, betaPost2.id); let commentBeta = await createComment(beta, betaPost2.post.id);
expect(commentBeta).toBeDefined(); expect(commentBeta).toBeDefined();
}); });
test('Delete a post', async () => { test('Delete a post', async () => {
let search = await searchForBetaCommunity(alpha); let search = await searchForBetaCommunity(alpha);
let postRes = await createPost(alpha, search.communities[0].id); let postRes = await createPost(alpha, search.communities[0].community.id);
await delay(); await delay();
let deletedPost = await deletePost(alpha, true, postRes.post); let deletedPost = await deletePost(alpha, true, postRes.post_view.post);
expect(deletedPost.post.deleted).toBe(true); expect(deletedPost.post_view.post.deleted).toBe(true);
await delay(); await delay();
// Make sure lemmy beta sees post is deleted // Make sure lemmy beta sees post is deleted
let searchBeta = await searchPost(beta, postRes.post); let searchBeta = await searchPost(beta, postRes.post_view.post);
let betaPost = searchBeta.posts[0]; let betaPost = searchBeta.posts[0];
// This will be undefined because of the tombstone // This will be undefined because of the tombstone
expect(betaPost).toBeUndefined(); expect(betaPost).toBeUndefined();
await delay(); await delay();
// Undelete // Undelete
let undeletedPost = await deletePost(alpha, false, postRes.post); let undeletedPost = await deletePost(alpha, false, postRes.post_view.post);
expect(undeletedPost.post.deleted).toBe(false); expect(undeletedPost.post_view.post.deleted).toBe(false);
await delay(); await delay();
// Make sure lemmy beta sees post is undeleted // Make sure lemmy beta sees post is undeleted
let searchBeta2 = await searchPost(beta, postRes.post); let searchBeta2 = await searchPost(beta, postRes.post_view.post);
let betaPost2 = searchBeta2.posts[0]; let betaPost2 = searchBeta2.posts[0];
expect(betaPost2.deleted).toBe(false); expect(betaPost2.post.deleted).toBe(false);
assertPostFederation(betaPost2, undeletedPost.post); assertPostFederation(betaPost2, undeletedPost.post_view);
// Make sure lemmy beta cannot delete the post // Make sure lemmy beta cannot delete the post
let deletedPostBeta = await deletePost(beta, true, betaPost2); let deletedPostBeta = await deletePost(beta, true, betaPost2.post);
expect(deletedPostBeta).toStrictEqual({ error: 'no_post_edit_allowed' }); expect(deletedPostBeta).toStrictEqual({ error: 'no_post_edit_allowed' });
}); });
test('Remove a post from admin and community on different instance', async () => { test('Remove a post from admin and community on different instance', async () => {
let search = await searchForBetaCommunity(alpha); let search = await searchForBetaCommunity(alpha);
let postRes = await createPost(alpha, search.communities[0].id); let postRes = await createPost(alpha, search.communities[0].community.id);
await delay(); await delay();
let removedPost = await removePost(alpha, true, postRes.post); let removedPost = await removePost(alpha, true, postRes.post_view.post);
expect(removedPost.post.removed).toBe(true); expect(removedPost.post_view.post.removed).toBe(true);
await delay(); await delay();
// Make sure lemmy beta sees post is NOT removed // Make sure lemmy beta sees post is NOT removed
let searchBeta = await searchPost(beta, postRes.post); let searchBeta = await searchPost(beta, postRes.post_view.post);
let betaPost = searchBeta.posts[0]; let betaPost = searchBeta.posts[0];
expect(betaPost.removed).toBe(false); expect(betaPost.post.removed).toBe(false);
await delay(); await delay();
// Undelete // Undelete
let undeletedPost = await removePost(alpha, false, postRes.post); let undeletedPost = await removePost(alpha, false, postRes.post_view.post);
expect(undeletedPost.post.removed).toBe(false); expect(undeletedPost.post_view.post.removed).toBe(false);
await delay(); await delay();
// Make sure lemmy beta sees post is undeleted // Make sure lemmy beta sees post is undeleted
let searchBeta2 = await searchPost(beta, postRes.post); let searchBeta2 = await searchPost(beta, postRes.post_view.post);
let betaPost2 = searchBeta2.posts[0]; let betaPost2 = searchBeta2.posts[0];
expect(betaPost2.removed).toBe(false); expect(betaPost2.post.removed).toBe(false);
assertPostFederation(betaPost2, undeletedPost.post); assertPostFederation(betaPost2, undeletedPost.post_view);
}); });
test('Remove a post from admin and community on same instance', async () => { test('Remove a post from admin and community on same instance', async () => {
let search = await searchForBetaCommunity(alpha); let search = await searchForBetaCommunity(alpha);
let postRes = await createPost(alpha, search.communities[0].id); let postRes = await createPost(alpha, search.communities[0].community.id);
await longDelay(); await longDelay();
// Get the id for beta // Get the id for beta
let searchBeta = await searchPost(beta, postRes.post); let searchBeta = await searchPost(beta, postRes.post_view.post);
let betaPost = searchBeta.posts[0]; let betaPost = searchBeta.posts[0];
await longDelay(); await longDelay();
// The beta admin removes it (the community lives on beta) // The beta admin removes it (the community lives on beta)
let removePostRes = await removePost(beta, true, betaPost); let removePostRes = await removePost(beta, true, betaPost.post);
expect(removePostRes.post.removed).toBe(true); expect(removePostRes.post_view.post.removed).toBe(true);
await longDelay(); await longDelay();
// Make sure lemmy alpha sees post is removed // Make sure lemmy alpha sees post is removed
let alphaPost = await getPost(alpha, postRes.post.id); let alphaPost = await getPost(alpha, postRes.post_view.post.id);
expect(alphaPost.post.removed).toBe(true); expect(alphaPost.post_view.post.removed).toBe(true);
assertPostFederation(alphaPost.post, removePostRes.post); assertPostFederation(alphaPost.post_view, removePostRes.post_view);
await longDelay(); await longDelay();
// Undelete // Undelete
let undeletedPost = await removePost(beta, false, betaPost); let undeletedPost = await removePost(beta, false, betaPost.post);
expect(undeletedPost.post.removed).toBe(false); expect(undeletedPost.post_view.post.removed).toBe(false);
await longDelay(); await longDelay();
// Make sure lemmy alpha sees post is undeleted // Make sure lemmy alpha sees post is undeleted
let alphaPost2 = await getPost(alpha, postRes.post.id); let alphaPost2 = await getPost(alpha, postRes.post_view.post.id);
await delay(); await delay();
expect(alphaPost2.post.removed).toBe(false); expect(alphaPost2.post_view.post.removed).toBe(false);
assertPostFederation(alphaPost2.post, undeletedPost.post); assertPostFederation(alphaPost2.post_view, undeletedPost.post_view);
}); });
test('Search for a post', async () => { test('Search for a post', async () => {
let search = await searchForBetaCommunity(alpha); let search = await searchForBetaCommunity(alpha);
await delay(); await delay();
let postRes = await createPost(alpha, search.communities[0].id); let postRes = await createPost(alpha, search.communities[0].community.id);
await delay(); await delay();
let searchBeta = await searchPost(beta, postRes.post); let searchBeta = await searchPost(beta, postRes.post_view.post);
expect(searchBeta.posts[0].name).toBeDefined(); expect(searchBeta.posts[0].post.name).toBeDefined();
}); });
test('A and G subscribe to B (center) A posts, it gets announced to G', async () => { test('A and G subscribe to B (center) A posts, it gets announced to G', async () => {
let search = await searchForBetaCommunity(alpha); let search = await searchForBetaCommunity(alpha);
let postRes = await createPost(alpha, search.communities[0].id); let postRes = await createPost(alpha, search.communities[0].community.id);
await delay(); await delay();
let search2 = await searchPost(gamma, postRes.post); let search2 = await searchPost(gamma, postRes.post_view.post);
expect(search2.posts[0].name).toBeDefined(); expect(search2.posts[0].post.name).toBeDefined();
}); });
test('Enforce site ban for federated user', async () => { test('Enforce site ban for federated user', async () => {
let alphaShortname = `@lemmy_alpha@lemmy-alpha:8541`; let alphaShortname = `@lemmy_alpha@lemmy-alpha:8541`;
let userSearch = await searchForUser(beta, alphaShortname); let userSearch = await searchForUser(beta, alphaShortname);
let alphaUser = userSearch.users[0]; let alphaUser = userSearch.users[0];
@ -346,28 +341,28 @@ test('Enforce site ban for federated user', async () => {
await delay(); await delay();
// ban alpha from beta site // ban alpha from beta site
let banAlpha = await banUserFromSite(beta, alphaUser.id, true); let banAlpha = await banUserFromSite(beta, alphaUser.user.id, true);
expect(banAlpha.banned).toBe(true); expect(banAlpha.banned).toBe(true);
await longDelay(); await longDelay();
// Alpha makes post on beta // Alpha makes post on beta
let search = await searchForBetaCommunity(alpha); let search = await searchForBetaCommunity(alpha);
await delay(); await delay();
let postRes = await createPost(alpha, search.communities[0].id); let postRes = await createPost(alpha, search.communities[0].community.id);
expect(postRes.post).toBeDefined(); expect(postRes.post_view.post).toBeDefined();
expect(postRes.post.community_local).toBe(false); expect(postRes.post_view.community.local).toBe(false);
expect(postRes.post.creator_local).toBe(true); expect(postRes.post_view.creator.local).toBe(true);
expect(postRes.post.score).toBe(1); expect(postRes.post_view.counts.score).toBe(1);
await longDelay(); await longDelay();
// Make sure that post doesn't make it to beta // Make sure that post doesn't make it to beta
let searchBeta = await searchPostLocal(beta, postRes.post); let searchBeta = await searchPostLocal(beta, postRes.post_view.post);
let betaPost = searchBeta.posts[0]; let betaPost = searchBeta.posts[0];
expect(betaPost).toBeUndefined(); expect(betaPost).toBeUndefined();
await delay(); await delay();
// Unban alpha // Unban alpha
let unBanAlpha = await banUserFromSite(beta, alphaUser.id, false); let unBanAlpha = await banUserFromSite(beta, alphaUser.user.id, false);
expect(unBanAlpha.banned).toBe(false); expect(unBanAlpha.banned).toBe(false);
}); });
@ -379,27 +374,32 @@ test('Enforce community ban for federated user', async () => {
await delay(); await delay();
// ban alpha from beta site // ban alpha from beta site
await banUserFromCommunity(beta, alphaUser.id, 2, false); await banUserFromCommunity(beta, alphaUser.user.id, 2, false);
let banAlpha = await banUserFromCommunity(beta, alphaUser.id, 2, true); let banAlpha = await banUserFromCommunity(beta, alphaUser.user.id, 2, true);
expect(banAlpha.banned).toBe(true); expect(banAlpha.banned).toBe(true);
await longDelay(); await longDelay();
// Alpha makes post on beta // Alpha makes post on beta
let search = await searchForBetaCommunity(alpha); let search = await searchForBetaCommunity(alpha);
await delay(); await delay();
let postRes = await createPost(alpha, search.communities[0].id); let postRes = await createPost(alpha, search.communities[0].community.id);
expect(postRes.post).toBeDefined(); expect(postRes.post_view.post).toBeDefined();
expect(postRes.post.community_local).toBe(false); expect(postRes.post_view.community.local).toBe(false);
expect(postRes.post.creator_local).toBe(true); expect(postRes.post_view.creator.local).toBe(true);
expect(postRes.post.score).toBe(1); expect(postRes.post_view.counts.score).toBe(1);
await longDelay(); await longDelay();
// Make sure that post doesn't make it to beta community // Make sure that post doesn't make it to beta community
let searchBeta = await searchPostLocal(beta, postRes.post); let searchBeta = await searchPostLocal(beta, postRes.post_view.post);
let betaPost = searchBeta.posts[0]; let betaPost = searchBeta.posts[0];
expect(betaPost).toBeUndefined(); expect(betaPost).toBeUndefined();
// Unban alpha // Unban alpha
let unBanAlpha = await banUserFromCommunity(beta, alphaUser.id, 2, false); let unBanAlpha = await banUserFromCommunity(
beta,
alphaUser.user.id,
2,
false
);
expect(unBanAlpha.banned).toBe(false); expect(unBanAlpha.banned).toBe(false);
}); });

@ -5,7 +5,7 @@ import {
setupLogins, setupLogins,
followBeta, followBeta,
createPrivateMessage, createPrivateMessage,
updatePrivateMessage, editPrivateMessage,
listPrivateMessages, listPrivateMessages,
deletePrivateMessage, deletePrivateMessage,
unfollowRemotes, unfollowRemotes,
@ -19,7 +19,7 @@ beforeAll(async () => {
await setupLogins(); await setupLogins();
let follow = await followBeta(alpha); let follow = await followBeta(alpha);
await longDelay(); await longDelay();
recipient_id = follow.community.creator_id; recipient_id = follow.community_view.creator.id;
}); });
afterAll(async () => { afterAll(async () => {
@ -28,55 +28,72 @@ afterAll(async () => {
test('Create a private message', async () => { test('Create a private message', async () => {
let pmRes = await createPrivateMessage(alpha, recipient_id); let pmRes = await createPrivateMessage(alpha, recipient_id);
expect(pmRes.message.content).toBeDefined(); expect(pmRes.private_message_view.private_message.content).toBeDefined();
expect(pmRes.message.local).toBe(true); expect(pmRes.private_message_view.private_message.local).toBe(true);
expect(pmRes.message.creator_local).toBe(true); expect(pmRes.private_message_view.creator.local).toBe(true);
expect(pmRes.message.recipient_local).toBe(false); expect(pmRes.private_message_view.recipient.local).toBe(false);
await delay(); await delay();
let betaPms = await listPrivateMessages(beta); let betaPms = await listPrivateMessages(beta);
expect(betaPms.messages[0].content).toBeDefined(); expect(betaPms.private_messages[0].private_message.content).toBeDefined();
expect(betaPms.messages[0].local).toBe(false); expect(betaPms.private_messages[0].private_message.local).toBe(false);
expect(betaPms.messages[0].creator_local).toBe(false); expect(betaPms.private_messages[0].creator.local).toBe(false);
expect(betaPms.messages[0].recipient_local).toBe(true); expect(betaPms.private_messages[0].recipient.local).toBe(true);
}); });
test('Update a private message', async () => { test('Update a private message', async () => {
let updatedContent = 'A jest test federated private message edited'; let updatedContent = 'A jest test federated private message edited';
let pmRes = await createPrivateMessage(alpha, recipient_id); let pmRes = await createPrivateMessage(alpha, recipient_id);
let pmUpdated = await updatePrivateMessage(alpha, pmRes.message.id); let pmUpdated = await editPrivateMessage(
expect(pmUpdated.message.content).toBe(updatedContent); alpha,
pmRes.private_message_view.private_message.id
);
expect(pmUpdated.private_message_view.private_message.content).toBe(
updatedContent
);
await longDelay(); await longDelay();
let betaPms = await listPrivateMessages(beta); let betaPms = await listPrivateMessages(beta);
expect(betaPms.messages[0].content).toBe(updatedContent); expect(betaPms.private_messages[0].private_message.content).toBe(
updatedContent
);
}); });
test('Delete a private message', async () => { test('Delete a private message', async () => {
let pmRes = await createPrivateMessage(alpha, recipient_id); let pmRes = await createPrivateMessage(alpha, recipient_id);
await delay(); await delay();
let betaPms1 = await listPrivateMessages(beta); let betaPms1 = await listPrivateMessages(beta);
let deletedPmRes = await deletePrivateMessage(alpha, true, pmRes.message.id); let deletedPmRes = await deletePrivateMessage(
expect(deletedPmRes.message.deleted).toBe(true); alpha,
true,
pmRes.private_message_view.private_message.id
);
expect(deletedPmRes.private_message_view.private_message.deleted).toBe(true);
await delay(); await delay();
// The GetPrivateMessages filters out deleted, // The GetPrivateMessages filters out deleted,
// even though they are in the actual database. // even though they are in the actual database.
// no reason to show them // no reason to show them
let betaPms2 = await listPrivateMessages(beta); let betaPms2 = await listPrivateMessages(beta);
expect(betaPms2.messages.length).toBe(betaPms1.messages.length - 1); expect(betaPms2.private_messages.length).toBe(
betaPms1.private_messages.length - 1
);
await delay(); await delay();
// Undelete // Undelete
let undeletedPmRes = await deletePrivateMessage( let undeletedPmRes = await deletePrivateMessage(
alpha, alpha,
false, false,
pmRes.message.id pmRes.private_message_view.private_message.id
);
expect(undeletedPmRes.private_message_view.private_message.deleted).toBe(
false
); );
expect(undeletedPmRes.message.deleted).toBe(false);
await longDelay(); await longDelay();
let betaPms3 = await listPrivateMessages(beta); let betaPms3 = await listPrivateMessages(beta);
expect(betaPms3.messages.length).toBe(betaPms1.messages.length); expect(betaPms3.private_messages.length).toBe(
betaPms1.private_messages.length
);
}); });

@ -1,52 +1,54 @@
import { import {
LoginForm, Login,
LoginResponse, LoginResponse,
Post, CreatePost,
PostForm, EditPost,
Comment, CreateComment,
DeletePostForm, DeletePost,
RemovePostForm, RemovePost,
StickyPostForm, StickyPost,
LockPostForm, LockPost,
PostResponse, PostResponse,
SearchResponse, SearchResponse,
FollowCommunityForm, FollowCommunity,
CommunityResponse, CommunityResponse,
GetFollowedCommunitiesResponse, GetFollowedCommunitiesResponse,
GetPostResponse, GetPostResponse,
RegisterForm, Register,
CommentForm, Comment,
DeleteCommentForm, EditComment,
RemoveCommentForm, DeleteComment,
SearchForm, RemoveComment,
Search,
CommentResponse, CommentResponse,
GetCommunityForm, GetCommunity,
CommunityForm, CreateCommunity,
DeleteCommunityForm, DeleteCommunity,
RemoveCommunityForm, RemoveCommunity,
GetUserMentionsForm, GetUserMentions,
CommentLikeForm, CreateCommentLike,
CreatePostLikeForm, CreatePostLike,
PrivateMessageForm, EditPrivateMessage,
EditPrivateMessageForm, DeletePrivateMessage,
DeletePrivateMessageForm, GetFollowedCommunities,
GetFollowedCommunitiesForm, GetPrivateMessages,
GetPrivateMessagesForm, GetSite,
GetSiteForm, GetPost,
GetPostForm,
PrivateMessageResponse, PrivateMessageResponse,
PrivateMessagesResponse, PrivateMessagesResponse,
GetUserMentionsResponse, GetUserMentionsResponse,
UserSettingsForm, SaveUserSettings,
SortType, SortType,
ListingType, ListingType,
GetSiteResponse, GetSiteResponse,
SearchType, SearchType,
LemmyHttp, LemmyHttp,
BanUserResponse, BanUserResponse,
BanUserForm, BanUser,
BanFromCommunityForm, BanFromCommunity,
BanFromCommunityResponse, BanFromCommunityResponse,
Post,
CreatePrivateMessage,
} from 'lemmy-js-client'; } from 'lemmy-js-client';
export interface API { export interface API {
@ -55,27 +57,27 @@ export interface API {
} }
export let alpha: API = { export let alpha: API = {
client: new LemmyHttp('http://localhost:8541/api/v1'), client: new LemmyHttp('http://localhost:8541/api/v2'),
}; };
export let beta: API = { export let beta: API = {
client: new LemmyHttp('http://localhost:8551/api/v1'), client: new LemmyHttp('http://localhost:8551/api/v2'),
}; };
export let gamma: API = { export let gamma: API = {
client: new LemmyHttp('http://localhost:8561/api/v1'), client: new LemmyHttp('http://localhost:8561/api/v2'),
}; };
export let delta: API = { export let delta: API = {
client: new LemmyHttp('http://localhost:8571/api/v1'), client: new LemmyHttp('http://localhost:8571/api/v2'),
}; };
export let epsilon: API = { export let epsilon: API = {
client: new LemmyHttp('http://localhost:8581/api/v1'), client: new LemmyHttp('http://localhost:8581/api/v2'),
}; };
export async function setupLogins() { export async function setupLogins() {
let formAlpha: LoginForm = { let formAlpha: Login = {
username_or_email: 'lemmy_alpha', username_or_email: 'lemmy_alpha',
password: 'lemmy', password: 'lemmy',
}; };
@ -127,7 +129,7 @@ export async function createPost(
let name = randomString(5); let name = randomString(5);
let body = randomString(10); let body = randomString(10);
let url = 'https://google.com/'; let url = 'https://google.com/';
let form: PostForm = { let form: CreatePost = {
name, name,
url, url,
body, body,
@ -138,9 +140,9 @@ export async function createPost(
return api.client.createPost(form); return api.client.createPost(form);
} }
export async function updatePost(api: API, post: Post): Promise<PostResponse> { export async function editPost(api: API, post: Post): Promise<PostResponse> {
let name = 'A jest test federated post, updated'; let name = 'A jest test federated post, updated';
let form: PostForm = { let form: EditPost = {
name, name,
edit_id: post.id, edit_id: post.id,
auth: api.auth, auth: api.auth,
@ -154,7 +156,7 @@ export async function deletePost(
deleted: boolean, deleted: boolean,
post: Post post: Post
): Promise<PostResponse> { ): Promise<PostResponse> {
let form: DeletePostForm = { let form: DeletePost = {
edit_id: post.id, edit_id: post.id,
deleted: deleted, deleted: deleted,
auth: api.auth, auth: api.auth,
@ -167,7 +169,7 @@ export async function removePost(
removed: boolean, removed: boolean,
post: Post post: Post
): Promise<PostResponse> { ): Promise<PostResponse> {
let form: RemovePostForm = { let form: RemovePost = {
edit_id: post.id, edit_id: post.id,
removed, removed,
auth: api.auth, auth: api.auth,
@ -180,7 +182,7 @@ export async function stickyPost(
stickied: boolean, stickied: boolean,
post: Post post: Post
): Promise<PostResponse> { ): Promise<PostResponse> {
let form: StickyPostForm = { let form: StickyPost = {
edit_id: post.id, edit_id: post.id,
stickied, stickied,
auth: api.auth, auth: api.auth,
@ -193,7 +195,7 @@ export async function lockPost(
locked: boolean, locked: boolean,
post: Post post: Post
): Promise<PostResponse> { ): Promise<PostResponse> {
let form: LockPostForm = { let form: LockPost = {
edit_id: post.id, edit_id: post.id,
locked, locked,
auth: api.auth, auth: api.auth,
@ -205,7 +207,7 @@ export async function searchPost(
api: API, api: API,
post: Post post: Post
): Promise<SearchResponse> { ): Promise<SearchResponse> {
let form: SearchForm = { let form: Search = {
q: post.ap_id, q: post.ap_id,
type_: SearchType.Posts, type_: SearchType.Posts,
sort: SortType.TopAll, sort: SortType.TopAll,
@ -217,7 +219,7 @@ export async function searchPostLocal(
api: API, api: API,
post: Post post: Post
): Promise<SearchResponse> { ): Promise<SearchResponse> {
let form: SearchForm = { let form: Search = {
q: post.name, q: post.name,
type_: SearchType.Posts, type_: SearchType.Posts,
sort: SortType.TopAll, sort: SortType.TopAll,
@ -229,7 +231,7 @@ export async function getPost(
api: API, api: API,
post_id: number post_id: number
): Promise<GetPostResponse> { ): Promise<GetPostResponse> {
let form: GetPostForm = { let form: GetPost = {
id: post_id, id: post_id,
}; };
return api.client.getPost(form); return api.client.getPost(form);
@ -239,7 +241,7 @@ export async function searchComment(
api: API, api: API,
comment: Comment comment: Comment
): Promise<SearchResponse> { ): Promise<SearchResponse> {
let form: SearchForm = { let form: Search = {
q: comment.ap_id, q: comment.ap_id,
type_: SearchType.Comments, type_: SearchType.Comments,
sort: SortType.TopAll, sort: SortType.TopAll,
@ -252,7 +254,7 @@ export async function searchForBetaCommunity(
): Promise<SearchResponse> { ): Promise<SearchResponse> {
// Make sure lemmy-beta/c/main is cached on lemmy_alpha // Make sure lemmy-beta/c/main is cached on lemmy_alpha
// Use short-hand search url // Use short-hand search url
let form: SearchForm = { let form: Search = {
q: '!main@lemmy-beta:8551', q: '!main@lemmy-beta:8551',
type_: SearchType.Communities, type_: SearchType.Communities,
sort: SortType.TopAll, sort: SortType.TopAll,
@ -262,10 +264,10 @@ export async function searchForBetaCommunity(
export async function searchForCommunity( export async function searchForCommunity(
api: API, api: API,
q: string, q: string
): Promise<SearchResponse> { ): Promise<SearchResponse> {
// Use short-hand search url // Use short-hand search url
let form: SearchForm = { let form: Search = {
q, q,
type_: SearchType.Communities, type_: SearchType.Communities,
sort: SortType.TopAll, sort: SortType.TopAll,
@ -279,7 +281,7 @@ export async function searchForUser(
): Promise<SearchResponse> { ): Promise<SearchResponse> {
// Make sure lemmy-beta/c/main is cached on lemmy_alpha // Make sure lemmy-beta/c/main is cached on lemmy_alpha
// Use short-hand search url // Use short-hand search url
let form: SearchForm = { let form: Search = {
q: apShortname, q: apShortname,
type_: SearchType.Users, type_: SearchType.Users,
sort: SortType.TopAll, sort: SortType.TopAll,
@ -290,13 +292,14 @@ export async function searchForUser(
export async function banUserFromSite( export async function banUserFromSite(
api: API, api: API,
user_id: number, user_id: number,
ban: boolean, ban: boolean
): Promise<BanUserResponse> { ): Promise<BanUserResponse> {
// Make sure lemmy-beta/c/main is cached on lemmy_alpha // Make sure lemmy-beta/c/main is cached on lemmy_alpha
// Use short-hand search url // Use short-hand search url
let form: BanUserForm = { let form: BanUser = {
user_id, user_id,
ban, ban,
remove_data: false,
auth: api.auth, auth: api.auth,
}; };
return api.client.banUser(form); return api.client.banUser(form);
@ -306,13 +309,14 @@ export async function banUserFromCommunity(
api: API, api: API,
user_id: number, user_id: number,
community_id: number, community_id: number,
ban: boolean, ban: boolean
): Promise<BanFromCommunityResponse> { ): Promise<BanFromCommunityResponse> {
// Make sure lemmy-beta/c/main is cached on lemmy_alpha // Make sure lemmy-beta/c/main is cached on lemmy_alpha
// Use short-hand search url // Use short-hand search url
let form: BanFromCommunityForm = { let form: BanFromCommunity = {
user_id, user_id,
community_id, community_id,
remove_data: false,
ban, ban,
auth: api.auth, auth: api.auth,
}; };
@ -324,7 +328,7 @@ export async function followCommunity(
follow: boolean, follow: boolean,
community_id: number community_id: number
): Promise<CommunityResponse> { ): Promise<CommunityResponse> {
let form: FollowCommunityForm = { let form: FollowCommunity = {
community_id, community_id,
follow, follow,
auth: api.auth, auth: api.auth,
@ -335,7 +339,7 @@ export async function followCommunity(
export async function checkFollowedCommunities( export async function checkFollowedCommunities(
api: API api: API
): Promise<GetFollowedCommunitiesResponse> { ): Promise<GetFollowedCommunitiesResponse> {
let form: GetFollowedCommunitiesForm = { let form: GetFollowedCommunities = {
auth: api.auth, auth: api.auth,
}; };
return api.client.getFollowedCommunities(form); return api.client.getFollowedCommunities(form);
@ -346,7 +350,7 @@ export async function likePost(
score: number, score: number,
post: Post post: Post
): Promise<PostResponse> { ): Promise<PostResponse> {
let form: CreatePostLikeForm = { let form: CreatePostLike = {
post_id: post.id, post_id: post.id,
score: score, score: score,
auth: api.auth, auth: api.auth,
@ -361,7 +365,7 @@ export async function createComment(
parent_id?: number, parent_id?: number,
content = 'a jest test comment' content = 'a jest test comment'
): Promise<CommentResponse> { ): Promise<CommentResponse> {
let form: CommentForm = { let form: CreateComment = {
content, content,
post_id, post_id,
parent_id, parent_id,
@ -370,12 +374,12 @@ export async function createComment(
return api.client.createComment(form); return api.client.createComment(form);
} }
export async function updateComment( export async function editComment(
api: API, api: API,
edit_id: number, edit_id: number,
content = 'A jest test federated comment update' content = 'A jest test federated comment update'
): Promise<CommentResponse> { ): Promise<CommentResponse> {
let form: CommentForm = { let form: EditComment = {
content, content,
edit_id, edit_id,
auth: api.auth, auth: api.auth,
@ -388,7 +392,7 @@ export async function deleteComment(
deleted: boolean, deleted: boolean,
edit_id: number edit_id: number
): Promise<CommentResponse> { ): Promise<CommentResponse> {
let form: DeleteCommentForm = { let form: DeleteComment = {
edit_id, edit_id,
deleted, deleted,
auth: api.auth, auth: api.auth,
@ -401,7 +405,7 @@ export async function removeComment(
removed: boolean, removed: boolean,
edit_id: number edit_id: number
): Promise<CommentResponse> { ): Promise<CommentResponse> {
let form: RemoveCommentForm = { let form: RemoveComment = {
edit_id, edit_id,
removed, removed,
auth: api.auth, auth: api.auth,
@ -410,7 +414,7 @@ export async function removeComment(
} }
export async function getMentions(api: API): Promise<GetUserMentionsResponse> { export async function getMentions(api: API): Promise<GetUserMentionsResponse> {
let form: GetUserMentionsForm = { let form: GetUserMentions = {
sort: SortType.New, sort: SortType.New,
unread_only: false, unread_only: false,
auth: api.auth, auth: api.auth,
@ -423,7 +427,7 @@ export async function likeComment(
score: number, score: number,
comment: Comment comment: Comment
): Promise<CommentResponse> { ): Promise<CommentResponse> {
let form: CommentLikeForm = { let form: CreateCommentLike = {
comment_id: comment.id, comment_id: comment.id,
score, score,
auth: api.auth, auth: api.auth,
@ -438,7 +442,7 @@ export async function createCommunity(
let description = 'a sample description'; let description = 'a sample description';
let icon = 'https://image.flaticon.com/icons/png/512/35/35896.png'; let icon = 'https://image.flaticon.com/icons/png/512/35/35896.png';
let banner = 'https://image.flaticon.com/icons/png/512/35/35896.png'; let banner = 'https://image.flaticon.com/icons/png/512/35/35896.png';
let form: CommunityForm = { let form: CreateCommunity = {
name: name_, name: name_,
title: name_, title: name_,
description, description,
@ -453,9 +457,9 @@ export async function createCommunity(
export async function getCommunity( export async function getCommunity(
api: API, api: API,
id: number, id: number
): Promise<CommunityResponse> { ): Promise<CommunityResponse> {
let form: GetCommunityForm = { let form: GetCommunity = {
id, id,
}; };
return api.client.getCommunity(form); return api.client.getCommunity(form);
@ -466,7 +470,7 @@ export async function deleteCommunity(
deleted: boolean, deleted: boolean,
edit_id: number edit_id: number
): Promise<CommunityResponse> { ): Promise<CommunityResponse> {
let form: DeleteCommunityForm = { let form: DeleteCommunity = {
edit_id, edit_id,
deleted, deleted,
auth: api.auth, auth: api.auth,
@ -479,7 +483,7 @@ export async function removeCommunity(
removed: boolean, removed: boolean,
edit_id: number edit_id: number
): Promise<CommunityResponse> { ): Promise<CommunityResponse> {
let form: RemoveCommunityForm = { let form: RemoveCommunity = {
edit_id, edit_id,
removed, removed,
auth: api.auth, auth: api.auth,
@ -492,7 +496,7 @@ export async function createPrivateMessage(
recipient_id: number recipient_id: number
): Promise<PrivateMessageResponse> { ): Promise<PrivateMessageResponse> {
let content = 'A jest test federated private message'; let content = 'A jest test federated private message';
let form: PrivateMessageForm = { let form: CreatePrivateMessage = {
content, content,
recipient_id, recipient_id,
auth: api.auth, auth: api.auth,
@ -500,12 +504,12 @@ export async function createPrivateMessage(
return api.client.createPrivateMessage(form); return api.client.createPrivateMessage(form);
} }
export async function updatePrivateMessage( export async function editPrivateMessage(
api: API, api: API,
edit_id: number edit_id: number
): Promise<PrivateMessageResponse> { ): Promise<PrivateMessageResponse> {
let updatedContent = 'A jest test federated private message edited'; let updatedContent = 'A jest test federated private message edited';
let form: EditPrivateMessageForm = { let form: EditPrivateMessage = {
content: updatedContent, content: updatedContent,
edit_id, edit_id,
auth: api.auth, auth: api.auth,
@ -518,7 +522,7 @@ export async function deletePrivateMessage(
deleted: boolean, deleted: boolean,
edit_id: number edit_id: number
): Promise<PrivateMessageResponse> { ): Promise<PrivateMessageResponse> {
let form: DeletePrivateMessageForm = { let form: DeletePrivateMessage = {
deleted, deleted,
edit_id, edit_id,
auth: api.auth, auth: api.auth,
@ -530,7 +534,7 @@ export async function registerUser(
api: API, api: API,
username: string = randomString(5) username: string = randomString(5)
): Promise<LoginResponse> { ): Promise<LoginResponse> {
let form: RegisterForm = { let form: Register = {
username, username,
password: 'test', password: 'test',
password_verify: 'test', password_verify: 'test',
@ -544,11 +548,11 @@ export async function saveUserSettingsBio(
api: API, api: API,
auth: string auth: string
): Promise<LoginResponse> { ): Promise<LoginResponse> {
let form: UserSettingsForm = { let form: SaveUserSettings = {
show_nsfw: true, show_nsfw: true,
theme: 'darkly', theme: 'darkly',
default_sort_type: Object.keys(SortType).indexOf(SortType.Active), default_sort_type: SortType.Active,
default_listing_type: Object.keys(ListingType).indexOf(ListingType.All), default_listing_type: ListingType.All,
lang: 'en', lang: 'en',
show_avatars: true, show_avatars: true,
send_notifications_to_email: false, send_notifications_to_email: false,
@ -560,7 +564,7 @@ export async function saveUserSettingsBio(
export async function saveUserSettings( export async function saveUserSettings(
api: API, api: API,
form: UserSettingsForm form: SaveUserSettings
): Promise<LoginResponse> { ): Promise<LoginResponse> {
return api.client.saveUserSettings(form); return api.client.saveUserSettings(form);
} }
@ -569,7 +573,7 @@ export async function getSite(
api: API, api: API,
auth: string auth: string
): Promise<GetSiteResponse> { ): Promise<GetSiteResponse> {
let form: GetSiteForm = { let form: GetSite = {
auth, auth,
}; };
return api.client.getSite(form); return api.client.getSite(form);
@ -578,7 +582,7 @@ export async function getSite(
export async function listPrivateMessages( export async function listPrivateMessages(
api: API api: API
): Promise<PrivateMessagesResponse> { ): Promise<PrivateMessagesResponse> {
let form: GetPrivateMessagesForm = { let form: GetPrivateMessages = {
auth: api.auth, auth: api.auth,
unread_only: false, unread_only: false,
limit: 999, limit: 999,
@ -592,10 +596,10 @@ export async function unfollowRemotes(
// Unfollow all remote communities // Unfollow all remote communities
let followed = await checkFollowedCommunities(api); let followed = await checkFollowedCommunities(api);
let remoteFollowed = followed.communities.filter( let remoteFollowed = followed.communities.filter(
c => c.community_local == false c => c.community.local == false
); );
for (let cu of remoteFollowed) { for (let cu of remoteFollowed) {
await followCommunity(api, false, cu.community_id); await followCommunity(api, false, cu.community.id);
} }
let followed2 = await checkFollowedCommunities(api); let followed2 = await checkFollowedCommunities(api);
return followed2; return followed2;
@ -606,17 +610,15 @@ export async function followBeta(api: API): Promise<CommunityResponse> {
// Cache it // Cache it
let search = await searchForBetaCommunity(api); let search = await searchForBetaCommunity(api);
let com = search.communities.filter(c => c.local == false); let com = search.communities.find(c => c.community.local == false);
if (com[0]) { if (com) {
let follow = await followCommunity(api, true, com[0].id); let follow = await followCommunity(api, true, com.community.id);
return follow; return follow;
} }
} }
export function delay(millis: number = 500) { export function delay(millis: number = 500) {
return new Promise((resolve, _reject) => { return new Promise(resolve => setTimeout(resolve, millis));
setTimeout(_ => resolve(), millis);
});
} }
export function longDelay() { export function longDelay() {

@ -9,23 +9,23 @@ import {
getSite, getSite,
} from './shared'; } from './shared';
import { import {
UserView, UserViewSafe,
UserSettingsForm, SaveUserSettings,
SortType,
ListingType,
} from 'lemmy-js-client'; } from 'lemmy-js-client';
let auth: string; let auth: string;
let apShortname: string; let apShortname: string;
function assertUserFederation( function assertUserFederation(userOne: UserViewSafe, userTwo: UserViewSafe) {
userOne: UserView, expect(userOne.user.name).toBe(userTwo.user.name);
userTwo: UserView) { expect(userOne.user.preferred_username).toBe(userTwo.user.preferred_username);
expect(userOne.name).toBe(userTwo.name); expect(userOne.user.bio).toBe(userTwo.user.bio);
expect(userOne.preferred_username).toBe(userTwo.preferred_username); expect(userOne.user.actor_id).toBe(userTwo.user.actor_id);
expect(userOne.bio).toBe(userTwo.bio); expect(userOne.user.avatar).toBe(userTwo.user.avatar);
expect(userOne.actor_id).toBe(userTwo.actor_id); expect(userOne.user.banner).toBe(userTwo.user.banner);
expect(userOne.avatar).toBe(userTwo.avatar); expect(userOne.user.published).toBe(userTwo.user.published);
expect(userOne.banner).toBe(userTwo.banner);
expect(userOne.published).toBe(userTwo.published);
} }
test('Create user', async () => { test('Create user', async () => {
@ -55,20 +55,20 @@ test('Save user settings, check changed bio from beta', async () => {
test('Set avatar and banner, check that they are federated', async () => { test('Set avatar and banner, check that they are federated', async () => {
let avatar = 'https://image.flaticon.com/icons/png/512/35/35896.png'; let avatar = 'https://image.flaticon.com/icons/png/512/35/35896.png';
let banner = 'https://image.flaticon.com/icons/png/512/36/35896.png'; let banner = 'https://image.flaticon.com/icons/png/512/36/35896.png';
let form: UserSettingsForm = { let form: SaveUserSettings = {
show_nsfw: false, show_nsfw: false,
theme: "", theme: '',
default_sort_type: 0, default_sort_type: SortType.Hot,
default_listing_type: 0, default_listing_type: ListingType.All,
lang: "", lang: '',
avatar, avatar,
banner, banner,
preferred_username: "user321", preferred_username: 'user321',
show_avatars: false, show_avatars: false,
send_notifications_to_email: false, send_notifications_to_email: false,
auth, auth,
} };
let settingsRes = await saveUserSettings(alpha, form); let _settingsRes = await saveUserSettings(alpha, form);
let searchAlpha = await searchForUser(beta, apShortname); let searchAlpha = await searchForUser(beta, apShortname);
let userOnAlpha = searchAlpha.users[0]; let userOnAlpha = searchAlpha.users[0];

@ -0,0 +1,16 @@
{
"compilerOptions": {
"declaration": true,
"declarationDir": "./dist",
"module": "CommonJS",
"noImplicitAny": true,
"lib": ["es2017", "es7", "es6", "dom"],
"outDir": "./dist",
"target": "ES5",
"moduleResolution": "Node"
},
"include": [
"src/**/*"
],
"exclude": ["node_modules", "dist"]
}

File diff suppressed because it is too large Load Diff

@ -7,7 +7,7 @@ use serde::Deserialize;
pub fn config(cfg: &mut web::ServiceConfig, rate_limit: &RateLimit) { pub fn config(cfg: &mut web::ServiceConfig, rate_limit: &RateLimit) {
cfg.service( cfg.service(
web::scope("/api/v1") web::scope("/api/v2")
// Websockets // Websockets
.service(web::resource("/ws").to(super::websocket::chat_route)) .service(web::resource("/ws").to(super::websocket::chat_route))
// Site // Site

Loading…
Cancel
Save