fix waits after all follow actions
This commit is contained in:
parent
48496599b2
commit
943b960c32
4 changed files with 21 additions and 29 deletions
|
@ -42,10 +42,7 @@ let postOnAlphaRes: PostResponse;
|
||||||
beforeAll(async () => {
|
beforeAll(async () => {
|
||||||
await setupLogins();
|
await setupLogins();
|
||||||
await unfollows();
|
await unfollows();
|
||||||
await followBeta(alpha);
|
await Promise.all([followBeta(alpha), followBeta(gamma)]);
|
||||||
await followBeta(gamma);
|
|
||||||
// wait for FOLLOW_ADDITIONS_RECHECK_DELAY
|
|
||||||
await delay(2000);
|
|
||||||
let betaCommunity = (await resolveBetaCommunity(alpha)).community;
|
let betaCommunity = (await resolveBetaCommunity(alpha)).community;
|
||||||
if (betaCommunity) {
|
if (betaCommunity) {
|
||||||
postOnAlphaRes = await createPost(alpha, betaCommunity.community.id);
|
postOnAlphaRes = await createPost(alpha, betaCommunity.community.id);
|
||||||
|
@ -560,8 +557,6 @@ test("Check that activity from another instance is sent to third instance", asyn
|
||||||
() => resolveBetaCommunity(gamma),
|
() => resolveBetaCommunity(gamma),
|
||||||
c => c.community?.subscribed === "Subscribed",
|
c => c.community?.subscribed === "Subscribed",
|
||||||
);
|
);
|
||||||
// FOLLOW_ADDITIONS_RECHECK_DELAY
|
|
||||||
await delay(2000);
|
|
||||||
|
|
||||||
// Create a post on beta
|
// Create a post on beta
|
||||||
let betaPost = await createPost(beta, 2);
|
let betaPost = await createPost(beta, 2);
|
||||||
|
@ -607,8 +602,7 @@ test("Check that activity from another instance is sent to third instance", asyn
|
||||||
commentRes.comment_view,
|
commentRes.comment_view,
|
||||||
);
|
);
|
||||||
|
|
||||||
await unfollowRemotes(alpha);
|
await Promise.all([unfollowRemotes(alpha), unfollowRemotes(gamma)]);
|
||||||
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 () => {
|
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 () => {
|
||||||
|
@ -671,7 +665,8 @@ test("Fetch in_reply_tos: A is unsubbed from B, B makes a post, and some embedde
|
||||||
() => getComments(alpha, alphaPostB!.post.id),
|
() => getComments(alpha, alphaPostB!.post.id),
|
||||||
c =>
|
c =>
|
||||||
c.comments[1]?.comment.content ===
|
c.comments[1]?.comment.content ===
|
||||||
parentCommentRes.comment_view.comment.content,
|
parentCommentRes.comment_view.comment.content &&
|
||||||
|
c.comments[0]?.comment.content === updateRes.comment_view.comment.content,
|
||||||
);
|
);
|
||||||
expect(alphaPost.post_view.post.name).toBeDefined();
|
expect(alphaPost.post_view.post.name).toBeDefined();
|
||||||
assertCommentFederation(
|
assertCommentFederation(
|
||||||
|
|
|
@ -87,12 +87,6 @@ test("Delete community", async () => {
|
||||||
// Make sure the follow response went through
|
// Make sure the follow response went through
|
||||||
expect(follow.community_view.community.local).toBe(false);
|
expect(follow.community_view.community.local).toBe(false);
|
||||||
|
|
||||||
await waitUntil(
|
|
||||||
() => resolveCommunity(alpha, searchShort),
|
|
||||||
g => g.community?.subscribed === "Subscribed",
|
|
||||||
);
|
|
||||||
// wait FOLLOW_ADDITIONS_RECHECK_DELAY
|
|
||||||
await delay(2000);
|
|
||||||
let deleteCommunityRes = await deleteCommunity(
|
let deleteCommunityRes = await deleteCommunity(
|
||||||
beta,
|
beta,
|
||||||
true,
|
true,
|
||||||
|
@ -145,10 +139,6 @@ test("Remove community", async () => {
|
||||||
// Make sure the follow response went through
|
// Make sure the follow response went through
|
||||||
expect(follow.community_view.community.local).toBe(false);
|
expect(follow.community_view.community.local).toBe(false);
|
||||||
|
|
||||||
await waitUntil(
|
|
||||||
() => resolveCommunity(alpha, searchShort),
|
|
||||||
g => g.community?.subscribed === "Subscribed",
|
|
||||||
);
|
|
||||||
let removeCommunityRes = await removeCommunity(
|
let removeCommunityRes = await removeCommunity(
|
||||||
beta,
|
beta,
|
||||||
true,
|
true,
|
||||||
|
|
|
@ -220,8 +220,6 @@ test("Lock a post", async () => {
|
||||||
() => resolveBetaCommunity(alpha),
|
() => resolveBetaCommunity(alpha),
|
||||||
c => c.community?.subscribed === "Subscribed",
|
c => c.community?.subscribed === "Subscribed",
|
||||||
);
|
);
|
||||||
// wait FOLLOW_ADDITIONS_RECHECK_DELAY (there's no API to wait for this currently)
|
|
||||||
await delay(2_000);
|
|
||||||
|
|
||||||
let postRes = await createPost(alpha, betaCommunity.community.id);
|
let postRes = await createPost(alpha, betaCommunity.community.id);
|
||||||
// wait for federation
|
// wait for federation
|
||||||
|
|
|
@ -447,7 +447,14 @@ export async function followCommunity(
|
||||||
follow,
|
follow,
|
||||||
auth: api.auth,
|
auth: api.auth,
|
||||||
};
|
};
|
||||||
return api.client.followCommunity(form);
|
const res = await api.client.followCommunity(form);
|
||||||
|
await waitUntil(
|
||||||
|
() => resolveCommunity(api, res.community_view.community.actor_id),
|
||||||
|
g => g.community?.subscribed === (follow ? "Subscribed" : "NotSubscribed"),
|
||||||
|
);
|
||||||
|
// wait FOLLOW_ADDITIONS_RECHECK_DELAY (there's no API to wait for this currently)
|
||||||
|
await delay(2000);
|
||||||
|
return res;
|
||||||
}
|
}
|
||||||
|
|
||||||
export async function likePost(
|
export async function likePost(
|
||||||
|
@ -745,9 +752,9 @@ export async function unfollowRemotes(api: API): Promise<GetSiteResponse> {
|
||||||
let site = await getSite(api);
|
let site = await getSite(api);
|
||||||
let remoteFollowed =
|
let remoteFollowed =
|
||||||
site.my_user?.follows.filter(c => c.community.local == false) ?? [];
|
site.my_user?.follows.filter(c => c.community.local == false) ?? [];
|
||||||
for (let cu of remoteFollowed) {
|
await Promise.all(
|
||||||
await followCommunity(api, false, cu.community.id);
|
remoteFollowed.map(cu => followCommunity(api, false, cu.community.id)),
|
||||||
}
|
);
|
||||||
let siteRes = await getSite(api);
|
let siteRes = await getSite(api);
|
||||||
return siteRes;
|
return siteRes;
|
||||||
}
|
}
|
||||||
|
@ -841,10 +848,12 @@ export function randomString(length: number): string {
|
||||||
}
|
}
|
||||||
|
|
||||||
export async function unfollows() {
|
export async function unfollows() {
|
||||||
await unfollowRemotes(alpha);
|
await Promise.all([
|
||||||
await unfollowRemotes(gamma);
|
unfollowRemotes(alpha),
|
||||||
await unfollowRemotes(delta);
|
unfollowRemotes(gamma),
|
||||||
await unfollowRemotes(epsilon);
|
unfollowRemotes(delta),
|
||||||
|
unfollowRemotes(epsilon),
|
||||||
|
]);
|
||||||
}
|
}
|
||||||
|
|
||||||
export function getCommentParentId(comment: Comment): number | undefined {
|
export function getCommentParentId(comment: Comment): number | undefined {
|
||||||
|
|
Loading…
Reference in a new issue