dify/web/app/components/integrations/__tests__/tool-provider-card.spec.tsx
Jingyi 9b74df21d0
feat(web): refine onboarding UI (#37433)
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>
2026-06-15 08:47:15 +00:00

102 lines
3.6 KiB
TypeScript

import type { Collection } from '@/app/components/tools/types'
import { render, screen } from '@testing-library/react'
import { describe, expect, it, vi } from 'vitest'
import IntegrationsToolProviderCard from '../tool-provider-card'
vi.mock('@/context/i18n', () => ({
useGetLanguage: () => 'en_US',
}))
vi.mock('react-i18next', () => ({
useTranslation: () => ({
t: (key: string, options?: { count?: number, ns?: string }) => options?.ns ? `${options.ns}.${key}${options.count ? `:${options.count}` : ''}` : key,
}),
}))
vi.mock('@/app/components/plugins/card/base/card-icon', () => ({
default: () => <div data-testid="card-icon" />,
}))
vi.mock('@/app/components/plugins/card/base/corner-mark', () => ({
default: ({ text }: { text: string }) => <div data-testid="corner-mark">{text}</div>,
}))
const createCollection = (overrides: Partial<Collection> = {}): Collection => ({
id: 'builtin-provider',
name: 'builtin-provider',
author: 'Dify',
description: { en_US: 'Builtin provider description', zh_Hans: 'Builtin provider description' },
icon: '',
label: { en_US: 'Builtin Provider', zh_Hans: 'Builtin Provider' },
type: 'builtin',
team_credentials: {},
is_team_authorization: false,
allow_delete: false,
labels: [],
tools: [],
...overrides,
})
describe('IntegrationsToolProviderCard', () => {
it('shows a built-in corner badge for builtin tools', () => {
render(<IntegrationsToolProviderCard collection={createCollection()} showBuiltInBadge />)
expect(screen.getByTestId('corner-mark')).toHaveTextContent('dataset.metadata.datasetMetadata.builtIn')
})
it('does not infer built-in badge from a missing plugin id', () => {
render(<IntegrationsToolProviderCard collection={createCollection()} />)
expect(screen.queryByTestId('corner-mark')).not.toBeInTheDocument()
})
it('does not show a source label for builtin tools', () => {
render(<IntegrationsToolProviderCard collection={createCollection()} />)
expect(screen.queryByText('plugin.from')).not.toBeInTheDocument()
})
it('does not show a built-in corner badge for marketplace plugin tools', () => {
render(<IntegrationsToolProviderCard collection={createCollection({ plugin_id: 'author/provider' })} showBuiltInBadge />)
expect(screen.queryByTestId('corner-mark')).not.toBeInTheDocument()
})
it('shows the built-in tool count without using endpoint copy', () => {
render(
<IntegrationsToolProviderCard collection={createCollection({
tools: [
{ name: 'tool-a' },
{ name: 'tool-b' },
] as Collection['tools'],
})}
/>,
)
expect(screen.getByText('tools.mcp.toolsCount:2')).toBeInTheDocument()
expect(screen.queryByText(/plugin\.endpointsEnabled/)).not.toBeInTheDocument()
})
it('shows author and labels in the labeled card style', () => {
render(
<IntegrationsToolProviderCard
collection={createCollection({
author: 'Evan',
labels: ['Productivity', 'Utilities'],
tools: [
{ name: 'tool-a' },
] as Collection['tools'],
})}
variant="labeled"
/>,
)
expect(screen.getByTestId('card-builtin-provider')).toHaveClass('shadow-xs', 'hover:bg-components-panel-on-panel-item-bg-hover', 'hover:shadow-md')
expect(screen.getByText('tools.author Evan')).toBeInTheDocument()
expect(screen.getByText('Productivity')).toBeInTheDocument()
expect(screen.getByText('Utilities')).toBeInTheDocument()
expect(screen.getAllByText('#')).toHaveLength(2)
expect(screen.queryByText('tools.mcp.toolsCount:1')).not.toBeInTheDocument()
})
})