mirror of
https://github.com/misskey-dev/misskey.git
synced 2026-05-04 13:05:57 +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
69 lines
1.9 KiB
TypeScript
69 lines
1.9 KiB
TypeScript
/*
|
|
* SPDX-FileCopyrightText: syuilo and misskey-project
|
|
* SPDX-License-Identifier: AGPL-3.0-only
|
|
*/
|
|
|
|
process.env.NODE_ENV = 'test';
|
|
|
|
import { afterAll, beforeAll, beforeEach, describe, test, expect } from 'vitest';
|
|
import { Test } from '@nestjs/testing';
|
|
import {
|
|
DeleteObjectCommand,
|
|
DeleteObjectCommandOutput,
|
|
InvalidObjectState,
|
|
NoSuchKey,
|
|
S3Client,
|
|
} from '@aws-sdk/client-s3';
|
|
import { mockClient } from 'aws-sdk-client-mock';
|
|
import { GlobalModule } from '@/GlobalModule.js';
|
|
import { DriveService } from '@/core/DriveService.js';
|
|
import { CoreModule } from '@/core/CoreModule.js';
|
|
import type { TestingModule } from '@nestjs/testing';
|
|
|
|
describe('DriveService', () => {
|
|
let app: TestingModule;
|
|
let driveService: DriveService;
|
|
const s3Mock = mockClient(S3Client);
|
|
|
|
beforeAll(async () => {
|
|
app = await Test.createTestingModule({
|
|
imports: [GlobalModule, CoreModule],
|
|
providers: [DriveService],
|
|
}).compile();
|
|
app.enableShutdownHooks();
|
|
driveService = app.get<DriveService>(DriveService);
|
|
});
|
|
|
|
beforeEach(async () => {
|
|
s3Mock.reset();
|
|
});
|
|
|
|
afterAll(async () => {
|
|
await app.close();
|
|
});
|
|
|
|
describe('Object storage', () => {
|
|
test('delete a file', async () => {
|
|
s3Mock.on(DeleteObjectCommand)
|
|
.resolves({} as DeleteObjectCommandOutput);
|
|
|
|
await driveService.deleteObjectStorageFile('peace of the world');
|
|
});
|
|
|
|
test('delete a file then unexpected error', async () => {
|
|
s3Mock.on(DeleteObjectCommand)
|
|
.rejects(new InvalidObjectState({ $metadata: {}, message: '' }));
|
|
|
|
await expect(driveService.deleteObjectStorageFile('unexpected')).rejects.toThrow(Error);
|
|
});
|
|
|
|
test('delete a file with no valid key', async () => {
|
|
// Some S3 implementations returns 404 Not Found on deleting with a non-existent key
|
|
s3Mock.on(DeleteObjectCommand)
|
|
.rejects(new NoSuchKey({ $metadata: {}, message: 'allowed error.' }));
|
|
|
|
await driveService.deleteObjectStorageFile('lol no way');
|
|
});
|
|
});
|
|
});
|