import type { TriggerProps } from '@rc-component/trigger'; import dayjs from 'dayjs'; import customParseFormat from 'dayjs/plugin/customParseFormat'; import React from 'react'; import ConfigProvider from '..'; import { render } from '../../../tests/utils'; import Cascader from '../../cascader'; import Select from '../../select'; import TreeSelect from '../../tree-select'; dayjs.extend(customParseFormat); function triggerProps(): TriggerProps { return globalThis.triggerProps; } vi.mock('@rc-component/trigger', async (importOriginal) => { const R = await vi.importActual('react'); const { default: Trigger } = await importOriginal(); return { default: R.forwardRef((props: any, ref: any) => { (globalThis as any).triggerProps = props; return ; }), }; }); describe('ConfigProvider.Popup', () => { beforeEach(() => { (global as any).triggerProps = null; }); const selectLikeNodes = ( <> , ); expect(triggerProps().builtinPlacements!.topLeft!.htmlRegion).toBe('scroll'); }); it('TreeSelect', () => { render( , ); expect(triggerProps().builtinPlacements!.topLeft!.htmlRegion).toBe('scroll'); }); it('Cascader', () => { render( , ); expect(triggerProps().builtinPlacements!.topLeft!.htmlRegion).toBe('scroll'); }); }); });