mirror of
https://github.com/misskey-dev/misskey.git
synced 2026-03-21 19:43:32 +00:00
* fix(deps): update [backend] update dependencies * update approve builds * update minimum node version for testing * remove types/bcryptjs * fix(backend): remove removed type previously exported from file-type * migrate webauthnservice * Update Changelog * update deps (MisskeyIO#889) - メンテナンスされないredis-lockを自前実装に変更 - 既にロックされている場合のリトライ間隔を調整 * use main redis for lock * spdx * tweak max retries * [ci skip] dedupe * attempt to fix test * attempt to fix test * Revert "attempt to fix test" This reverts commitc508318627. * temporarily roll back simonjs/fake-timers to v11.3.1 * Revert "temporarily roll back simonjs/fake-timers to v11.3.1" This reverts commit54f1fc3d79. * migrate sinonjs/fake-timers * update deps / migrate jest 30 * fix test * fix: update node.js min version to 20.18.1 * fix: rollback nsfwjs to 4.2.0 * fix * attempt to fix test * attempt to fix test * attempt to fix test * attempt to fix test * revert jest 30 related changes * update deps * fix test * fix: rollback nsfwjs to 4.2.0 * fix: rollback sharp to 0.33 * update deps * fix: rollback sharp-read-bmp to 1.2.0 * fix: rollback nsfwjs to 4.2.0 * recreate lockfile * update deps * fix: rollback sharp-read-bmp to 1.2.0 * fix: rollback jsdom, parse5 * fix: rollback jsdom types * fix [ci skip] * run pnpm dedupe * update deps * run pnpm dedupe [ci skip] * Update Changelog [ci skip] --------- Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com> Co-authored-by: kakkokari-gtyih <67428053+kakkokari-gtyih@users.noreply.github.com> Co-authored-by: あわわわとーにゅ <17376330+u1-liquid@users.noreply.github.com> Co-authored-by: syuilo <4439005+syuilo@users.noreply.github.com>
103 lines
3.3 KiB
TypeScript
103 lines
3.3 KiB
TypeScript
/*
|
|
* SPDX-FileCopyrightText: syuilo and misskey-project
|
|
* SPDX-License-Identifier: AGPL-3.0-only
|
|
*/
|
|
|
|
process.env.NODE_ENV = 'test';
|
|
|
|
import { jest } from '@jest/globals';
|
|
import { Test } from '@nestjs/testing';
|
|
import { ModuleMocker } from 'jest-mock';
|
|
import type { TestingModule } from '@nestjs/testing';
|
|
import type { MockMetadata } from 'jest-mock';
|
|
import { ApRendererService } from '@/core/activitypub/ApRendererService.js';
|
|
import { UserEntityService } from '@/core/entities/UserEntityService.js';
|
|
import { IdService } from '@/core/IdService.js';
|
|
import { QueueService } from '@/core/QueueService.js';
|
|
import { RelayService } from '@/core/RelayService.js';
|
|
import { SystemAccountService } from '@/core/SystemAccountService.js';
|
|
import { GlobalModule } from '@/GlobalModule.js';
|
|
import { UtilityService } from '@/core/UtilityService.js';
|
|
|
|
const moduleMocker = new ModuleMocker(global);
|
|
|
|
describe('RelayService', () => {
|
|
let app: TestingModule;
|
|
let relayService: RelayService;
|
|
let queueService: jest.Mocked<QueueService>;
|
|
|
|
beforeAll(async () => {
|
|
app = await Test.createTestingModule({
|
|
imports: [
|
|
GlobalModule,
|
|
],
|
|
providers: [
|
|
IdService,
|
|
ApRendererService,
|
|
RelayService,
|
|
UserEntityService,
|
|
SystemAccountService,
|
|
UtilityService,
|
|
],
|
|
})
|
|
.useMocker((token) => {
|
|
if (token === QueueService) {
|
|
return { deliver: jest.fn() };
|
|
}
|
|
if (typeof token === 'function') {
|
|
const mockMetadata = moduleMocker.getMetadata(token) as MockMetadata<any, any>;
|
|
const Mock = moduleMocker.generateFromMetadata(mockMetadata);
|
|
return new Mock();
|
|
}
|
|
})
|
|
.compile();
|
|
|
|
app.enableShutdownHooks();
|
|
|
|
relayService = app.get<RelayService>(RelayService);
|
|
queueService = app.get<QueueService>(QueueService) as jest.Mocked<QueueService>;
|
|
});
|
|
|
|
afterAll(async () => {
|
|
await app.close();
|
|
});
|
|
|
|
test('addRelay', async () => {
|
|
const result = await relayService.addRelay('https://example.com');
|
|
|
|
expect(result.inbox).toBe('https://example.com');
|
|
expect(result.status).toBe('requesting');
|
|
expect(queueService.deliver).toHaveBeenCalled();
|
|
expect(queueService.deliver.mock.lastCall![1]?.type).toBe('Follow');
|
|
expect(queueService.deliver.mock.lastCall![2]).toBe('https://example.com');
|
|
//expect(queueService.deliver.mock.lastCall![0].username).toBe('relay.actor');
|
|
});
|
|
|
|
test('listRelay', async () => {
|
|
const result = await relayService.listRelay();
|
|
|
|
expect(result.length).toBe(1);
|
|
expect(result[0].inbox).toBe('https://example.com');
|
|
expect(result[0].status).toBe('requesting');
|
|
});
|
|
|
|
test('removeRelay: succ', async () => {
|
|
await relayService.removeRelay('https://example.com');
|
|
|
|
expect(queueService.deliver).toHaveBeenCalled();
|
|
expect(queueService.deliver.mock.lastCall![1]?.type).toBe('Undo');
|
|
expect(typeof queueService.deliver.mock.lastCall![1]?.object).toBe('object');
|
|
expect((queueService.deliver.mock.lastCall![1]?.object as any).type).toBe('Follow');
|
|
expect(queueService.deliver.mock.lastCall![2]).toBe('https://example.com');
|
|
//expect(queueService.deliver.mock.lastCall![0].username).toBe('relay.actor');
|
|
|
|
const list = await relayService.listRelay();
|
|
expect(list.length).toBe(0);
|
|
});
|
|
|
|
test('removeRelay: fail', async () => {
|
|
await expect(relayService.removeRelay('https://x.example.com'))
|
|
.rejects.toThrow('relay not found');
|
|
});
|
|
});
|