Files
FastGPT/test/mocks/common/s3.ts
T
Archer 2ccb5b50c6 V4.14.4 features (#6036)
* feat: add query optimize and bill (#6021)

* add query optimize and bill

* perf: query extension

* fix: embe model

* remove log

* remove log

* fix: test

---------

Co-authored-by: xxyyh <2289112474@qq>
Co-authored-by: archer <545436317@qq.com>

* feat: notice (#6013)

* feat: record user's language

* feat: notice points/dataset indexes; support count limit; update docker-compose.yml

* fix: ts error

* feat: send auth code i18n

* chore: dataset notice limit

* chore: adjust

* fix: ts

* fix: countLimit race condition; i18n en-prefix locale fallback to en

---------

Co-authored-by: archer <545436317@qq.com>

* perf: comment

* perf: send inform code

* fix: type error (#6029)

* feat: add ip region for chat logs (#6010)

* feat: add ip region for chat logs

* refactor: use Geolite2.mmdb

* fix: export chat logs

* fix: return location directly

* test: add unit test

* perf: log show ip data

* adjust commercial plans (#6008)

* plan frontend

* plan limit

* coupon

* discount coupon

* fix

* type

* fix audit

* type

* plan name

* legacy plan

* track

* feat: add discount coupon

* fix

* fix discount coupon

* openapi

* type

* type

* env

* api type

* fix

* fix: simple agent plugin input & agent dashboard card (#6034)

* refactor: remove gridfs (#6031)

* fix: replace gridfs multer operations with s3 compatible ops

* wip: s3 features

* refactor: remove gridfs

* fix

* perf: mock test

* doc

* doc

* doc

* fix: test

* fix: s3

* fix: mock s3

* remove invalid config

* fix: init query extension

* initv4144 (#6037)

* chore: initv4144

* fix

* version

* fix: new plans (#6039)

* fix: new plans

* qr modal tip

* fix: buffer raw text filename (#6040)

* fix: initv4144 (#6041)

* fix: pay refresh (#6042)

* fix: migration shell

* rename collection

* clear timerlock

* clear timerlock

* perf: faq

* perf: bill schema

* fix: openapi

* doc

* fix: share var render

* feat: delete dataset queue

* plan usage display (#6043)

* plan usage display

* text

* fix

* fix: ts

* perf: remove invalid code

* perf: init shell

* doc

* perf: rename field

* perf: avatar presign

* init

* custom plan text (#6045)

* fix plans

* fix

* fixed

* computed

---------

Co-authored-by: archer <545436317@qq.com>

* init shell

* plan text & price page back button (#6046)

* init

* index

* delete dataset

* delete dataset

* perf: delete dataset

* init

---------

Co-authored-by: YeYuheng <57035043+YYH211@users.noreply.github.com>
Co-authored-by: xxyyh <2289112474@qq>
Co-authored-by: Finley Ge <32237950+FinleyGe@users.noreply.github.com>
Co-authored-by: Roy <whoeverimf5@gmail.com>
Co-authored-by: heheer <heheer@sealos.io>
2025-12-08 01:44:15 +08:00

168 lines
5.6 KiB
TypeScript

import { vi } from 'vitest';
// Create mock S3 bucket object for global use
const createMockS3Bucket = () => ({
name: 'mock-bucket',
client: {},
externalClient: {},
exist: vi.fn().mockResolvedValue(true),
delete: vi.fn().mockResolvedValue(undefined),
putObject: vi.fn().mockResolvedValue(undefined),
getObject: vi.fn().mockResolvedValue(null),
statObject: vi.fn().mockResolvedValue({ size: 0, etag: 'mock-etag' }),
move: vi.fn().mockResolvedValue(undefined),
copy: vi.fn().mockResolvedValue(undefined),
addDeleteJob: vi.fn().mockResolvedValue(undefined),
createPostPresignedUrl: vi.fn().mockResolvedValue({
url: 'http://localhost:9000/mock-bucket',
fields: { key: 'mock-key' },
maxSize: 100 * 1024 * 1024
}),
createExternalUrl: vi.fn().mockResolvedValue('http://localhost:9000/mock-bucket/mock-key'),
createGetPresignedUrl: vi.fn().mockResolvedValue('http://localhost:9000/mock-bucket/mock-key'),
createPublicUrl: vi.fn((key: string) => `http://localhost:9000/mock-bucket/${key}`)
});
// Initialize global s3BucketMap early to prevent any real S3 connections
const mockBucket = createMockS3Bucket();
global.s3BucketMap = {
'fastgpt-public': mockBucket,
'fastgpt-private': mockBucket
} as any;
// Mock minio Client to prevent real connections
const createMockMinioClient = vi.hoisted(() => {
return vi.fn().mockImplementation(() => ({
bucketExists: vi.fn().mockResolvedValue(true),
makeBucket: vi.fn().mockResolvedValue(undefined),
setBucketPolicy: vi.fn().mockResolvedValue(undefined),
copyObject: vi.fn().mockResolvedValue(undefined),
removeObject: vi.fn().mockResolvedValue(undefined),
putObject: vi.fn().mockResolvedValue({ etag: 'mock-etag' }),
getObject: vi.fn().mockResolvedValue(null),
statObject: vi.fn().mockResolvedValue({ size: 0, etag: 'mock-etag' }),
presignedGetObject: vi.fn().mockResolvedValue('http://localhost:9000/mock-bucket/mock-object'),
presignedPostPolicy: vi.fn().mockResolvedValue({
postURL: 'http://localhost:9000/mock-bucket',
formData: { key: 'mock-key' }
}),
newPostPolicy: vi.fn(() => ({
setKey: vi.fn().mockReturnThis(),
setBucket: vi.fn().mockReturnThis(),
setContentType: vi.fn().mockReturnThis(),
setContentLengthRange: vi.fn().mockReturnThis(),
setExpires: vi.fn().mockReturnThis(),
setUserMetaData: vi.fn().mockReturnThis()
}))
}));
});
vi.mock('minio', () => ({
Client: createMockMinioClient(),
S3Error: class S3Error extends Error {},
CopyConditions: vi.fn()
}));
// Simplified S3 bucket class mock
const createMockBucketClass = (defaultName: string) => {
return class MockS3Bucket {
public name: string;
public options: any;
public client = {};
public externalClient = {};
constructor(bucket?: string, options?: any) {
this.name = bucket || defaultName;
this.options = options || {};
}
async exist() {
return true;
}
async delete() {}
async putObject() {}
async getObject() {
return null;
}
async statObject() {
return { size: 0, etag: 'mock-etag' };
}
async move() {}
async copy() {}
async addDeleteJob() {}
async createPostPresignedUrl(params: any, options?: any) {
return {
url: 'http://localhost:9000/mock-bucket',
fields: { key: `mock/${params.teamId || 'test'}/${params.filename}` },
maxSize: (options?.maxFileSize || 100) * 1024 * 1024
};
}
async createExternalUrl(params: any) {
return `http://localhost:9000/mock-bucket/${params.key}`;
}
async createGetPresignedUrl(params: any) {
return `http://localhost:9000/mock-bucket/${params.key}`;
}
createPublicUrl(objectKey: string) {
return `http://localhost:9000/mock-bucket/${objectKey}`;
}
};
};
vi.mock('@fastgpt/service/common/s3/buckets/base', () => ({
S3BaseBucket: createMockBucketClass('fastgpt-bucket')
}));
vi.mock('@fastgpt/service/common/s3/buckets/public', () => ({
S3PublicBucket: createMockBucketClass('fastgpt-public')
}));
vi.mock('@fastgpt/service/common/s3/buckets/private', () => ({
S3PrivateBucket: createMockBucketClass('fastgpt-private')
}));
// Mock S3 source modules
vi.mock('@fastgpt/service/common/s3/sources/avatar', () => ({
getS3AvatarSource: vi.fn(() => ({
prefix: '/avatar/',
createUploadAvatarURL: vi.fn().mockResolvedValue({
url: 'http://localhost:9000/mock-bucket',
fields: { key: 'mock-key' },
maxSize: 5 * 1024 * 1024
}),
createPublicUrl: vi.fn((key: string) => `http://localhost:9000/mock-bucket/${key}`),
removeAvatarTTL: vi.fn().mockResolvedValue(undefined),
deleteAvatar: vi.fn().mockResolvedValue(undefined),
refreshAvatar: vi.fn().mockResolvedValue(undefined),
copyAvatar: vi.fn().mockResolvedValue('http://localhost:9000/mock-bucket/mock-avatar')
}))
}));
vi.mock('@fastgpt/service/common/s3/sources/dataset/index', () => ({
getS3DatasetSource: vi.fn(() => ({
createUploadDatasetFileURL: vi.fn().mockResolvedValue({
url: 'http://localhost:9000/mock-bucket',
fields: { key: 'mock-key' },
maxSize: 500 * 1024 * 1024
}),
deleteDatasetFile: vi.fn().mockResolvedValue(undefined)
})),
S3DatasetSource: vi.fn()
}));
vi.mock('@fastgpt/service/common/s3/sources/chat/index', () => ({
S3ChatSource: vi.fn()
}));
// Mock S3 initialization
vi.mock('@fastgpt/service/common/s3', () => ({
initS3Buckets: vi.fn(() => {
const mockBucket = createMockS3Bucket();
global.s3BucketMap = {
'fastgpt-public': mockBucket,
'fastgpt-private': mockBucket
} as any;
}),
initS3MQWorker: vi.fn().mockResolvedValue(undefined)
}));