test(backend): kill many any in backend test (partial) (#14054)
				
					
				
			* kill any on utils:api * kill any on timeline test * use optional chain to kill TS2532 on timeline test 変更前: 該当ノートが見つからなければundefinedに対するプロパティアクセスとしてテストがクラッシュ 変更後: 該当ノートが見つからなければoptional chainがundefinedとして評価されるが、strictEqualの右辺がnon-nullableなためアサーションに失敗しテストがクラッシュ * kill `as any` for ApMfmService * kill argument any for api-visibility * kill argument any across a few tests * do not return value that has yielded from `await`-ing `Promise<void>` * force cast * runtime non-null assertion to coerce * rewrite `assert.notEqual(expr, null)` to `assert.ok(expr)` こうすることでassertion type扱いになり、non-nullableになる * change return type of `failedApiCall` to `void` 戻り値がどこにも使われていない * split bindings for exports.ts 型が合わなくて文句を言ってくるので適切に分割 * runtime non-null assertion * runtime non-null assertion * 何故かうまく行かないので、とりあえずXORしてみる * Revert "何故かうまく行かないので、とりあえずXORしてみる" This reverts commit48cf32c930. * castAsErrorで安全ではないキャストを隠蔽 * 型アサーションの追加 * 型アサーションの追加 * 型アサーションの追加 * voidで値を返さない * castAsError * assert.ok => kill nullability * もはや明示的な型の指定は必要ない * castAsError * castAsError * 型アサーションの追加 * nullableを一旦抑止 * 変数を分離して型エラーを排除 * 不要なプロパティを削除する処理を隠蔽してanyを排除 * Repository type * simple type * assert.ok => kill nullability * revert `as any` drop revertsfe95c05b3fpartialy * test: fix invalid assertion partially revertb99b7b5392* test:52d8a54fc7により型が合うようになった部分の`as any`を除去 * format * test: apply https://github.com/misskey-dev/misskey/pull/14054#discussion_r1672369526 (part 1) * test: use non-null assertion to suppress too many error * Update packages/backend/test/utils.ts Co-authored-by: anatawa12 <anatawa12@icloud.com> --------- Co-authored-by: anatawa12 <anatawa12@icloud.com>
This commit is contained in:
		| @@ -23,10 +23,10 @@ describe('ApMfmService', () => { | ||||
|  | ||||
| 	describe('getNoteHtml', () => { | ||||
| 		test('Do not provide _misskey_content for simple text', () => { | ||||
| 			const note: MiNote = { | ||||
| 			const note = { | ||||
| 				text: 'テキスト #タグ @mention 🍊 :emoji: https://example.com', | ||||
| 				mentionedRemoteUsers: '[]', | ||||
| 			} as any; | ||||
| 			}; | ||||
|  | ||||
| 			const { content, noMisskeyContent } = apMfmService.getNoteHtml(note); | ||||
|  | ||||
| @@ -35,10 +35,10 @@ describe('ApMfmService', () => { | ||||
| 		}); | ||||
|  | ||||
| 		test('Provide _misskey_content for MFM', () => { | ||||
| 			const note: MiNote = { | ||||
| 			const note = { | ||||
| 				text: '$[tada foo]', | ||||
| 				mentionedRemoteUsers: '[]', | ||||
| 			} as any; | ||||
| 			}; | ||||
|  | ||||
| 			const { content, noMisskeyContent } = apMfmService.getNoteHtml(note); | ||||
|  | ||||
|   | ||||
| @@ -12,7 +12,7 @@ import { ModuleMocker } from 'jest-mock'; | ||||
| import { Test } from '@nestjs/testing'; | ||||
| import { afterAll, beforeAll, describe, test } from '@jest/globals'; | ||||
| import { GlobalModule } from '@/GlobalModule.js'; | ||||
| import { FileInfoService } from '@/core/FileInfoService.js'; | ||||
| import { FileInfo, FileInfoService } from '@/core/FileInfoService.js'; | ||||
| //import { DI } from '@/di-symbols.js'; | ||||
| import { AiService } from '@/core/AiService.js'; | ||||
| import { LoggerService } from '@/core/LoggerService.js'; | ||||
| @@ -28,6 +28,15 @@ const moduleMocker = new ModuleMocker(global); | ||||
| describe('FileInfoService', () => { | ||||
| 	let app: TestingModule; | ||||
| 	let fileInfoService: FileInfoService; | ||||
| 	const strip = (fileInfo: FileInfo): Omit<Partial<FileInfo>, 'warnings' | 'blurhash' | 'sensitive' | 'porn'> => { | ||||
| 		const fi: Partial<FileInfo> = fileInfo; | ||||
| 		delete fi.warnings; | ||||
| 		delete fi.sensitive; | ||||
| 		delete fi.blurhash; | ||||
| 		delete fi.porn; | ||||
| 		 | ||||
| 		return fi; | ||||
| 	} | ||||
|  | ||||
| 	beforeAll(async () => { | ||||
| 		app = await Test.createTestingModule({ | ||||
| @@ -63,11 +72,7 @@ describe('FileInfoService', () => { | ||||
|  | ||||
| 	test('Empty file', async () => { | ||||
| 		const path = `${resources}/emptyfile`; | ||||
| 		const info = await fileInfoService.getFileInfo(path, { skipSensitiveDetection: true }) as any; | ||||
| 		delete info.warnings; | ||||
| 		delete info.blurhash; | ||||
| 		delete info.sensitive; | ||||
| 		delete info.porn; | ||||
| 		const info = strip(await fileInfoService.getFileInfo(path, { skipSensitiveDetection: true })); | ||||
| 		assert.deepStrictEqual(info, { | ||||
| 			size: 0, | ||||
| 			md5: 'd41d8cd98f00b204e9800998ecf8427e', | ||||
| @@ -84,11 +89,7 @@ describe('FileInfoService', () => { | ||||
| 	describe('IMAGE', () => { | ||||
| 		test('Generic JPEG', async () => { | ||||
| 			const path = `${resources}/192.jpg`; | ||||
| 			const info = await fileInfoService.getFileInfo(path, { skipSensitiveDetection: true }) as any; | ||||
| 			delete info.warnings; | ||||
| 			delete info.blurhash; | ||||
| 			delete info.sensitive; | ||||
| 			delete info.porn; | ||||
| 			const info = strip(await fileInfoService.getFileInfo(path, { skipSensitiveDetection: true })); | ||||
| 			assert.deepStrictEqual(info, { | ||||
| 				size: 5131, | ||||
| 				md5: '8c9ed0677dd2b8f9f7472c3af247e5e3', | ||||
| @@ -104,11 +105,7 @@ describe('FileInfoService', () => { | ||||
|  | ||||
| 		test('Generic APNG', async () => { | ||||
| 			const path = `${resources}/anime.png`; | ||||
| 			const info = await fileInfoService.getFileInfo(path, { skipSensitiveDetection: true }) as any; | ||||
| 			delete info.warnings; | ||||
| 			delete info.blurhash; | ||||
| 			delete info.sensitive; | ||||
| 			delete info.porn; | ||||
| 			const info = strip(await fileInfoService.getFileInfo(path, { skipSensitiveDetection: true })); | ||||
| 			assert.deepStrictEqual(info, { | ||||
| 				size: 1868, | ||||
| 				md5: '08189c607bea3b952704676bb3c979e0', | ||||
| @@ -124,11 +121,7 @@ describe('FileInfoService', () => { | ||||
|  | ||||
| 		test('Generic AGIF', async () => { | ||||
| 			const path = `${resources}/anime.gif`; | ||||
| 			const info = await fileInfoService.getFileInfo(path, { skipSensitiveDetection: true }) as any; | ||||
| 			delete info.warnings; | ||||
| 			delete info.blurhash; | ||||
| 			delete info.sensitive; | ||||
| 			delete info.porn; | ||||
| 			const info = strip(await fileInfoService.getFileInfo(path, { skipSensitiveDetection: true })); | ||||
| 			assert.deepStrictEqual(info, { | ||||
| 				size: 2248, | ||||
| 				md5: '32c47a11555675d9267aee1a86571e7e', | ||||
| @@ -144,11 +137,7 @@ describe('FileInfoService', () => { | ||||
|  | ||||
| 		test('PNG with alpha', async () => { | ||||
| 			const path = `${resources}/with-alpha.png`; | ||||
| 			const info = await fileInfoService.getFileInfo(path, { skipSensitiveDetection: true }) as any; | ||||
| 			delete info.warnings; | ||||
| 			delete info.blurhash; | ||||
| 			delete info.sensitive; | ||||
| 			delete info.porn; | ||||
| 			const info = strip(await fileInfoService.getFileInfo(path, { skipSensitiveDetection: true })); | ||||
| 			assert.deepStrictEqual(info, { | ||||
| 				size: 3772, | ||||
| 				md5: 'f73535c3e1e27508885b69b10cf6e991', | ||||
| @@ -164,11 +153,7 @@ describe('FileInfoService', () => { | ||||
|  | ||||
| 		test('Generic SVG', async () => { | ||||
| 			const path = `${resources}/image.svg`; | ||||
| 			const info = await fileInfoService.getFileInfo(path, { skipSensitiveDetection: true }) as any; | ||||
| 			delete info.warnings; | ||||
| 			delete info.blurhash; | ||||
| 			delete info.sensitive; | ||||
| 			delete info.porn; | ||||
| 			const info = strip(await fileInfoService.getFileInfo(path, { skipSensitiveDetection: true })); | ||||
| 			assert.deepStrictEqual(info, { | ||||
| 				size: 505, | ||||
| 				md5: 'b6f52b4b021e7b92cdd04509c7267965', | ||||
| @@ -185,11 +170,7 @@ describe('FileInfoService', () => { | ||||
| 		test('SVG with XML definition', async () => { | ||||
| 			// https://github.com/misskey-dev/misskey/issues/4413 | ||||
| 			const path = `${resources}/with-xml-def.svg`; | ||||
| 			const info = await fileInfoService.getFileInfo(path, { skipSensitiveDetection: true }) as any; | ||||
| 			delete info.warnings; | ||||
| 			delete info.blurhash; | ||||
| 			delete info.sensitive; | ||||
| 			delete info.porn; | ||||
| 			const info = strip(await fileInfoService.getFileInfo(path, { skipSensitiveDetection: true })); | ||||
| 			assert.deepStrictEqual(info, { | ||||
| 				size: 544, | ||||
| 				md5: '4b7a346cde9ccbeb267e812567e33397', | ||||
| @@ -205,11 +186,7 @@ describe('FileInfoService', () => { | ||||
|  | ||||
| 		test('Dimension limit', async () => { | ||||
| 			const path = `${resources}/25000x25000.png`; | ||||
| 			const info = await fileInfoService.getFileInfo(path, { skipSensitiveDetection: true }) as any; | ||||
| 			delete info.warnings; | ||||
| 			delete info.blurhash; | ||||
| 			delete info.sensitive; | ||||
| 			delete info.porn; | ||||
| 			const info = strip(await fileInfoService.getFileInfo(path, { skipSensitiveDetection: true })); | ||||
| 			assert.deepStrictEqual(info, { | ||||
| 				size: 75933, | ||||
| 				md5: '268c5dde99e17cf8fe09f1ab3f97df56', | ||||
| @@ -225,11 +202,7 @@ describe('FileInfoService', () => { | ||||
|  | ||||
| 		test('Rotate JPEG', async () => { | ||||
| 			const path = `${resources}/rotate.jpg`; | ||||
| 			const info = await fileInfoService.getFileInfo(path, { skipSensitiveDetection: true }) as any; | ||||
| 			delete info.warnings; | ||||
| 			delete info.blurhash; | ||||
| 			delete info.sensitive; | ||||
| 			delete info.porn; | ||||
| 			const info = strip(await fileInfoService.getFileInfo(path, { skipSensitiveDetection: true })); | ||||
| 			assert.deepStrictEqual(info, { | ||||
| 				size: 12624, | ||||
| 				md5: '68d5b2d8d1d1acbbce99203e3ec3857e', | ||||
| @@ -247,11 +220,7 @@ describe('FileInfoService', () => { | ||||
| 	describe('AUDIO', () => { | ||||
| 		test('MP3', async () => { | ||||
| 			const path = `${resources}/kick_gaba7.mp3`; | ||||
| 			const info = await fileInfoService.getFileInfo(path, { skipSensitiveDetection: true }) as any; | ||||
| 			delete info.warnings; | ||||
| 			delete info.blurhash; | ||||
| 			delete info.sensitive; | ||||
| 			delete info.porn; | ||||
| 			const info = strip(await fileInfoService.getFileInfo(path, { skipSensitiveDetection: true })); | ||||
| 			delete info.width; | ||||
| 			delete info.height; | ||||
| 			delete info.orientation; | ||||
| @@ -267,11 +236,7 @@ describe('FileInfoService', () => { | ||||
|  | ||||
| 		test('WAV', async () => { | ||||
| 			const path = `${resources}/kick_gaba7.wav`; | ||||
| 			const info = await fileInfoService.getFileInfo(path, { skipSensitiveDetection: true }) as any; | ||||
| 			delete info.warnings; | ||||
| 			delete info.blurhash; | ||||
| 			delete info.sensitive; | ||||
| 			delete info.porn; | ||||
| 			const info = strip(await fileInfoService.getFileInfo(path, { skipSensitiveDetection: true })); | ||||
| 			delete info.width; | ||||
| 			delete info.height; | ||||
| 			delete info.orientation; | ||||
| @@ -287,11 +252,7 @@ describe('FileInfoService', () => { | ||||
|  | ||||
| 		test('AAC', async () => { | ||||
| 			const path = `${resources}/kick_gaba7.aac`; | ||||
| 			const info = await fileInfoService.getFileInfo(path, { skipSensitiveDetection: true }) as any; | ||||
| 			delete info.warnings; | ||||
| 			delete info.blurhash; | ||||
| 			delete info.sensitive; | ||||
| 			delete info.porn; | ||||
| 			const info = strip(await fileInfoService.getFileInfo(path, { skipSensitiveDetection: true })); | ||||
| 			delete info.width; | ||||
| 			delete info.height; | ||||
| 			delete info.orientation; | ||||
| @@ -307,11 +268,7 @@ describe('FileInfoService', () => { | ||||
|  | ||||
| 		test('FLAC', async () => { | ||||
| 			const path = `${resources}/kick_gaba7.flac`; | ||||
| 			const info = await fileInfoService.getFileInfo(path, { skipSensitiveDetection: true }) as any; | ||||
| 			delete info.warnings; | ||||
| 			delete info.blurhash; | ||||
| 			delete info.sensitive; | ||||
| 			delete info.porn; | ||||
| 			const info = strip(await fileInfoService.getFileInfo(path, { skipSensitiveDetection: true })); | ||||
| 			delete info.width; | ||||
| 			delete info.height; | ||||
| 			delete info.orientation; | ||||
| @@ -327,11 +284,7 @@ describe('FileInfoService', () => { | ||||
|  | ||||
| 		test('MPEG-4 AUDIO (M4A)', async () => { | ||||
| 			const path = `${resources}/kick_gaba7.m4a`; | ||||
| 			const info = await fileInfoService.getFileInfo(path, { skipSensitiveDetection: true }) as any; | ||||
| 			delete info.warnings; | ||||
| 			delete info.blurhash; | ||||
| 			delete info.sensitive; | ||||
| 			delete info.porn; | ||||
| 			const info = strip(await fileInfoService.getFileInfo(path, { skipSensitiveDetection: true })); | ||||
| 			delete info.width; | ||||
| 			delete info.height; | ||||
| 			delete info.orientation; | ||||
| @@ -347,11 +300,7 @@ describe('FileInfoService', () => { | ||||
|  | ||||
| 		test('WEBM AUDIO', async () => { | ||||
| 			const path = `${resources}/kick_gaba7.webm`; | ||||
| 			const info = await fileInfoService.getFileInfo(path, { skipSensitiveDetection: true }) as any; | ||||
| 			delete info.warnings; | ||||
| 			delete info.blurhash; | ||||
| 			delete info.sensitive; | ||||
| 			delete info.porn; | ||||
| 			const info = strip(await fileInfoService.getFileInfo(path, { skipSensitiveDetection: true })); | ||||
| 			delete info.width; | ||||
| 			delete info.height; | ||||
| 			delete info.orientation; | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Kisaragi
					Kisaragi