summaryrefslogtreecommitdiff
path: root/test/block.ts
diff options
context:
space:
mode:
authorsyuilo <Syuilotan@yahoo.co.jp>2021-08-17 21:48:59 +0900
committerGitHub <noreply@github.com>2021-08-17 21:48:59 +0900
commit7015df37e3545d835ecd71cdcd1910fbb16e80da (patch)
tree58fe6dd4352444302dbdadb8a31d540604437495 /test/block.ts
parentFix truncate (#7642) (diff)
downloadsharkey-7015df37e3545d835ecd71cdcd1910fbb16e80da.tar.gz
sharkey-7015df37e3545d835ecd71cdcd1910fbb16e80da.tar.bz2
sharkey-7015df37e3545d835ecd71cdcd1910fbb16e80da.zip
enhance(server): Improve user block (#7640)
* enhance(server): Improve user block * Update CHANGELOG.md * ユーザーリスト対応 * 相手から見れなくなるように * Update 1629004542760-chart-reindex.ts https://github.com/misskey-dev/misskey/commit/2365761ba5445f26c8b66b3b20ef4be44e70d549#commitcomment-54919821 * update test * add test * add todos * Update 1629004542760-chart-reindex.ts
Diffstat (limited to 'test/block.ts')
-rw-r--r--test/block.ts95
1 files changed, 95 insertions, 0 deletions
diff --git a/test/block.ts b/test/block.ts
new file mode 100644
index 0000000000..408b218a79
--- /dev/null
+++ b/test/block.ts
@@ -0,0 +1,95 @@
+/*
+ * Tests of block
+ *
+ * How to run the tests:
+ * > npx cross-env TS_NODE_FILES=true TS_NODE_TRANSPILE_ONLY=true npx mocha test/block.ts --require ts-node/register
+ *
+ * To specify test:
+ * > npx cross-env TS_NODE_FILES=true TS_NODE_TRANSPILE_ONLY=true npx mocha test/block.ts --require ts-node/register -g 'test name'
+ */
+
+process.env.NODE_ENV = 'test';
+
+import * as assert from 'assert';
+import * as childProcess from 'child_process';
+import { async, signup, request, post, startServer, shutdownServer } from './utils';
+
+describe('Block', () => {
+ let p: childProcess.ChildProcess;
+
+ // alice blocks bob
+ let alice: any;
+ let bob: any;
+ let carol: any;
+
+ before(async () => {
+ p = await startServer();
+ alice = await signup({ username: 'alice' });
+ bob = await signup({ username: 'bob' });
+ carol = await signup({ username: 'carol' });
+ });
+
+ after(async () => {
+ await shutdownServer(p);
+ });
+
+ it('Block作成', async(async () => {
+ const res = await request('/blocking/create', {
+ userId: bob.id
+ }, alice);
+
+ assert.strictEqual(res.status, 200);
+ }));
+
+ it('ブロックされているユーザーをフォローできない', async(async () => {
+ const res = await request('/following/create', { userId: alice.id }, bob);
+
+ assert.strictEqual(res.status, 400);
+ assert.strictEqual(res.body.error.id, 'c4ab57cc-4e41-45e9-bfd9-584f61e35ce0');
+ }));
+
+ it('ブロックされているユーザーにリアクションできない', async(async () => {
+ const note = await post(alice, { text: 'hello' });
+
+ const res = await request('/notes/reactions/create', { noteId: note.id, reaction: '👍' }, bob);
+
+ assert.strictEqual(res.status, 400);
+ assert.strictEqual(res.body.error.id, '20ef5475-9f38-4e4c-bd33-de6d979498ec');
+ }));
+
+ it('ブロックされているユーザーに返信できない', async(async () => {
+ const note = await post(alice, { text: 'hello' });
+
+ const res = await request('/notes/create', { replyId: note.id, text: 'yo' }, bob);
+
+ assert.strictEqual(res.status, 400);
+ assert.strictEqual(res.body.error.id, 'b390d7e1-8a5e-46ed-b625-06271cafd3d3');
+ }));
+
+ it('ブロックされているユーザーのノートをRenoteできない', async(async () => {
+ const note = await post(alice, { text: 'hello' });
+
+ const res = await request('/notes/create', { renoteId: note.id, text: 'yo' }, bob);
+
+ assert.strictEqual(res.status, 400);
+ assert.strictEqual(res.body.error.id, 'b390d7e1-8a5e-46ed-b625-06271cafd3d3');
+ }));
+
+ // TODO: ユーザーリストに入れられないテスト
+
+ // TODO: ユーザーリストから除外されるテスト
+
+ it('タイムライン(LTL)にブロックされているユーザーの投稿が含まれない', async(async () => {
+ const aliceNote = await post(alice);
+ const bobNote = await post(bob);
+ const carolNote = await post(carol);
+
+ const res = await request('/notes/local-timeline', {}, bob);
+
+ assert.strictEqual(res.status, 200);
+ assert.strictEqual(Array.isArray(res.body), true);
+ assert.strictEqual(res.body.some((note: any) => note.id === aliceNote.id), false);
+ assert.strictEqual(res.body.some((note: any) => note.id === bobNote.id), true);
+ assert.strictEqual(res.body.some((note: any) => note.id === carolNote.id), true);
+ }));
+});