mirror of
				https://codeberg.org/yeentown/barkey.git
				synced 2025-11-03 23:14:13 +00:00 
			
		
		
		
	* wip * wip * wip * Update SystemAccountService.ts * Update 1740121393164-system-accounts.js * Update DeleteAccountService.ts * wip * wip * wip * wip * Update 1740121393164-system-accounts.js * Update RepositoryModule.ts * wip * wip * wip * Update ApRendererService.ts * wip * wip * Update SystemAccountService.ts * fix tests * fix tests * fix tests * fix tests * fix tests * fix tests * add print logs * ログが長すぎて出てないかもしれない * fix migration * refactor * fix fed-tests * Update RelayService.ts * merge * Update user.test.ts * chore: emit log * fix: tweak sleep duration * fix: exit 1 * fix: wait for misskey processes to become healthy * fix: longer sleep for user deletion * fix: make sleep longer again * デッドロック解消の試み https://github.com/misskey-dev/misskey/issues/15005 * Revert "デッドロック解消の試み" This reverts commit 266141f66fb584371bbb56ef7eba04e14bcff94d. * wip * Update SystemAccountService.ts --------- Co-authored-by: おさむのひと <46447427+samunohito@users.noreply.github.com> Co-authored-by: zyoshoka <107108195+zyoshoka@users.noreply.github.com>
		
			
				
	
	
		
			52 lines
		
	
	
	
		
			2 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			52 lines
		
	
	
	
		
			2 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
import { rejects, strictEqual } from 'node:assert';
 | 
						|
import * as Misskey from 'misskey-js';
 | 
						|
import { createAccount, createModerator, resolveRemoteUser, sleep, type LoginUser } from './utils.js';
 | 
						|
 | 
						|
describe('Abuse report', () => {
 | 
						|
	describe('Forwarding report', () => {
 | 
						|
		let alice: LoginUser, bob: LoginUser, aModerator: LoginUser, bModerator: LoginUser;
 | 
						|
		let bobInA: Misskey.entities.UserDetailedNotMe, aliceInB: Misskey.entities.UserDetailedNotMe;
 | 
						|
 | 
						|
		beforeAll(async () => {
 | 
						|
			[alice, bob] = await Promise.all([
 | 
						|
				createAccount('a.test'),
 | 
						|
				createAccount('b.test'),
 | 
						|
			]);
 | 
						|
 | 
						|
			[aModerator, bModerator] = await Promise.all([
 | 
						|
				createModerator('a.test'),
 | 
						|
				createModerator('b.test'),
 | 
						|
			]);
 | 
						|
 | 
						|
			[bobInA, aliceInB] = await Promise.all([
 | 
						|
				resolveRemoteUser('b.test', bob.id, alice),
 | 
						|
				resolveRemoteUser('a.test', alice.id, bob),
 | 
						|
			]);
 | 
						|
		});
 | 
						|
 | 
						|
		test('Alice reports Bob, moderator in A forwards it, and B moderator receives it', async () => {
 | 
						|
			const comment = crypto.randomUUID();
 | 
						|
			await alice.client.request('users/report-abuse', { userId: bobInA.id, comment });
 | 
						|
			const reports = await aModerator.client.request('admin/abuse-user-reports', {});
 | 
						|
			const report = reports.filter(report => report.comment === comment)[0];
 | 
						|
			await aModerator.client.request('admin/forward-abuse-user-report', { reportId: report.id });
 | 
						|
			await sleep();
 | 
						|
 | 
						|
			const reportsInB = await bModerator.client.request('admin/abuse-user-reports', {});
 | 
						|
			const reportInB = reportsInB.filter(report => report.comment.includes(comment))[0];
 | 
						|
			// NOTE: reporter is not Alice, and is not moderator in A
 | 
						|
			strictEqual(reportInB.reporter.url, 'https://a.test/@system.actor');
 | 
						|
			strictEqual(reportInB.targetUserId, bob.id);
 | 
						|
 | 
						|
			// NOTE: cannot forward multiple times
 | 
						|
			await rejects(
 | 
						|
				async () => await aModerator.client.request('admin/forward-abuse-user-report', { reportId: report.id }),
 | 
						|
				(err: any) => {
 | 
						|
					strictEqual(err.code, 'INTERNAL_ERROR');
 | 
						|
					strictEqual(err.info.e.message, 'The report has already been forwarded.');
 | 
						|
					return true;
 | 
						|
				},
 | 
						|
			);
 | 
						|
		});
 | 
						|
	});
 | 
						|
});
 |