make sure S3 clients are properly disposed
This commit is contained in:
parent
db4661397b
commit
4d9317ad2b
4 changed files with 112 additions and 39 deletions
|
|
@ -14,28 +14,37 @@ import {
|
|||
UploadPartCommand,
|
||||
} from '@aws-sdk/client-s3';
|
||||
import { mockClient } from 'aws-sdk-client-mock';
|
||||
import { FakeInternalEventService } from '../misc/FakeInternalEventService.js';
|
||||
import type { TestingModule } from '@nestjs/testing';
|
||||
import { GlobalModule } from '@/GlobalModule.js';
|
||||
import { CoreModule } from '@/core/CoreModule.js';
|
||||
import { S3Service } from '@/core/S3Service.js';
|
||||
import { MiMeta } from '@/models/_.js';
|
||||
import type { TestingModule } from '@nestjs/testing';
|
||||
import { HttpRequestService } from '@/core/HttpRequestService.js';
|
||||
import { InternalEventService } from '@/core/InternalEventService.js';
|
||||
import { DI } from '@/di-symbols.js';
|
||||
|
||||
describe('S3Service', () => {
|
||||
let app: TestingModule;
|
||||
let s3Service: S3Service;
|
||||
let fakeMeta: MiMeta;
|
||||
const s3Mock = mockClient(S3Client);
|
||||
|
||||
beforeAll(async () => {
|
||||
app = await Test.createTestingModule({
|
||||
imports: [GlobalModule, CoreModule],
|
||||
providers: [S3Service],
|
||||
}).compile();
|
||||
})
|
||||
.overrideProvider(InternalEventService).useClass(FakeInternalEventService)
|
||||
.compile();
|
||||
app.enableShutdownHooks();
|
||||
s3Service = app.get<S3Service>(S3Service);
|
||||
});
|
||||
|
||||
beforeEach(async () => {
|
||||
s3Mock.reset();
|
||||
|
||||
fakeMeta = Object.create(app.get<MiMeta>(DI.meta));
|
||||
s3Service = new S3Service(fakeMeta, app.get(HttpRequestService), app.get(InternalEventService));
|
||||
});
|
||||
|
||||
afterAll(async () => {
|
||||
|
|
@ -45,8 +54,9 @@ describe('S3Service', () => {
|
|||
describe('upload', () => {
|
||||
test('upload a file', async () => {
|
||||
s3Mock.on(PutObjectCommand).resolves({});
|
||||
fakeMeta.objectStorageRegion = 'us-east-1';
|
||||
|
||||
await s3Service.upload({ objectStorageRegion: 'us-east-1' } as MiMeta, {
|
||||
await s3Service.upload({
|
||||
Bucket: 'fake',
|
||||
Key: 'fake',
|
||||
Body: 'x',
|
||||
|
|
@ -58,7 +68,7 @@ describe('S3Service', () => {
|
|||
s3Mock.on(UploadPartCommand).resolves({ ETag: '1' });
|
||||
s3Mock.on(CompleteMultipartUploadCommand).resolves({ Bucket: 'fake', Key: 'fake' });
|
||||
|
||||
await s3Service.upload({} as MiMeta, {
|
||||
await s3Service.upload({
|
||||
Bucket: 'fake',
|
||||
Key: 'fake',
|
||||
Body: 'x'.repeat(8 * 1024 * 1024 + 1), // デフォルトpartSizeにしている 8 * 1024 * 1024 を越えるサイズ
|
||||
|
|
@ -67,22 +77,23 @@ describe('S3Service', () => {
|
|||
|
||||
test('upload a file error', async () => {
|
||||
s3Mock.on(PutObjectCommand).rejects({ name: 'Fake Error' });
|
||||
fakeMeta.objectStorageRegion = 'us-east-1';
|
||||
|
||||
await expect(s3Service.upload({ objectStorageRegion: 'us-east-1' } as MiMeta, {
|
||||
await expect(s3Service.upload({
|
||||
Bucket: 'fake',
|
||||
Key: 'fake',
|
||||
Body: 'x',
|
||||
})).rejects.toThrowError(Error);
|
||||
})).rejects.toThrow();
|
||||
});
|
||||
|
||||
test('upload a large file error', async () => {
|
||||
s3Mock.on(UploadPartCommand).rejects();
|
||||
|
||||
await expect(s3Service.upload({} as MiMeta, {
|
||||
await expect(s3Service.upload({
|
||||
Bucket: 'fake',
|
||||
Key: 'fake',
|
||||
Body: 'x'.repeat(8 * 1024 * 1024 + 1), // デフォルトpartSizeにしている 8 * 1024 * 1024 を越えるサイズ
|
||||
})).rejects.toThrowError(Error);
|
||||
})).rejects.toThrow();
|
||||
});
|
||||
});
|
||||
});
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue