X-Git-Url: http://these/git/?a=blobdiff_plain;f=api_tests%2Fsrc%2Fcomment.spec.ts;h=d7d533119778062833de3d5b3d8e97a84919f9ac;hb=21a87ebaf2e5c038594eb70ef58bd51826259529;hp=693bdaf21b5207a5923fa7f4c70b6c0921cbc30f;hpb=179709cc0942d36c78f53572c8a167b9c4fa05b3;p=lemmy.git diff --git a/api_tests/src/comment.spec.ts b/api_tests/src/comment.spec.ts index 693bdaf2..d7d53311 100644 --- a/api_tests/src/comment.spec.ts +++ b/api_tests/src/comment.spec.ts @@ -1,4 +1,6 @@ jest.setTimeout(180000); + +import { PostResponse } from "lemmy-js-client/dist/types/PostResponse"; import { alpha, beta, @@ -6,354 +8,583 @@ import { setupLogins, createPost, getPost, - searchComment, + resolveComment, likeComment, followBeta, - searchForBetaCommunity, + resolveBetaCommunity, createComment, - updateComment, + editComment, deleteComment, removeComment, getMentions, - searchPost, + resolvePost, unfollowRemotes, createCommunity, registerUser, + reportComment, + listCommentReports, + randomString, API, -} from './shared'; -import { - Comment, -} from 'lemmy-js-client'; - -import { PostResponse } from 'lemmy-js-client'; + unfollows, + getComments, + getCommentParentId, + resolveCommunity, + getPersonDetails, +} from "./shared"; +import { CommentView } from "lemmy-js-client/dist/types/CommentView"; let postRes: PostResponse; beforeAll(async () => { await setupLogins(); + await unfollows(); await followBeta(alpha); await followBeta(gamma); - let search = await searchForBetaCommunity(alpha); - postRes = await createPost( - alpha, - search.communities.filter(c => c.local == false)[0].id - ); + let betaCommunity = (await resolveBetaCommunity(alpha)).community; + if (betaCommunity) { + postRes = await createPost(alpha, betaCommunity.community.id); + } }); afterAll(async () => { - await unfollowRemotes(alpha); - await unfollowRemotes(gamma); + await unfollows(); }); function assertCommentFederation( - commentOne: Comment, - commentTwo: Comment) { - expect(commentOne.ap_id).toBe(commentOne.ap_id); - expect(commentOne.content).toBe(commentTwo.content); - expect(commentOne.creator_name).toBe(commentTwo.creator_name); - expect(commentOne.community_actor_id).toBe(commentTwo.community_actor_id); - expect(commentOne.published).toBe(commentTwo.published); - expect(commentOne.updated).toBe(commentOne.updated); - expect(commentOne.deleted).toBe(commentOne.deleted); - expect(commentOne.removed).toBe(commentOne.removed); + commentOne?: CommentView, + commentTwo?: CommentView, +) { + expect(commentOne?.comment.ap_id).toBe(commentTwo?.comment.ap_id); + expect(commentOne?.comment.content).toBe(commentTwo?.comment.content); + expect(commentOne?.creator.name).toBe(commentTwo?.creator.name); + expect(commentOne?.community.actor_id).toBe(commentTwo?.community.actor_id); + expect(commentOne?.comment.published).toBe(commentTwo?.comment.published); + expect(commentOne?.comment.updated).toBe(commentOne?.comment.updated); + expect(commentOne?.comment.deleted).toBe(commentOne?.comment.deleted); + expect(commentOne?.comment.removed).toBe(commentOne?.comment.removed); } -test('Create a comment', async () => { - let commentRes = await createComment(alpha, postRes.post.id); - expect(commentRes.comment.content).toBeDefined(); - expect(commentRes.comment.community_local).toBe(false); - expect(commentRes.comment.creator_local).toBe(true); - expect(commentRes.comment.score).toBe(1); +test("Create a comment", async () => { + let commentRes = await createComment(alpha, postRes.post_view.post.id); + expect(commentRes.comment_view.comment.content).toBeDefined(); + expect(commentRes.comment_view.community.local).toBe(false); + expect(commentRes.comment_view.creator.local).toBe(true); + expect(commentRes.comment_view.counts.score).toBe(1); // Make sure that comment is liked on beta - let searchBeta = await searchComment(beta, commentRes.comment); - let betaComment = searchBeta.comments[0]; + let betaComment = ( + await resolveComment(beta, commentRes.comment_view.comment) + ).comment; expect(betaComment).toBeDefined(); - expect(betaComment.community_local).toBe(true); - expect(betaComment.creator_local).toBe(false); - expect(betaComment.score).toBe(1); - assertCommentFederation(betaComment, commentRes.comment); + expect(betaComment?.community.local).toBe(true); + expect(betaComment?.creator.local).toBe(false); + expect(betaComment?.counts.score).toBe(1); + assertCommentFederation(betaComment, commentRes.comment_view); }); -test('Create a comment in a non-existent post', async () => { - let commentRes = await createComment(alpha, -1); - expect(commentRes).toStrictEqual({ error: 'couldnt_find_post' }); +test("Create a comment in a non-existent post", async () => { + await expect(createComment(alpha, -1)).rejects.toBe("couldnt_find_post"); }); -test('Update a comment', async () => { - let commentRes = await createComment(alpha, postRes.post.id); +test("Update a comment", async () => { + let commentRes = await createComment(alpha, postRes.post_view.post.id); // Federate the comment first - let searchBeta = await searchComment(beta, commentRes.comment); - assertCommentFederation(searchBeta.comments[0], commentRes.comment); + let betaComment = ( + await resolveComment(beta, commentRes.comment_view.comment) + ).comment; + assertCommentFederation(betaComment, commentRes.comment_view); - let updateCommentRes = await updateComment(alpha, commentRes.comment.id); - expect(updateCommentRes.comment.content).toBe( - 'A jest test federated comment update' + let updateCommentRes = await editComment( + alpha, + commentRes.comment_view.comment.id, ); - expect(updateCommentRes.comment.community_local).toBe(false); - expect(updateCommentRes.comment.creator_local).toBe(true); + expect(updateCommentRes.comment_view.comment.content).toBe( + "A jest test federated comment update", + ); + expect(updateCommentRes.comment_view.community.local).toBe(false); + expect(updateCommentRes.comment_view.creator.local).toBe(true); // Make sure that post is updated on beta - let searchBetaUpdated = await searchComment(beta, commentRes.comment); - assertCommentFederation(searchBetaUpdated.comments[0], updateCommentRes.comment); + let betaCommentUpdated = ( + await resolveComment(beta, commentRes.comment_view.comment) + ).comment; + assertCommentFederation(betaCommentUpdated, updateCommentRes.comment_view); }); -test('Delete a comment', async () => { - let commentRes = await createComment(alpha, postRes.post.id); +test("Delete a comment", async () => { + // creating a comment on alpha (remote from home of community) + let commentRes = await createComment(alpha, postRes.post_view.post.id); + + // Find the comment on beta (home of community) + let betaComment = ( + await resolveComment(beta, commentRes.comment_view.comment) + ).comment; + + if (!betaComment) { + throw "Missing beta comment before delete"; + } + + // Find the comment on remote instance gamma + let gammaComment = ( + await resolveComment(gamma, commentRes.comment_view.comment) + ).comment; + + if (!gammaComment) { + throw "Missing gamma comment (remote-home-remote replication) before delete"; + } let deleteCommentRes = await deleteComment( alpha, true, - commentRes.comment.id + commentRes.comment_view.comment.id, ); - expect(deleteCommentRes.comment.deleted).toBe(true); + expect(deleteCommentRes.comment_view.comment.deleted).toBe(true); // Make sure that comment is undefined on beta - let searchBeta = await searchComment(beta, commentRes.comment); - let betaComment = searchBeta.comments[0]; - expect(betaComment).toBeUndefined(); + await expect( + resolveComment(beta, commentRes.comment_view.comment), + ).rejects.toBe("couldnt_find_object"); + + // Make sure that comment is undefined on gamma after delete + await expect( + resolveComment(gamma, commentRes.comment_view.comment), + ).rejects.toBe("couldnt_find_object"); + // Test undeleting the comment let undeleteCommentRes = await deleteComment( alpha, false, - commentRes.comment.id + commentRes.comment_view.comment.id, ); - expect(undeleteCommentRes.comment.deleted).toBe(false); + expect(undeleteCommentRes.comment_view.comment.deleted).toBe(false); // Make sure that comment is undeleted on beta - let searchBeta2 = await searchComment(beta, commentRes.comment); - let betaComment2 = searchBeta2.comments[0]; - expect(betaComment2.deleted).toBe(false); - assertCommentFederation(searchBeta2.comments[0], undeleteCommentRes.comment); + let betaComment2 = ( + await resolveComment(beta, commentRes.comment_view.comment) + ).comment; + expect(betaComment2?.comment.deleted).toBe(false); + assertCommentFederation(betaComment2, undeleteCommentRes.comment_view); }); -test('Remove a comment from admin and community on the same instance', async () => { - let commentRes = await createComment(alpha, postRes.post.id); +test.skip("Remove a comment from admin and community on the same instance", async () => { + let commentRes = await createComment(alpha, postRes.post_view.post.id); // Get the id for beta - let betaCommentId = (await searchComment(beta, commentRes.comment)) - .comments[0].id; + let betaCommentId = ( + await resolveComment(beta, commentRes.comment_view.comment) + ).comment?.comment.id; + + if (!betaCommentId) { + throw "beta comment id is missing"; + } // The beta admin removes it (the community lives on beta) let removeCommentRes = await removeComment(beta, true, betaCommentId); - expect(removeCommentRes.comment.removed).toBe(true); + expect(removeCommentRes.comment_view.comment.removed).toBe(true); // 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); - expect(refetchedPost.comments[0].removed).toBe(true); + let refetchedPostComments = await getPersonDetails( + alpha, + commentRes.comment_view.comment.creator_id, + ); + expect(refetchedPostComments.comments[0].comment.removed).toBe(true); let unremoveCommentRes = await removeComment(beta, false, betaCommentId); - expect(unremoveCommentRes.comment.removed).toBe(false); + expect(unremoveCommentRes.comment_view.comment.removed).toBe(false); // Make sure that comment is unremoved on beta - let refetchedPost2 = await getPost(alpha, postRes.post.id); - expect(refetchedPost2.comments[0].removed).toBe(false); - assertCommentFederation(refetchedPost2.comments[0], unremoveCommentRes.comment); + let refetchedPostComments2 = await getComments( + alpha, + postRes.post_view.post.id, + ); + expect(refetchedPostComments2.comments[0].comment.removed).toBe(false); + assertCommentFederation( + refetchedPostComments2.comments[0], + unremoveCommentRes.comment_view, + ); }); -test('Remove a comment from admin and community on different instance', async () => { - let alphaUser = await registerUser(alpha); +test("Remove a comment from admin and community on different instance", async () => { + let alpha_user = await registerUser(alpha); let newAlphaApi: API = { client: alpha.client, - auth: alphaUser.jwt, + auth: alpha_user.jwt ?? "", }; // New alpha user creates a community, post, and comment. let newCommunity = await createCommunity(newAlphaApi); - let newPost = await createPost(newAlphaApi, newCommunity.community.id); - let commentRes = await createComment(newAlphaApi, newPost.post.id); - expect(commentRes.comment.content).toBeDefined(); + let newPost = await createPost( + newAlphaApi, + newCommunity.community_view.community.id, + ); + let commentRes = await createComment(newAlphaApi, newPost.post_view.post.id); + expect(commentRes.comment_view.comment.content).toBeDefined(); // Beta searches that to cache it, then removes it - let searchBeta = await searchComment(beta, commentRes.comment); - let betaComment = searchBeta.comments[0]; - let removeCommentRes = await removeComment(beta, true, betaComment.id); - expect(removeCommentRes.comment.removed).toBe(true); + let betaComment = ( + await resolveComment(beta, commentRes.comment_view.comment) + ).comment; + + if (!betaComment) { + throw "beta comment missing"; + } + + let removeCommentRes = await removeComment( + beta, + true, + betaComment.comment.id, + ); + expect(removeCommentRes.comment_view.comment.removed).toBe(true); // Make sure its not removed on alpha - let refetchedPost = await getPost(newAlphaApi, newPost.post.id); - expect(refetchedPost.comments[0].removed).toBe(false); - assertCommentFederation(refetchedPost.comments[0], commentRes.comment); + let refetchedPostComments = await getComments( + alpha, + newPost.post_view.post.id, + ); + expect(refetchedPostComments.comments[0].comment.removed).toBe(false); + assertCommentFederation( + refetchedPostComments.comments[0], + commentRes.comment_view, + ); }); -test('Unlike a comment', async () => { - let commentRes = await createComment(alpha, postRes.post.id); - let unlike = await likeComment(alpha, 0, commentRes.comment); - expect(unlike.comment.score).toBe(0); - - // Make sure that post is unliked on beta - let searchBeta = await searchComment(beta, commentRes.comment); - let betaComment = searchBeta.comments[0]; +test("Unlike a comment", async () => { + let commentRes = await createComment(alpha, postRes.post_view.post.id); + + // Lemmy automatically creates 1 like (vote) by author of comment. + // Make sure that comment is liked (voted up) on gamma, downstream peer + // This is testing replication from remote-home-remote (alpha-beta-gamma) + let gammaComment1 = ( + await resolveComment(gamma, commentRes.comment_view.comment) + ).comment; + expect(gammaComment1).toBeDefined(); + expect(gammaComment1?.community.local).toBe(false); + expect(gammaComment1?.creator.local).toBe(false); + expect(gammaComment1?.counts.score).toBe(1); + + let unlike = await likeComment(alpha, 0, commentRes.comment_view.comment); + expect(unlike.comment_view.counts.score).toBe(0); + + // Make sure that comment is unliked on beta + let betaComment = ( + await resolveComment(beta, commentRes.comment_view.comment) + ).comment; expect(betaComment).toBeDefined(); - expect(betaComment.community_local).toBe(true); - expect(betaComment.creator_local).toBe(false); - expect(betaComment.score).toBe(0); + expect(betaComment?.community.local).toBe(true); + expect(betaComment?.creator.local).toBe(false); + expect(betaComment?.counts.score).toBe(0); + + // Make sure that comment is unliked on gamma, downstream peer + // This is testing replication from remote-home-remote (alpha-beta-gamma) + let gammaComment = ( + await resolveComment(gamma, commentRes.comment_view.comment) + ).comment; + expect(gammaComment).toBeDefined(); + expect(gammaComment?.community.local).toBe(false); + expect(gammaComment?.creator.local).toBe(false); + expect(gammaComment?.counts.score).toBe(0); }); -test('Federated comment like', async () => { - let commentRes = await createComment(alpha, postRes.post.id); +test("Federated comment like", async () => { + let commentRes = await createComment(alpha, postRes.post_view.post.id); // Find the comment on beta - let searchBeta = await searchComment(beta, commentRes.comment); - let betaComment = searchBeta.comments[0]; + let betaComment = ( + await resolveComment(beta, commentRes.comment_view.comment) + ).comment; - let like = await likeComment(beta, 1, betaComment); - expect(like.comment.score).toBe(2); + if (!betaComment) { + throw "Missing beta comment"; + } + + let like = await likeComment(beta, 1, betaComment.comment); + expect(like.comment_view.counts.score).toBe(2); // Get the post from alpha, check the likes - let post = await getPost(alpha, postRes.post.id); - expect(post.comments[0].score).toBe(2); + let postComments = await getComments(alpha, postRes.post_view.post.id); + expect(postComments.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 - let commentRes = await createComment(alpha, postRes.post.id); - let searchBeta = await searchComment(beta, commentRes.comment); - let betaComment = searchBeta.comments[0]; + let commentRes = await createComment(alpha, postRes.post_view.post.id); + let betaComment = ( + await resolveComment(beta, commentRes.comment_view.comment) + ).comment; + + if (!betaComment) { + throw "Missing beta comment"; + } // find that comment id on beta // Reply from beta - let replyRes = await createComment(beta, betaComment.post_id, betaComment.id); - expect(replyRes.comment.content).toBeDefined(); - expect(replyRes.comment.community_local).toBe(true); - expect(replyRes.comment.creator_local).toBe(true); - expect(replyRes.comment.parent_id).toBe(betaComment.id); - expect(replyRes.comment.score).toBe(1); + let replyRes = await createComment( + beta, + betaComment.post.id, + betaComment.comment.id, + ); + expect(replyRes.comment_view.comment.content).toBeDefined(); + expect(replyRes.comment_view.community.local).toBe(true); + expect(replyRes.comment_view.creator.local).toBe(true); + expect(getCommentParentId(replyRes.comment_view.comment)).toBe( + betaComment.comment.id, + ); + expect(replyRes.comment_view.counts.score).toBe(1); // Make sure that comment is seen on alpha // TODO not sure why, but a searchComment back to alpha, for the ap_id of betas // comment, isn't working. // let searchAlpha = await searchComment(alpha, replyRes.comment); - let post = await getPost(alpha, postRes.post.id); - let alphaComment = post.comments[0]; - expect(alphaComment.content).toBeDefined(); - expect(alphaComment.parent_id).toBe(post.comments[1].id); - expect(alphaComment.community_local).toBe(false); - expect(alphaComment.creator_local).toBe(false); - expect(alphaComment.score).toBe(1); - assertCommentFederation(alphaComment, replyRes.comment); + let postComments = await getComments(alpha, postRes.post_view.post.id); + let alphaComment = postComments.comments[0]; + expect(alphaComment.comment.content).toBeDefined(); + expect(getCommentParentId(alphaComment.comment)).toBe( + postComments.comments[1].comment.id, + ); + expect(alphaComment.community.local).toBe(false); + expect(alphaComment.creator.local).toBe(false); + expect(alphaComment.counts.score).toBe(1); + assertCommentFederation(alphaComment, replyRes.comment_view); }); -test('Mention beta', async () => { +test("Mention beta", async () => { // Create a mention on alpha - let mentionContent = 'A test mention of @lemmy_beta@lemmy-beta:8551'; - let commentRes = await createComment(alpha, postRes.post.id); + let mentionContent = "A test mention of @lemmy_beta@lemmy-beta:8551"; + let commentRes = await createComment(alpha, postRes.post_view.post.id); let mentionRes = await createComment( alpha, - postRes.post.id, - commentRes.comment.id, - mentionContent + postRes.post_view.post.id, + commentRes.comment_view.comment.id, + mentionContent, ); - expect(mentionRes.comment.content).toBeDefined(); - expect(mentionRes.comment.community_local).toBe(false); - expect(mentionRes.comment.creator_local).toBe(true); - expect(mentionRes.comment.score).toBe(1); + expect(mentionRes.comment_view.comment.content).toBeDefined(); + expect(mentionRes.comment_view.community.local).toBe(false); + expect(mentionRes.comment_view.creator.local).toBe(true); + expect(mentionRes.comment_view.counts.score).toBe(1); let mentionsRes = await getMentions(beta); - expect(mentionsRes.mentions[0].content).toBeDefined(); - expect(mentionsRes.mentions[0].community_local).toBe(true); - expect(mentionsRes.mentions[0].creator_local).toBe(false); - expect(mentionsRes.mentions[0].score).toBe(1); + expect(mentionsRes.mentions[0].comment.content).toBeDefined(); + expect(mentionsRes.mentions[0].community.local).toBe(true); + expect(mentionsRes.mentions[0].creator.local).toBe(false); + expect(mentionsRes.mentions[0].counts.score).toBe(1); }); -test('Comment Search', async () => { - let commentRes = await createComment(alpha, postRes.post.id); - let searchBeta = await searchComment(beta, commentRes.comment); - assertCommentFederation(searchBeta.comments[0], commentRes.comment); +test("Comment Search", async () => { + let commentRes = await createComment(alpha, postRes.post_view.post.id); + let betaComment = ( + await resolveComment(beta, commentRes.comment_view.comment) + ).comment; + assertCommentFederation(betaComment, 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 - let alphaPost = await createPost(alpha, 2); - expect(alphaPost.post.community_local).toBe(true); + let alphaCommunity = (await resolveCommunity(alpha, "!main@lemmy-alpha:8541")) + .community; + + if (!alphaCommunity) { + throw "Missing alpha community"; + } + + let alphaPost = await createPost(alpha, alphaCommunity.community.id); + expect(alphaPost.post_view.community.local).toBe(true); // Make sure gamma sees it - let search = await searchPost(gamma, alphaPost.post); - let gammaPost = search.posts[0]; + let gammaPost = (await resolvePost(gamma, alphaPost.post_view.post)).post; + + if (!gammaPost) { + throw "Missing gamma post"; + } 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( gamma, - gammaPost.id, + gammaPost.post.id, undefined, - commentContent + commentContent, ); - expect(commentRes.comment.content).toBe(commentContent); - expect(commentRes.comment.community_local).toBe(false); - expect(commentRes.comment.creator_local).toBe(true); - expect(commentRes.comment.score).toBe(1); + expect(commentRes.comment_view.comment.content).toBe(commentContent); + expect(commentRes.comment_view.community.local).toBe(false); + expect(commentRes.comment_view.creator.local).toBe(true); + expect(commentRes.comment_view.counts.score).toBe(1); // Make sure alpha sees it - let alphaPost2 = await getPost(alpha, alphaPost.post.id); - expect(alphaPost2.comments[0].content).toBe(commentContent); - expect(alphaPost2.comments[0].community_local).toBe(true); - expect(alphaPost2.comments[0].creator_local).toBe(false); - expect(alphaPost2.comments[0].score).toBe(1); - assertCommentFederation(alphaPost2.comments[0], commentRes.comment); + let alphaPostComments2 = await getComments( + alpha, + alphaPost.post_view.post.id, + ); + expect(alphaPostComments2.comments[0].comment.content).toBe(commentContent); + expect(alphaPostComments2.comments[0].community.local).toBe(true); + expect(alphaPostComments2.comments[0].creator.local).toBe(false); + expect(alphaPostComments2.comments[0].counts.score).toBe(1); + assertCommentFederation( + alphaPostComments2.comments[0], + commentRes.comment_view, + ); // Make sure beta has mentions let mentionsRes = await getMentions(beta); - expect(mentionsRes.mentions[0].content).toBe(commentContent); - expect(mentionsRes.mentions[0].community_local).toBe(false); - expect(mentionsRes.mentions[0].creator_local).toBe(false); + expect(mentionsRes.mentions[0].comment.content).toBe(commentContent); + expect(mentionsRes.mentions[0].community.local).toBe(false); + expect(mentionsRes.mentions[0].creator.local).toBe(false); // TODO this is failing because fetchInReplyTos aren't getting score // expect(mentionsRes.mentions[0].score).toBe(1); }); -test('Fetch in_reply_tos: A is unsubbed from B, B makes a post, and some embedded comments, A subs to B, B updates the lowest level comment, A fetches both the post and all the inreplyto comments for that post.', async () => { +test("Check that activity from another instance is sent to third instance", async () => { + // Alpha and gamma users follow beta community + let alphaFollow = await followBeta(alpha); + expect(alphaFollow.community_view.community.local).toBe(false); + expect(alphaFollow.community_view.community.name).toBe("main"); + + let gammaFollow = await followBeta(gamma); + expect(gammaFollow.community_view.community.local).toBe(false); + expect(gammaFollow.community_view.community.name).toBe("main"); + + // Create a post on beta + let betaPost = await createPost(beta, 2); + expect(betaPost.post_view.community.local).toBe(true); + + // Make sure gamma and alpha see it + let gammaPost = (await resolvePost(gamma, betaPost.post_view.post)).post; + if (!gammaPost) { + throw "Missing gamma post"; + } + expect(gammaPost.post).toBeDefined(); + + let alphaPost = (await resolvePost(alpha, betaPost.post_view.post)).post; + if (!alphaPost) { + throw "Missing alpha post"; + } + expect(alphaPost.post).toBeDefined(); + + // The bug: gamma comments, and alpha should see it. + let commentContent = "Comment from gamma"; + let commentRes = await createComment( + gamma, + gammaPost.post.id, + undefined, + commentContent, + ); + expect(commentRes.comment_view.comment.content).toBe(commentContent); + expect(commentRes.comment_view.community.local).toBe(false); + expect(commentRes.comment_view.creator.local).toBe(true); + expect(commentRes.comment_view.counts.score).toBe(1); + + // Make sure alpha sees it + let alphaPostComments2 = await getComments(alpha, alphaPost.post.id); + expect(alphaPostComments2.comments[0].comment.content).toBe(commentContent); + expect(alphaPostComments2.comments[0].community.local).toBe(false); + expect(alphaPostComments2.comments[0].creator.local).toBe(false); + expect(alphaPostComments2.comments[0].counts.score).toBe(1); + assertCommentFederation( + alphaPostComments2.comments[0], + commentRes.comment_view, + ); + + await unfollowRemotes(alpha); + await unfollowRemotes(gamma); +}); + +test("Fetch in_reply_tos: A is unsubbed from B, B makes a post, and some embedded comments, A subs to B, B updates the lowest level comment, A fetches both the post and all the inreplyto comments for that post.", async () => { // Unfollow all remote communities - let followed = await unfollowRemotes(alpha); + let site = await unfollowRemotes(alpha); expect( - followed.communities.filter(c => c.community_local == false).length + site.my_user?.follows.filter(c => c.community.local == false).length, ).toBe(0); // B creates a post, and two comments, should be invisible to A let postRes = await createPost(beta, 2); - expect(postRes.post.name).toBeDefined(); + expect(postRes.post_view.post.name).toBeDefined(); - let parentCommentContent = 'An invisible top level comment from beta'; + let parentCommentContent = "An invisible top level comment from beta"; let parentCommentRes = await createComment( beta, - postRes.post.id, + postRes.post_view.post.id, undefined, - parentCommentContent + parentCommentContent, + ); + expect(parentCommentRes.comment_view.comment.content).toBe( + parentCommentContent, ); - expect(parentCommentRes.comment.content).toBe(parentCommentContent); // 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( beta, - postRes.post.id, - parentCommentRes.comment.id, - childCommentContent + postRes.post_view.post.id, + parentCommentRes.comment_view.comment.id, + childCommentContent, + ); + expect(childCommentRes.comment_view.comment.content).toBe( + childCommentContent, ); - expect(childCommentRes.comment.content).toBe(childCommentContent); // Follow beta again let follow = await followBeta(alpha); - expect(follow.community.local).toBe(false); - expect(follow.community.name).toBe('main'); + expect(follow.community_view.community.local).toBe(false); + expect(follow.community_view.community.name).toBe("main"); // 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 updateRes = await updateComment( + let updatedCommentContent = "An update child comment from beta"; + let updateRes = await editComment( beta, - childCommentRes.comment.id, - updatedCommentContent + childCommentRes.comment_view.comment.id, + updatedCommentContent, ); - expect(updateRes.comment.content).toBe(updatedCommentContent); + expect(updateRes.comment_view.comment.content).toBe(updatedCommentContent); // Get the post from alpha - let search = await searchPost(alpha, postRes.post); - let alphaPostB = search.posts[0]; - - let alphaPost = await getPost(alpha, alphaPostB.id); - expect(alphaPost.post.name).toBeDefined(); - assertCommentFederation(alphaPost.comments[1], parentCommentRes.comment); - assertCommentFederation(alphaPost.comments[0], updateRes.comment); - expect(alphaPost.post.community_local).toBe(false); - expect(alphaPost.post.creator_local).toBe(false); + let alphaPostB = (await resolvePost(alpha, postRes.post_view.post)).post; + if (!alphaPostB) { + throw "Missing alpha post B"; + } + + let alphaPost = await getPost(alpha, alphaPostB.post.id); + let alphaPostComments = await getComments(alpha, alphaPostB.post.id); + expect(alphaPost.post_view.post.name).toBeDefined(); + assertCommentFederation( + alphaPostComments.comments[1], + parentCommentRes.comment_view, + ); + assertCommentFederation( + alphaPostComments.comments[0], + updateRes.comment_view, + ); + expect(alphaPost.post_view.community.local).toBe(false); + expect(alphaPost.post_view.creator.local).toBe(false); + + await unfollowRemotes(alpha); +}); + +test("Report a comment", async () => { + let betaCommunity = (await resolveBetaCommunity(beta)).community; + if (!betaCommunity) { + throw "Missing beta community"; + } + let postRes = (await createPost(beta, betaCommunity.community.id)).post_view + .post; + expect(postRes).toBeDefined(); + let commentRes = (await createComment(beta, postRes.id)).comment_view.comment; + expect(commentRes).toBeDefined(); + + let alphaComment = (await resolveComment(alpha, commentRes)).comment?.comment; + if (!alphaComment) { + throw "Missing alpha comment"; + } + + let alphaReport = ( + await reportComment(alpha, alphaComment.id, randomString(10)) + ).comment_report_view.comment_report; + + let betaReport = (await listCommentReports(beta)).comment_reports[0] + .comment_report; + expect(betaReport).toBeDefined(); + expect(betaReport.resolved).toBe(false); + expect(betaReport.original_comment_text).toBe( + alphaReport.original_comment_text, + ); + expect(betaReport.reason).toBe(alphaReport.reason); });