Files
prompt-optimizer/packages/ui/tests/unit/components/ImageTokenUsage.spec.ts
linshen c75afa89e9 feat(i18n): establish english-first locale baseline
- split UI locale packs into en-US, zh-CN, and zh-TW modules
- switch runtime defaults, docs, and repository guidance toward an English-first baseline
- update core, MCP, and UI runtime copy to remove hardcoded Chinese fallbacks
- add locale parity and no-hardcoded-runtime guardrails across the repo
2026-04-08 20:18:27 +08:00

60 lines
1.6 KiB
TypeScript

import { describe, expect, it } from 'vitest'
import { mount } from '@vue/test-utils'
import ImageTokenUsage from '../../../src/components/image-mode/ImageTokenUsage.vue'
describe('ImageTokenUsage', () => {
it('keeps single-image input usage rendering intact', () => {
const wrapper = mount(ImageTokenUsage, {
props: {
inputImageInfo: {
width: 1024,
height: 768,
mimeType: 'image/jpeg',
},
metadata: {
usage: {
promptTokenCount: 123,
totalTokenCount: 456,
},
},
},
})
const text = wrapper.text()
expect(text).toContain('Image (JPEG): 1024x768px')
expect(text).toContain('Prompt tokens: 123')
expect(text).toContain('All tokens: 456')
})
it('renders ordered multi-image input usage without collapsing it into one fake input image', () => {
const wrapper = mount(ImageTokenUsage, {
props: {
inputImagesInfo: [
{
width: 1024,
height: 1024,
mimeType: 'image/jpeg',
},
{
width: 768,
height: 1344,
mimeType: 'image/png',
},
],
metadata: {
usage: {
promptTokenCount: 321,
},
},
},
})
const text = wrapper.text()
expect(text).toContain('Image 1 (JPEG): 1024x1024px')
expect(text).toContain('Image 2 (PNG): 768x1344px')
expect(text).toContain('Prompt tokens: 321')
expect(text).not.toContain('Image (JPEG): 1024x1024px')
})
})