feat: manually mirror opencoze's code from bytedance
Change-Id: I09a73aadda978ad9511264a756b2ce51f5761adf
This commit is contained in:
@@ -0,0 +1,184 @@
|
||||
/*
|
||||
* Copyright 2025 coze-dev Authors
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
import '@testing-library/jest-dom';
|
||||
|
||||
import React from 'react';
|
||||
|
||||
import { describe, it, expect, vi } from 'vitest';
|
||||
import { type BackgroundImageInfo } from '@coze-arch/bot-api/developer_api';
|
||||
|
||||
import {
|
||||
computePosition,
|
||||
getInitBackground,
|
||||
getOriginImageFromBackgroundInfo,
|
||||
} from '../src/utils';
|
||||
|
||||
vi.mock('@coze-arch/bot-semi', () => ({
|
||||
UIToast: {
|
||||
error: vi.fn(),
|
||||
},
|
||||
}));
|
||||
|
||||
vi.mock('@coze-common/chat-uikit', () => ({
|
||||
MODE_CONFIG: {
|
||||
pc: {
|
||||
size: {
|
||||
width: 486,
|
||||
height: 346,
|
||||
},
|
||||
centerWidth: 346,
|
||||
},
|
||||
mobile: {
|
||||
size: {
|
||||
width: 248,
|
||||
height: 346,
|
||||
},
|
||||
centerWidth: 206,
|
||||
},
|
||||
},
|
||||
}));
|
||||
|
||||
vi.mock('@coze-arch/coze-design', () => ({
|
||||
Avatar: vi.fn(),
|
||||
Tag: vi.fn(),
|
||||
}));
|
||||
vi.mock('@coze-arch/bot-error', () => ({
|
||||
CustomError: vi.fn(() => Error),
|
||||
}));
|
||||
|
||||
vi.mock('@coze-arch/bot-error', () => ({
|
||||
CustomError: vi.fn(() => Error),
|
||||
}));
|
||||
|
||||
describe('should compute position correctly', () => {
|
||||
const cropperRef = React.createRef();
|
||||
const cropperMock = {
|
||||
getCanvasData: vi.fn(() => ({
|
||||
left: 10,
|
||||
})),
|
||||
getImageData: vi.fn(() => ({
|
||||
left: 5,
|
||||
width: 20,
|
||||
})),
|
||||
};
|
||||
// 使用 vi.spyOn 模拟 createRef 的行为
|
||||
const createRefSpy = vi.spyOn(React, 'createRef').mockReturnValue(cropperRef);
|
||||
// 手动设置 cropperRef.current 的值
|
||||
cropperRef.current = {
|
||||
cropper: cropperMock,
|
||||
};
|
||||
cropperRef.current = {
|
||||
cropper: {
|
||||
getCanvasData: vi.fn(() => ({
|
||||
left: 10,
|
||||
})),
|
||||
getImageData: vi.fn(() => ({
|
||||
left: 5,
|
||||
width: 20,
|
||||
})),
|
||||
},
|
||||
};
|
||||
|
||||
const mode = 'pc';
|
||||
const result = computePosition(mode, cropperRef);
|
||||
expect(result.left).toBe(0.03);
|
||||
expect(result.right).toBe(0.92);
|
||||
// 恢复 createRef 的原始行为
|
||||
createRefSpy.mockRestore();
|
||||
});
|
||||
|
||||
describe('getOriginImageFromBackgroundInfo', () => {
|
||||
it('should return origin image info', () => {
|
||||
const value: BackgroundImageInfo[] = [
|
||||
{
|
||||
web_background_image: {
|
||||
origin_image_uri: '123',
|
||||
origin_image_url: '234',
|
||||
},
|
||||
},
|
||||
];
|
||||
const info = getOriginImageFromBackgroundInfo(value);
|
||||
expect(info).toMatchObject({
|
||||
uri: '123',
|
||||
url: '234',
|
||||
});
|
||||
});
|
||||
});
|
||||
|
||||
describe('getInitBackground', () => {
|
||||
it('should return origin image', () => {
|
||||
const value: BackgroundImageInfo[] = [
|
||||
{
|
||||
web_background_image: {
|
||||
origin_image_uri: '123',
|
||||
origin_image_url: '234',
|
||||
},
|
||||
},
|
||||
];
|
||||
const info = getInitBackground({
|
||||
isGenerateSuccess: false,
|
||||
originBackground: value,
|
||||
selectedImageInfo: {
|
||||
tar_uri: '222',
|
||||
tar_url: '111',
|
||||
},
|
||||
});
|
||||
expect(info).toMatchObject({
|
||||
uri: '123',
|
||||
url: '234',
|
||||
});
|
||||
});
|
||||
|
||||
it('should return selected image', () => {
|
||||
const value: BackgroundImageInfo[] = [
|
||||
{
|
||||
web_background_image: {
|
||||
origin_image_uri: '123',
|
||||
origin_image_url: '234',
|
||||
},
|
||||
},
|
||||
];
|
||||
const info = getInitBackground({
|
||||
isGenerateSuccess: true,
|
||||
originBackground: value,
|
||||
selectedImageInfo: {
|
||||
tar_uri: '222',
|
||||
tar_url: '111',
|
||||
},
|
||||
});
|
||||
expect(info).toMatchObject({
|
||||
url: '111',
|
||||
});
|
||||
});
|
||||
|
||||
it('should return empty image', () => {
|
||||
const value: BackgroundImageInfo[] = [
|
||||
{
|
||||
web_background_image: {},
|
||||
},
|
||||
];
|
||||
const info = getInitBackground({
|
||||
isGenerateSuccess: false,
|
||||
originBackground: value,
|
||||
selectedImageInfo: {
|
||||
tar_uri: '222',
|
||||
tar_url: '111',
|
||||
},
|
||||
});
|
||||
expect(info).toMatchObject({});
|
||||
});
|
||||
});
|
||||
Reference in New Issue
Block a user