summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorsyuilo <Syuilotan@yahoo.co.jp>2022-09-21 04:58:32 +0900
committersyuilo <Syuilotan@yahoo.co.jp>2022-09-21 04:58:32 +0900
commit18fe773923e164bab81c7dd4bbdf254a0b3a3ce7 (patch)
tree90e98fb8e3db85f25465d875dd0cd4b51da9004e
parenttest (diff)
downloadsharkey-18fe773923e164bab81c7dd4bbdf254a0b3a3ce7.tar.gz
sharkey-18fe773923e164bab81c7dd4bbdf254a0b3a3ce7.tar.bz2
sharkey-18fe773923e164bab81c7dd4bbdf254a0b3a3ce7.zip
add test for metaService
-rw-r--r--packages/backend/test/unit/MetaService.ts68
1 files changed, 68 insertions, 0 deletions
diff --git a/packages/backend/test/unit/MetaService.ts b/packages/backend/test/unit/MetaService.ts
new file mode 100644
index 0000000000..c1baefd460
--- /dev/null
+++ b/packages/backend/test/unit/MetaService.ts
@@ -0,0 +1,68 @@
+process.env.NODE_ENV = 'test';
+
+import { jest } from '@jest/globals';
+import { ModuleMocker } from 'jest-mock';
+import { Test } from '@nestjs/testing';
+import { GlobalModule } from '@/GlobalModule.js';
+import type { MetasRepository } from '@/models/index.js';
+import { DI } from '@/di-symbols.js';
+import { MetaService } from '@/core/MetaService.js';
+import { CoreModule } from '@/core/CoreModule.js';
+import type { DataSource } from 'typeorm';
+import type { TestingModule } from '@nestjs/testing';
+import type { MockFunctionMetadata } from 'jest-mock';
+
+const moduleMocker = new ModuleMocker(global);
+
+describe('MetaService', () => {
+ let app: TestingModule;
+ let metaService: MetaService;
+ let metasRepository: MetasRepository;
+
+ beforeAll(async () => {
+ app = await Test.createTestingModule({
+ imports: [
+ GlobalModule,
+ CoreModule,
+ ],
+ }).compile();
+
+ app.enableShutdownHooks();
+
+ metaService = app.get<MetaService>(MetaService, { strict: false });
+ metasRepository = app.get<MetasRepository>(DI.metasRepository, { strict: false });
+ });
+
+ afterAll(async () => {
+ await app.close();
+ });
+
+ it('fetch (cache)', async () => {
+ const db = app.get<DataSource>(DI.db);
+ const originalFunction = db.transaction;
+ const spy = jest.spyOn(db, 'transaction');
+ spy.mockImplementation((...args) => originalFunction(...args));
+
+ const result = await metaService.fetch();
+
+ expect(result.id).toBe('x');
+ expect(spy).toHaveBeenCalledTimes(0);
+
+ spy.mockRestore();
+ });
+/*
+ it('fetch (force)', async () => {
+ const db = app.get<DataSource>(DI.db);
+ const originalFunction = db.transaction;
+ const spy = jest.spyOn(db, 'transaction');
+ // 何故かここで無限再帰する db.transaction がspyのままになっている?
+ spy.mockImplementation((...args) => originalFunction(...args));
+
+ const result = await metaService.fetch(true);
+
+ expect(result.id).toBe('x');
+ expect(spy).toHaveBeenCalledTimes(1);
+
+ spy.mockRestore();
+ });*/
+});