jest.setTimeout(120000);
+import { None } from "@sniptt/monads";
+import { PersonViewSafe } from "lemmy-js-client";
+
import {
alpha,
beta,
registerUser,
- searchForUser,
- saveUserSettingsBio,
- saveUserSettings,
+ resolvePerson,
getSite,
-} from './shared';
-import {
- UserView,
- UserSettingsForm,
-} from 'lemmy-js-client';
+ createPost,
+ resolveCommunity,
+ createComment,
+ resolveBetaCommunity,
+ deleteUser,
+ resolvePost,
+ API,
+ resolveComment,
+ saveUserSettingsFederated,
+ setupLogins,
+} from "./shared";
+
+beforeAll(async () => {
+ await setupLogins();
+});
-let auth: string;
let apShortname: string;
function assertUserFederation(
- userOne: UserView,
- userTwo: UserView) {
- expect(userOne.name).toBe(userTwo.name);
- expect(userOne.preferred_username).toBe(userTwo.preferred_username);
- expect(userOne.bio).toBe(userTwo.bio);
- expect(userOne.actor_id).toBe(userTwo.actor_id);
- expect(userOne.avatar).toBe(userTwo.avatar);
- expect(userOne.banner).toBe(userTwo.banner);
+ userOne: PersonViewSafe,
+ userTwo: PersonViewSafe
+) {
+ expect(userOne.person.name).toBe(userTwo.person.name);
+ expect(userOne.person.display_name.unwrapOr("none")).toBe(
+ userTwo.person.display_name.unwrapOr("none")
+ );
+ expect(userOne.person.bio.unwrapOr("none")).toBe(
+ userTwo.person.bio.unwrapOr("none")
+ );
+ expect(userOne.person.actor_id).toBe(userTwo.person.actor_id);
+ expect(userOne.person.avatar.unwrapOr("none")).toBe(
+ userTwo.person.avatar.unwrapOr("none")
+ );
+ expect(userOne.person.banner.unwrapOr("none")).toBe(
+ userTwo.person.banner.unwrapOr("none")
+ );
+ expect(userOne.person.published).toBe(userTwo.person.published);
}
-test('Create user', async () => {
+test("Create user", async () => {
let userRes = await registerUser(alpha);
expect(userRes.jwt).toBeDefined();
- auth = userRes.jwt;
+ alpha.auth = userRes.jwt;
- let site = await getSite(alpha, auth);
+ let site = await getSite(alpha);
expect(site.my_user).toBeDefined();
- apShortname = `@${site.my_user.name}@lemmy-alpha:8541`;
+ apShortname = `@${
+ site.my_user.unwrap().local_user_view.person.name
+ }@lemmy-alpha:8541`;
});
-test('Save user settings, check changed bio from beta', async () => {
- let bio = 'a changed bio';
- let userRes = await saveUserSettingsBio(alpha, auth);
+test("Set some user settings, check that they are federated", async () => {
+ await saveUserSettingsFederated(alpha);
+ let alphaPerson = (await resolvePerson(alpha, apShortname)).person.unwrap();
+ let betaPerson = (await resolvePerson(beta, apShortname)).person.unwrap();
+ assertUserFederation(alphaPerson, betaPerson);
+});
+
+test("Delete user", async () => {
+ let userRes = await registerUser(alpha);
expect(userRes.jwt).toBeDefined();
+ let user: API = {
+ client: alpha.client,
+ auth: userRes.jwt,
+ };
- let site = await getSite(alpha, auth);
- expect(site.my_user.bio).toBe(bio);
- let searchAlpha = await searchForUser(alpha, site.my_user.actor_id);
+ // make a local post and comment
+ let alphaCommunity = (
+ await resolveCommunity(user, "!main@lemmy-alpha:8541")
+ ).community.unwrap();
+ let localPost = (await createPost(user, alphaCommunity.community.id))
+ .post_view.post;
+ expect(localPost).toBeDefined();
+ let localComment = (await createComment(user, localPost.id, None))
+ .comment_view.comment;
+ expect(localComment).toBeDefined();
- // Make sure beta sees this bio is changed
- let searchBeta = await searchForUser(beta, apShortname);
- assertUserFederation(searchAlpha.users[0], searchBeta.users[0]);
-});
+ // make a remote post and comment
+ let betaCommunity = (await resolveBetaCommunity(user)).community.unwrap();
+ let remotePost = (await createPost(user, betaCommunity.community.id))
+ .post_view.post;
+ expect(remotePost).toBeDefined();
+ let remoteComment = (await createComment(user, remotePost.id, None))
+ .comment_view.comment;
+ expect(remoteComment).toBeDefined();
-test('Set avatar and banner, check that they are federated', async () => {
- 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 form: UserSettingsForm = {
- show_nsfw: false,
- theme: "",
- default_sort_type: 0,
- default_listing_type: 0,
- lang: "",
- avatar,
- banner,
- preferred_username: "user321",
- show_avatars: false,
- send_notifications_to_email: false,
- auth,
- }
- let settingsRes = await saveUserSettings(alpha, form);
+ await deleteUser(user);
- let searchAlpha = await searchForUser(beta, apShortname);
- let userOnAlpha = searchAlpha.users[0];
- let searchBeta = await searchForUser(beta, apShortname);
- let userOnBeta = searchBeta.users[0];
- assertUserFederation(userOnAlpha, userOnBeta);
-});
\ No newline at end of file
+ expect((await resolvePost(alpha, localPost)).post.isNone()).toBe(true);
+ expect((await resolveComment(alpha, localComment)).comment.isNone()).toBe(
+ true
+ );
+ expect((await resolvePost(alpha, remotePost)).post.isNone()).toBe(true);
+ expect((await resolveComment(alpha, remoteComment)).comment.isNone()).toBe(
+ true
+ );
+});