mirror of
https://github.com/langgenius/dify.git
synced 2026-06-17 06:21:07 +08:00
Signed-off-by: dependabot[bot] <support@github.com> Co-authored-by: yyh <yuanyouhuilyz@gmail.com> Co-authored-by: Joel <iamjoel007@gmail.com> Co-authored-by: hjlarry <hjlarry@163.com> Co-authored-by: fatelei <fatelei@gmail.com> Co-authored-by: Asuka Minato <i@asukaminato.eu.org> Co-authored-by: autofix-ci[bot] <114827586+autofix-ci[bot]@users.noreply.github.com> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Xiyuan Chen <52963600+GareArc@users.noreply.github.com> Co-authored-by: gigglewang <gigglewang@dify.ai> Co-authored-by: Yunlu Wen <yunlu.wen@dify.ai> Co-authored-by: chariri <w@chariri.moe> Co-authored-by: Evan <2869018789@qq.com> Co-authored-by: yyh <92089059+lyzno1@users.noreply.github.com>
131 lines
3.4 KiB
TypeScript
131 lines
3.4 KiB
TypeScript
import { fireEvent, render, screen } from '@testing-library/react'
|
|
import { beforeEach, describe, expect, it, vi } from 'vitest'
|
|
import PluginVersionPicker from '../plugin-version-picker'
|
|
|
|
type VersionItem = {
|
|
version: string
|
|
unique_identifier: string
|
|
created_at: string
|
|
}
|
|
|
|
const mockVersionList = vi.hoisted(() => ({
|
|
data: {
|
|
versions: [] as VersionItem[],
|
|
},
|
|
}))
|
|
|
|
vi.mock('@/hooks/use-timestamp', () => ({
|
|
default: () => ({
|
|
formatDate: (value: string, format: string) => `${value}:${format}`,
|
|
}),
|
|
}))
|
|
|
|
vi.mock('@/service/use-plugins', () => ({
|
|
useVersionListOfPlugin: () => ({
|
|
data: mockVersionList,
|
|
}),
|
|
}))
|
|
|
|
describe('PluginVersionPicker', () => {
|
|
beforeEach(() => {
|
|
vi.clearAllMocks()
|
|
mockVersionList.data.versions = [
|
|
{
|
|
version: '2.0.0',
|
|
unique_identifier: 'uid-current',
|
|
created_at: '2024-01-02',
|
|
},
|
|
{
|
|
version: '1.0.0',
|
|
unique_identifier: 'uid-old',
|
|
created_at: '2023-12-01',
|
|
},
|
|
]
|
|
})
|
|
|
|
it('renders version options and highlights the current version', () => {
|
|
render(
|
|
<PluginVersionPicker
|
|
isShow
|
|
onShowChange={vi.fn()}
|
|
pluginID="plugin-1"
|
|
currentVersion="2.0.0"
|
|
trigger={<span>trigger</span>}
|
|
onSelect={vi.fn()}
|
|
/>,
|
|
)
|
|
|
|
expect(screen.getByText('plugin.detailPanel.switchVersion')).toBeInTheDocument()
|
|
expect(screen.getByText('2.0.0')).toBeInTheDocument()
|
|
expect(screen.getByText('2024-01-02:appLog.dateTimeFormat')).toBeInTheDocument()
|
|
expect(screen.getByText('CURRENT')).toBeInTheDocument()
|
|
})
|
|
|
|
it('renders figma-aligned version rows', () => {
|
|
render(
|
|
<PluginVersionPicker
|
|
isShow
|
|
onShowChange={vi.fn()}
|
|
pluginID="plugin-1"
|
|
currentVersion="2.0.0"
|
|
trigger={<span>trigger</span>}
|
|
onSelect={vi.fn()}
|
|
/>,
|
|
)
|
|
|
|
const currentVersion = screen.getByText('2.0.0')
|
|
const currentBadge = screen.getByText('CURRENT')
|
|
const oldVersion = screen.getByText('1.0.0')
|
|
|
|
expect(screen.getByText('plugin.detailPanel.switchVersion')).toHaveClass('px-3', 'pb-0.5', 'pt-1')
|
|
expect(currentVersion.closest('.cursor-default')).toHaveClass('px-2', 'py-1', 'opacity-30')
|
|
expect(oldVersion.closest('.cursor-pointer')).toHaveClass('px-2', 'py-1')
|
|
expect(currentVersion.parentElement).toHaveClass('min-h-5', 'gap-1', 'px-1')
|
|
expect(currentBadge).toHaveClass('bg-components-badge-bg-dimm')
|
|
})
|
|
|
|
it('calls onSelect with downgrade metadata and closes the picker', () => {
|
|
const onSelect = vi.fn()
|
|
const onShowChange = vi.fn()
|
|
|
|
render(
|
|
<PluginVersionPicker
|
|
isShow
|
|
onShowChange={onShowChange}
|
|
pluginID="plugin-1"
|
|
currentVersion="2.0.0"
|
|
trigger={<span>trigger</span>}
|
|
onSelect={onSelect}
|
|
/>,
|
|
)
|
|
|
|
fireEvent.click(screen.getByText('1.0.0'))
|
|
|
|
expect(onSelect).toHaveBeenCalledWith({
|
|
version: '1.0.0',
|
|
unique_identifier: 'uid-old',
|
|
isDowngrade: true,
|
|
})
|
|
expect(onShowChange).toHaveBeenCalledWith(false)
|
|
})
|
|
|
|
it('does not call onSelect when the current version is clicked', () => {
|
|
const onSelect = vi.fn()
|
|
|
|
render(
|
|
<PluginVersionPicker
|
|
isShow
|
|
onShowChange={vi.fn()}
|
|
pluginID="plugin-1"
|
|
currentVersion="2.0.0"
|
|
trigger={<span>trigger</span>}
|
|
onSelect={onSelect}
|
|
/>,
|
|
)
|
|
|
|
fireEvent.click(screen.getByText('2.0.0'))
|
|
|
|
expect(onSelect).not.toHaveBeenCalled()
|
|
})
|
|
})
|