mirror of
https://github.com/misskey-dev/misskey.git
synced 2026-05-04 08:26:19 +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
61 lines
1.4 KiB
TypeScript
61 lines
1.4 KiB
TypeScript
/*
|
|
* SPDX-FileCopyrightText: syuilo and misskey-project
|
|
* SPDX-License-Identifier: AGPL-3.0-only
|
|
*/
|
|
|
|
process.env.NODE_ENV = 'test';
|
|
|
|
import { afterAll, beforeAll, describe, test, expect, vi } from 'vitest';
|
|
import { Test } from '@nestjs/testing';
|
|
import { GlobalModule } from '@/GlobalModule.js';
|
|
import { DI } from '@/di-symbols.js';
|
|
import { MetaService } from '@/core/MetaService.js';
|
|
import { CoreModule } from '@/core/CoreModule.js';
|
|
import type { TestingModule } from '@nestjs/testing';
|
|
import type { DataSource } from 'typeorm';
|
|
|
|
describe('MetaService', () => {
|
|
let app: TestingModule;
|
|
let metaService: MetaService;
|
|
|
|
beforeAll(async () => {
|
|
app = await Test.createTestingModule({
|
|
imports: [
|
|
GlobalModule,
|
|
CoreModule,
|
|
],
|
|
}).compile();
|
|
|
|
app.enableShutdownHooks();
|
|
|
|
metaService = app.get<MetaService>(MetaService, { strict: false });
|
|
|
|
// Make it cached
|
|
await metaService.fetch();
|
|
});
|
|
|
|
afterAll(async () => {
|
|
await app.close();
|
|
});
|
|
|
|
test('fetch (cache)', async () => {
|
|
const db = app.get<DataSource>(DI.db);
|
|
const spy = vi.spyOn(db, 'transaction');
|
|
|
|
const result = await metaService.fetch();
|
|
|
|
expect(result.id).toBe('x');
|
|
expect(spy).toHaveBeenCalledTimes(0);
|
|
});
|
|
|
|
test('fetch (force)', async () => {
|
|
const db = app.get<DataSource>(DI.db);
|
|
const spy = vi.spyOn(db, 'transaction');
|
|
|
|
const result = await metaService.fetch(true);
|
|
|
|
expect(result.id).toBe('x');
|
|
expect(spy).toHaveBeenCalledTimes(1);
|
|
});
|
|
});
|