]> Untitled Git - lemmy.git/blob - api_tests/src/post.spec.ts
Trying to fix post test again.
[lemmy.git] / api_tests / src / post.spec.ts
1 jest.setTimeout(120000);
2 import {
3   alpha,
4   beta,
5   gamma,
6   delta,
7   epsilon,
8   setupLogins,
9   createPost,
10   updatePost,
11   stickyPost,
12   lockPost,
13   searchPost,
14   likePost,
15   followBeta,
16   searchForBetaCommunity,
17   createComment,
18   deletePost,
19   removePost,
20   getPost,
21   unfollowRemotes,
22   delay,
23   longDelay,
24   searchForUser,
25   banUserFromSite,
26   searchPostLocal,
27   banUserFromCommunity,
28 } from './shared';
29 import {
30   Post,
31 } from 'lemmy-js-client';
32
33 beforeAll(async () => {
34   await setupLogins();
35   await followBeta(alpha);
36   await followBeta(gamma);
37   await followBeta(delta);
38   await followBeta(epsilon);
39   await longDelay();
40 });
41
42 afterAll(async () => {
43   await unfollowRemotes(alpha);
44   await unfollowRemotes(gamma);
45   await unfollowRemotes(delta);
46   await unfollowRemotes(epsilon);
47 });
48
49 function assertPostFederation(
50   postOne: Post,
51   postTwo: Post) {
52   expect(postOne.ap_id).toBe(postTwo.ap_id);
53   expect(postOne.name).toBe(postTwo.name);
54   expect(postOne.body).toBe(postTwo.body);
55   expect(postOne.url).toBe(postTwo.url);
56   expect(postOne.nsfw).toBe(postTwo.nsfw);
57   expect(postOne.embed_title).toBe(postTwo.embed_title);
58   expect(postOne.embed_description).toBe(postTwo.embed_description);
59   expect(postOne.embed_html).toBe(postTwo.embed_html);
60   expect(postOne.published).toBe(postTwo.published);
61   expect(postOne.community_actor_id).toBe(postTwo.community_actor_id);
62   expect(postOne.locked).toBe(postTwo.locked);
63   expect(postOne.removed).toBe(postTwo.removed);
64   expect(postOne.deleted).toBe(postTwo.deleted);
65 }
66
67 test('Create a post', async () => {
68   let search = await searchForBetaCommunity(alpha);
69   await delay();
70   let postRes = await createPost(alpha, search.communities[0].id);
71   expect(postRes.post).toBeDefined();
72   expect(postRes.post.community_local).toBe(false);
73   expect(postRes.post.creator_local).toBe(true);
74   expect(postRes.post.score).toBe(1);
75   await longDelay();
76
77   // Make sure that post is liked on beta
78   let searchBeta = await searchPost(beta, postRes.post);
79   let betaPost = searchBeta.posts[0];
80
81   expect(betaPost).toBeDefined();
82   expect(betaPost.community_local).toBe(true);
83   expect(betaPost.creator_local).toBe(false);
84   expect(betaPost.score).toBe(1);
85   assertPostFederation(betaPost, postRes.post);
86
87   // Delta only follows beta, so it should not see an alpha ap_id
88   let searchDelta = await searchPost(delta, postRes.post);
89   expect(searchDelta.posts[0]).toBeUndefined();
90
91   // Epsilon has alpha blocked, it should not see the alpha post
92   let searchEpsilon = await searchPost(epsilon, postRes.post);
93   expect(searchEpsilon.posts[0]).toBeUndefined();
94 });
95
96 test('Create a post in a non-existent community', async () => {
97   let postRes = await createPost(alpha, -2);
98   expect(postRes).toStrictEqual({ error: 'couldnt_create_post' });
99 });
100
101 test('Unlike a post', async () => {
102   let search = await searchForBetaCommunity(alpha);
103   let postRes = await createPost(alpha, search.communities[0].id);
104   await delay();
105   let unlike = await likePost(alpha, 0, postRes.post);
106   expect(unlike.post.score).toBe(0);
107   await delay();
108
109   // Try to unlike it again, make sure it stays at 0
110   let unlike2 = await likePost(alpha, 0, postRes.post);
111   expect(unlike2.post.score).toBe(0);
112   await longDelay();
113
114   // Make sure that post is unliked on beta
115   let searchBeta = await searchPost(beta, postRes.post);
116   let betaPost = searchBeta.posts[0];
117
118   expect(betaPost).toBeDefined();
119   expect(betaPost.community_local).toBe(true);
120   expect(betaPost.creator_local).toBe(false);
121   expect(betaPost.score).toBe(0);
122   assertPostFederation(betaPost, postRes.post);
123 });
124
125 test('Update a post', async () => {
126   let search = await searchForBetaCommunity(alpha);
127   let postRes = await createPost(alpha, search.communities[0].id);
128   await delay();
129
130   let updatedName = 'A jest test federated post, updated';
131   let updatedPost = await updatePost(alpha, postRes.post);
132   expect(updatedPost.post.name).toBe(updatedName);
133   expect(updatedPost.post.community_local).toBe(false);
134   expect(updatedPost.post.creator_local).toBe(true);
135   await delay();
136
137   // Make sure that post is updated on beta
138   let searchBeta = await searchPost(beta, postRes.post);
139   let betaPost = searchBeta.posts[0];
140   expect(betaPost.community_local).toBe(true);
141   expect(betaPost.creator_local).toBe(false);
142   expect(betaPost.name).toBe(updatedName);
143   assertPostFederation(betaPost, updatedPost.post);
144   await delay();
145
146   // Make sure lemmy beta cannot update the post
147   let updatedPostBeta = await updatePost(beta, betaPost);
148   expect(updatedPostBeta).toStrictEqual({ error: 'no_post_edit_allowed' });
149 });
150
151 test('Sticky a post', async () => {
152   let search = await searchForBetaCommunity(alpha);
153   let postRes = await createPost(alpha, search.communities[0].id);
154   await delay();
155
156   let stickiedPostRes = await stickyPost(alpha, true, postRes.post);
157   expect(stickiedPostRes.post.stickied).toBe(true);
158   await delay();
159
160   // Make sure that post is stickied on beta
161   let searchBeta = await searchPost(beta, postRes.post);
162   let betaPost = searchBeta.posts[0];
163   expect(betaPost.community_local).toBe(true);
164   expect(betaPost.creator_local).toBe(false);
165   expect(betaPost.stickied).toBe(true);
166
167   // Unsticky a post
168   let unstickiedPost = await stickyPost(alpha, false, postRes.post);
169   expect(unstickiedPost.post.stickied).toBe(false);
170   await longDelay();
171
172   // Make sure that post is unstickied on beta
173   let searchBeta2 = await searchPost(beta, postRes.post);
174   let betaPost2 = searchBeta2.posts[0];
175   expect(betaPost2.community_local).toBe(true);
176   expect(betaPost2.creator_local).toBe(false);
177   expect(betaPost2.stickied).toBe(false);
178
179   // Make sure that gamma cannot sticky the post on beta
180   let searchGamma = await searchPost(gamma, postRes.post);
181   let gammaPost = searchGamma.posts[0];
182   await delay();
183   let gammaTrySticky = await stickyPost(gamma, true, gammaPost);
184   await delay();
185   let searchBeta3 = await searchPost(beta, postRes.post);
186   let betaPost3 = searchBeta3.posts[0];
187   expect(gammaTrySticky.post.stickied).toBe(true);
188   expect(betaPost3.stickied).toBe(false);
189 });
190
191 test('Lock a post', async () => {
192   let search = await searchForBetaCommunity(alpha);
193   await delay();
194   let postRes = await createPost(alpha, search.communities[0].id);
195   await delay();
196
197   // Lock the post
198   let lockedPostRes = await lockPost(alpha, true, postRes.post);
199   expect(lockedPostRes.post.locked).toBe(true);
200   await longDelay();
201
202   // Make sure that post is locked on beta
203   let searchBeta = await searchPostLocal(beta, postRes.post);
204   let betaPost1 = searchBeta.posts[0];
205   expect(betaPost1.locked).toBe(true);
206   await delay();
207
208   // Try to make a new comment there, on alpha
209   let comment = await createComment(alpha, postRes.post.id);
210   expect(comment['error']).toBe('locked');
211   await delay();
212
213   // Unlock a post
214   let unlockedPost = await lockPost(alpha, false, postRes.post);
215   expect(unlockedPost.post.locked).toBe(false);
216   await longDelay();
217
218   // Make sure that post is unlocked on beta
219   let searchBeta2 = await searchPost(beta, postRes.post);
220   let betaPost2 = searchBeta2.posts[0];
221   expect(betaPost2.community_local).toBe(true);
222   expect(betaPost2.creator_local).toBe(false);
223   expect(betaPost2.locked).toBe(false);
224
225   // Try to create a new comment, on beta
226   let commentBeta = await createComment(beta, betaPost2.id);
227   expect(commentBeta).toBeDefined();
228 });
229
230 test('Delete a post', async () => {
231   let search = await searchForBetaCommunity(alpha);
232   let postRes = await createPost(alpha, search.communities[0].id);
233   await delay();
234
235   let deletedPost = await deletePost(alpha, true, postRes.post);
236   expect(deletedPost.post.deleted).toBe(true);
237   await delay();
238
239   // Make sure lemmy beta sees post is deleted
240   let searchBeta = await searchPost(beta, postRes.post);
241   let betaPost = searchBeta.posts[0];
242   // This will be undefined because of the tombstone
243   expect(betaPost).toBeUndefined();
244   await delay();
245
246   // Undelete
247   let undeletedPost = await deletePost(alpha, false, postRes.post);
248   expect(undeletedPost.post.deleted).toBe(false);
249   await delay();
250
251   // Make sure lemmy beta sees post is undeleted
252   let searchBeta2 = await searchPost(beta, postRes.post);
253   let betaPost2 = searchBeta2.posts[0];
254   expect(betaPost2.deleted).toBe(false);
255   assertPostFederation(betaPost2, undeletedPost.post);
256
257   // Make sure lemmy beta cannot delete the post
258   let deletedPostBeta = await deletePost(beta, true, betaPost2);
259   expect(deletedPostBeta).toStrictEqual({ error: 'no_post_edit_allowed' });
260 });
261
262 test('Remove a post from admin and community on different instance', async () => {
263   let search = await searchForBetaCommunity(alpha);
264   let postRes = await createPost(alpha, search.communities[0].id);
265   await delay();
266
267   let removedPost = await removePost(alpha, true, postRes.post);
268   expect(removedPost.post.removed).toBe(true);
269   await delay();
270
271   // Make sure lemmy beta sees post is NOT removed
272   let searchBeta = await searchPost(beta, postRes.post);
273   let betaPost = searchBeta.posts[0];
274   expect(betaPost.removed).toBe(false);
275   await delay();
276
277   // Undelete
278   let undeletedPost = await removePost(alpha, false, postRes.post);
279   expect(undeletedPost.post.removed).toBe(false);
280   await delay();
281
282   // Make sure lemmy beta sees post is undeleted
283   let searchBeta2 = await searchPost(beta, postRes.post);
284   let betaPost2 = searchBeta2.posts[0];
285   expect(betaPost2.removed).toBe(false);
286   assertPostFederation(betaPost2, undeletedPost.post);
287 });
288
289 test('Remove a post from admin and community on same instance', async () => {
290   let search = await searchForBetaCommunity(alpha);
291   await longDelay();
292   let postRes = await createPost(alpha, search.communities[0].id);
293   await longDelay();
294
295   // Get the id for beta
296   let searchBeta = await searchPost(beta, postRes.post);
297   await longDelay();
298   let betaPost = searchBeta.posts[0];
299   await longDelay();
300
301   // The beta admin removes it (the community lives on beta)
302   let removePostRes = await removePost(beta, true, betaPost);
303   expect(removePostRes.post.removed).toBe(true);
304   await longDelay();
305
306   // Make sure lemmy alpha sees post is removed
307   let alphaPost = await getPost(alpha, postRes.post.id);
308   expect(alphaPost.post.removed).toBe(true);
309   assertPostFederation(alphaPost.post, removePostRes.post);
310   await longDelay();
311
312   // Undelete
313   let undeletedPost = await removePost(beta, false, betaPost);
314   expect(undeletedPost.post.removed).toBe(false);
315   await longDelay();
316
317   // Make sure lemmy alpha sees post is undeleted
318   let alphaPost2 = await getPost(alpha, postRes.post.id);
319   await delay();
320   expect(alphaPost2.post.removed).toBe(false);
321   assertPostFederation(alphaPost2.post, undeletedPost.post);
322 });
323
324 test('Search for a post', async () => {
325   let search = await searchForBetaCommunity(alpha);
326   await delay();
327   let postRes = await createPost(alpha, search.communities[0].id);
328   await delay();
329   let searchBeta = await searchPost(beta, postRes.post);
330
331   expect(searchBeta.posts[0].name).toBeDefined();
332 });
333
334 test('A and G subscribe to B (center) A posts, it gets announced to G', async () => {
335   let search = await searchForBetaCommunity(alpha);
336   let postRes = await createPost(alpha, search.communities[0].id);
337   await delay();
338
339   let search2 = await searchPost(gamma, postRes.post);
340   expect(search2.posts[0].name).toBeDefined();
341 });
342
343 test('Enforce site ban for federated user', async () => {
344
345   let alphaShortname = `@lemmy_alpha@lemmy-alpha:8541`;
346   let userSearch = await searchForUser(beta, alphaShortname);
347   let alphaUser = userSearch.users[0];
348   expect(alphaUser).toBeDefined();
349   await delay();
350
351   // ban alpha from beta site
352   let banAlpha = await banUserFromSite(beta, alphaUser.id, true);
353   expect(banAlpha.banned).toBe(true);
354   await longDelay();
355
356   // Alpha makes post on beta
357   let search = await searchForBetaCommunity(alpha);
358   await delay();
359   let postRes = await createPost(alpha, search.communities[0].id);
360   expect(postRes.post).toBeDefined();
361   expect(postRes.post.community_local).toBe(false);
362   expect(postRes.post.creator_local).toBe(true);
363   expect(postRes.post.score).toBe(1);
364   await longDelay();
365
366   // Make sure that post doesn't make it to beta
367   let searchBeta = await searchPostLocal(beta, postRes.post);
368   let betaPost = searchBeta.posts[0];
369   expect(betaPost).toBeUndefined();
370   await delay();
371
372   // Unban alpha
373   let unBanAlpha = await banUserFromSite(beta, alphaUser.id, false);
374   expect(unBanAlpha.banned).toBe(false);
375 });
376
377 test('Enforce community ban for federated user', async () => {
378   let alphaShortname = `@lemmy_alpha@lemmy-alpha:8541`;
379   let userSearch = await searchForUser(beta, alphaShortname);
380   let alphaUser = userSearch.users[0];
381   expect(alphaUser).toBeDefined();
382   await delay();
383
384   // ban alpha from beta site
385   await banUserFromCommunity(beta, alphaUser.id, 2, false);
386   let banAlpha = await banUserFromCommunity(beta, alphaUser.id, 2, true);
387   expect(banAlpha.banned).toBe(true);
388   await longDelay();
389
390   // Alpha makes post on beta
391   let search = await searchForBetaCommunity(alpha);
392   await delay();
393   let postRes = await createPost(alpha, search.communities[0].id);
394   expect(postRes.post).toBeDefined();
395   expect(postRes.post.community_local).toBe(false);
396   expect(postRes.post.creator_local).toBe(true);
397   expect(postRes.post.score).toBe(1);
398   await longDelay();
399
400   // Make sure that post doesn't make it to beta community
401   let searchBeta = await searchPostLocal(beta, postRes.post);
402   let betaPost = searchBeta.posts[0];
403   expect(betaPost).toBeUndefined();
404
405   // Unban alpha
406   let unBanAlpha = await banUserFromCommunity(beta, alphaUser.id, 2, false);
407   expect(unBanAlpha.banned).toBe(false);
408 });