mirror of
https://github.com/langgenius/dify.git
synced 2026-05-07 06:01:13 -04:00
81 lines
2.6 KiB
TypeScript
81 lines
2.6 KiB
TypeScript
import type { ReactElement, ReactNode } from 'react'
|
|
import { fireEvent, render, screen } from '@testing-library/react'
|
|
import { NuqsTestingAdapter } from 'nuqs/adapters/testing'
|
|
import { beforeEach, describe, expect, it, vi } from 'vitest'
|
|
import { createSystemFeaturesWrapper } from '@/__tests__/utils/mock-system-features'
|
|
import { usePluginPageContext } from '../context'
|
|
import { PluginPageContextProvider } from '../context-provider'
|
|
|
|
vi.mock('../../hooks', () => ({
|
|
PLUGIN_PAGE_TABS_MAP: {
|
|
plugins: 'plugins',
|
|
marketplace: 'discover',
|
|
},
|
|
usePluginPageTabs: () => [
|
|
{ value: 'plugins', text: 'Plugins' },
|
|
{ value: 'discover', text: 'Discover' },
|
|
],
|
|
}))
|
|
|
|
const renderWithProviders = (
|
|
ui: ReactElement,
|
|
options: { enableMarketplace: boolean, searchParams?: string } = { enableMarketplace: true },
|
|
) => {
|
|
const { wrapper: SystemFeaturesWrapper } = createSystemFeaturesWrapper({
|
|
systemFeatures: { enable_marketplace: options.enableMarketplace },
|
|
})
|
|
const Wrapper = ({ children }: { children: ReactNode }) => (
|
|
<SystemFeaturesWrapper>
|
|
<NuqsTestingAdapter searchParams={options.searchParams ?? ''}>
|
|
{children}
|
|
</NuqsTestingAdapter>
|
|
</SystemFeaturesWrapper>
|
|
)
|
|
return render(ui, { wrapper: Wrapper })
|
|
}
|
|
|
|
const Consumer = () => {
|
|
const currentPluginID = usePluginPageContext(v => v.currentPluginID)
|
|
const setCurrentPluginID = usePluginPageContext(v => v.setCurrentPluginID)
|
|
const options = usePluginPageContext(v => v.options)
|
|
|
|
return (
|
|
<div>
|
|
<span data-testid="current-plugin">{currentPluginID ?? 'none'}</span>
|
|
<span data-testid="options-count">{options.length}</span>
|
|
<button onClick={() => setCurrentPluginID('plugin-1')}>select plugin</button>
|
|
</div>
|
|
)
|
|
}
|
|
|
|
describe('PluginPageContextProvider', () => {
|
|
beforeEach(() => {
|
|
vi.clearAllMocks()
|
|
})
|
|
|
|
it('filters out the marketplace tab when the feature is disabled', () => {
|
|
renderWithProviders(
|
|
<PluginPageContextProvider>
|
|
<Consumer />
|
|
</PluginPageContextProvider>,
|
|
{ enableMarketplace: false },
|
|
)
|
|
|
|
expect(screen.getByTestId('options-count')).toHaveTextContent('1')
|
|
})
|
|
|
|
it('keeps the query-state tab and updates the current plugin id', () => {
|
|
renderWithProviders(
|
|
<PluginPageContextProvider>
|
|
<Consumer />
|
|
</PluginPageContextProvider>,
|
|
{ enableMarketplace: true, searchParams: '?tab=discover' },
|
|
)
|
|
|
|
fireEvent.click(screen.getByText('select plugin'))
|
|
|
|
expect(screen.getByTestId('current-plugin')).toHaveTextContent('plugin-1')
|
|
expect(screen.getByTestId('options-count')).toHaveTextContent('2')
|
|
})
|
|
})
|