mirror of
https://github.com/misskey-dev/misskey.git
synced 2026-05-13 22:15:41 +02:00
* wip * update fake-timers and migrate * fix * remove jest-mock * fix * fix * fix * fix * attempt to fix unit tests * attempt to fix e2e tests * fix federation test [ci skip] * attempt to fix e2e tests * fix typecheck * fix unit tests * fix * attempt to fix e2e * fix * Revert "attempt to fix e2e" This reverts commitb7b7b05d85. * attempt to fix e2e * revert attempt to fix e2e * update deps * update vitest * migrate * attempt to fix e2e * update * fix * remove vite swc plugin as oxc parser can handle decorators * attempt to fix drive/files/create test * Revert "attempt to fix drive/files/create test" This reverts commit4715153375. * fix: エンドポイントにまつわるテストをunitからe2eに移動 * attempt to fix e2e * remove swc * attempt to fix e2e * Revert "attempt to fix e2e" This reverts commit9fb86a4076. * add logs for debug * attempt to fix e2e * Partially revert "attempt to fix e2e" This reverts commitfb0008c85a. * attempt to fix test * fix: attempt to fix test * Revert "fix: attempt to fix test" This reverts commited2f5c40e8. * Revert "attempt to fix test" This reverts commitd7329c46f1. * attempt to fix e2e * fix: surpass eventemitter warning by increasing defaultMaxListeners * attempt to fix e2e * fix * fix e2e not ending properly * exp: add hanging-process reporter for investigation * Revert "exp: add hanging-process reporter for investigation" This reverts commit26851f8282. * update changelog
121 lines
4.2 KiB
TypeScript
121 lines
4.2 KiB
TypeScript
/*
|
|
* SPDX-FileCopyrightText: syuilo and misskey-project
|
|
* SPDX-License-Identifier: AGPL-3.0-only
|
|
*/
|
|
|
|
process.env.NODE_ENV = 'test';
|
|
|
|
import * as assert from 'assert';
|
|
import { beforeAll, describe, test } from 'vitest';
|
|
import { setTimeout } from 'node:timers/promises';
|
|
import { api, post, signup, waitFire } from '../utils.js';
|
|
import type * as misskey from 'misskey-js';
|
|
|
|
describe('Renote Mute', () => {
|
|
// alice mutes carol
|
|
let alice: misskey.entities.SignupResponse;
|
|
let bob: misskey.entities.SignupResponse;
|
|
let carol: misskey.entities.SignupResponse;
|
|
|
|
beforeAll(async () => {
|
|
alice = await signup({ username: 'alice' });
|
|
bob = await signup({ username: 'bob' });
|
|
carol = await signup({ username: 'carol' });
|
|
}, 1000 * 60 * 2);
|
|
|
|
test('ミュート作成', async () => {
|
|
const res = await api('renote-mute/create', {
|
|
userId: carol.id,
|
|
}, alice);
|
|
|
|
assert.strictEqual(res.status, 204);
|
|
});
|
|
|
|
test('タイムラインにリノートミュートしているユーザーのリノートが含まれない', async () => {
|
|
const bobNote = await post(bob, { text: 'hi' });
|
|
const carolRenote = await post(carol, { renoteId: bobNote.id });
|
|
const carolNote = await post(carol, { text: 'hi' });
|
|
|
|
// redisに追加されるのを待つ
|
|
await setTimeout(100);
|
|
|
|
const res = await api('notes/local-timeline', {}, alice);
|
|
|
|
assert.strictEqual(res.status, 200);
|
|
assert.strictEqual(Array.isArray(res.body), true);
|
|
assert.strictEqual(res.body.some(note => note.id === bobNote.id), true);
|
|
assert.strictEqual(res.body.some(note => note.id === carolRenote.id), false);
|
|
assert.strictEqual(res.body.some(note => note.id === carolNote.id), true);
|
|
});
|
|
|
|
test('タイムラインにリノートミュートしているユーザーの引用が含まれる', async () => {
|
|
const bobNote = await post(bob, { text: 'hi' });
|
|
const carolRenote = await post(carol, { renoteId: bobNote.id, text: 'kore' });
|
|
const carolNote = await post(carol, { text: 'hi' });
|
|
|
|
// redisに追加されるのを待つ
|
|
await setTimeout(100);
|
|
|
|
const res = await api('notes/local-timeline', {}, alice);
|
|
|
|
assert.strictEqual(res.status, 200);
|
|
assert.strictEqual(Array.isArray(res.body), true);
|
|
assert.strictEqual(res.body.some(note => note.id === bobNote.id), true);
|
|
assert.strictEqual(res.body.some(note => note.id === carolRenote.id), true);
|
|
assert.strictEqual(res.body.some(note => note.id === carolNote.id), true);
|
|
});
|
|
|
|
// #12956
|
|
test('タイムラインにリノートミュートしているユーザーの通常ノートのリノートが含まれる', async () => {
|
|
const carolNote = await post(carol, { text: 'hi' });
|
|
const bobRenote = await post(bob, { renoteId: carolNote.id });
|
|
|
|
// redisに追加されるのを待つ
|
|
await setTimeout(100);
|
|
|
|
const res = await api('notes/local-timeline', {}, alice);
|
|
|
|
assert.strictEqual(res.status, 200);
|
|
assert.strictEqual(Array.isArray(res.body), true);
|
|
assert.strictEqual(res.body.some(note => note.id === carolNote.id), true);
|
|
assert.strictEqual(res.body.some(note => note.id === bobRenote.id), true);
|
|
});
|
|
|
|
test('ストリームにリノートミュートしているユーザーのリノートが流れない', async () => {
|
|
const bobNote = await post(bob, { text: 'hi' });
|
|
|
|
const fired = await waitFire(
|
|
alice, 'localTimeline',
|
|
() => api('notes/create', { renoteId: bobNote.id }, carol),
|
|
msg => msg.type === 'note' && msg.body.userId === carol.id,
|
|
);
|
|
|
|
assert.strictEqual(fired, false);
|
|
});
|
|
|
|
test('ストリームにリノートミュートしているユーザーの引用が流れる', async () => {
|
|
const bobNote = await post(bob, { text: 'hi' });
|
|
|
|
const fired = await waitFire(
|
|
alice, 'localTimeline',
|
|
() => api('notes/create', { renoteId: bobNote.id, text: 'kore' }, carol),
|
|
msg => msg.type === 'note' && msg.body.userId === carol.id,
|
|
);
|
|
|
|
assert.strictEqual(fired, true);
|
|
});
|
|
|
|
// #12956
|
|
test('ストリームにリノートミュートしているユーザーの通常ノートのリノートが流れてくる', async () => {
|
|
const carolbNote = await post(carol, { text: 'hi' });
|
|
|
|
const fired = await waitFire(
|
|
alice, 'localTimeline',
|
|
() => api('notes/create', { renoteId: carolbNote.id }, bob),
|
|
msg => msg.type === 'note' && msg.body.userId === bob.id,
|
|
);
|
|
|
|
assert.strictEqual(fired, true);
|
|
});
|
|
});
|