mirror of
https://github.com/ant-design/ant-design.git
synced 2024-12-05 01:19:45 +08:00
205 lines
6.0 KiB
TypeScript
205 lines
6.0 KiB
TypeScript
import React from 'react';
|
|
import accessibilityTest from '../../../tests/shared/accessibilityTest';
|
|
import mountTest from '../../../tests/shared/mountTest';
|
|
import rtlTest from '../../../tests/shared/rtlTest';
|
|
import { render } from '../../../tests/utils';
|
|
import type { Route } from '../Breadcrumb';
|
|
import Breadcrumb from '../index';
|
|
|
|
describe('Breadcrumb', () => {
|
|
mountTest(Breadcrumb);
|
|
rtlTest(Breadcrumb);
|
|
accessibilityTest(Breadcrumb);
|
|
|
|
const errorSpy = jest.spyOn(console, 'error').mockImplementation(() => {});
|
|
|
|
afterEach(() => {
|
|
errorSpy.mockReset();
|
|
});
|
|
|
|
afterAll(() => {
|
|
errorSpy.mockRestore();
|
|
});
|
|
|
|
it('warns on non-Breadcrumb.Item and non-Breadcrumb.Separator children', () => {
|
|
const MyCom: React.FC = () => <div>foo</div>;
|
|
render(
|
|
<Breadcrumb>
|
|
<MyCom />
|
|
</Breadcrumb>,
|
|
);
|
|
expect(errorSpy).toHaveBeenCalledWith(
|
|
"Warning: [antd: Breadcrumb] Only accepts Breadcrumb.Item and Breadcrumb.Separator as it's children",
|
|
);
|
|
});
|
|
|
|
it('overlay deprecation warning', () => {
|
|
render(
|
|
<Breadcrumb>
|
|
<Breadcrumb.Item overlay={<div>menu</div>}>
|
|
<a href="">General</a>
|
|
</Breadcrumb.Item>
|
|
</Breadcrumb>,
|
|
);
|
|
expect(errorSpy).toHaveBeenCalledWith(
|
|
'Warning: [antd: Breadcrumb.Item] `overlay` is deprecated. Please use `menu` instead.',
|
|
);
|
|
});
|
|
|
|
// https://github.com/ant-design/ant-design/issues/5015
|
|
it('should allow Breadcrumb.Item is null or undefined', () => {
|
|
const { asFragment } = render(
|
|
<Breadcrumb>
|
|
{null}
|
|
<Breadcrumb.Item>Home</Breadcrumb.Item>
|
|
{undefined}
|
|
</Breadcrumb>,
|
|
);
|
|
expect(errorSpy).not.toHaveBeenCalled();
|
|
expect(asFragment().firstChild).toMatchSnapshot();
|
|
});
|
|
|
|
// https://github.com/ant-design/ant-design/issues/5542
|
|
it('should not display Breadcrumb Item when its children is falsy', () => {
|
|
const { asFragment } = render(
|
|
<Breadcrumb>
|
|
<Breadcrumb.Item />
|
|
<Breadcrumb.Item>xxx</Breadcrumb.Item>
|
|
<Breadcrumb.Item>yyy</Breadcrumb.Item>
|
|
</Breadcrumb>,
|
|
);
|
|
expect(asFragment().firstChild).toMatchSnapshot();
|
|
});
|
|
|
|
// https://github.com/ant-design/ant-design/issues/18260
|
|
it('filter React.Fragment', () => {
|
|
const { asFragment } = render(
|
|
<Breadcrumb separator="">
|
|
<Breadcrumb.Item>Location</Breadcrumb.Item>
|
|
<Breadcrumb.Separator>:</Breadcrumb.Separator>
|
|
<>
|
|
<Breadcrumb.Item href="">Application Center</Breadcrumb.Item>
|
|
<Breadcrumb.Separator />
|
|
</>
|
|
</Breadcrumb>,
|
|
);
|
|
expect(asFragment().firstChild).toMatchSnapshot();
|
|
});
|
|
|
|
it('should render a menu', () => {
|
|
const routes: Route[] = [
|
|
{
|
|
path: 'index',
|
|
breadcrumbName: 'home',
|
|
},
|
|
{
|
|
path: 'first',
|
|
breadcrumbName: 'first',
|
|
children: [
|
|
{
|
|
path: '/general',
|
|
breadcrumbName: 'General',
|
|
},
|
|
{
|
|
path: '/layout',
|
|
breadcrumbName: 'Layout',
|
|
},
|
|
{
|
|
path: '/navigation',
|
|
breadcrumbName: 'Navigation',
|
|
},
|
|
],
|
|
},
|
|
{
|
|
path: 'second',
|
|
breadcrumbName: 'second',
|
|
},
|
|
{
|
|
path: 'third',
|
|
breadcrumbName: '',
|
|
},
|
|
];
|
|
const { asFragment } = render(<Breadcrumb routes={routes} />);
|
|
expect(asFragment().firstChild).toMatchSnapshot();
|
|
});
|
|
|
|
it('should accept undefined routes', () => {
|
|
const { asFragment } = render(<Breadcrumb routes={undefined} />);
|
|
expect(asFragment().firstChild).toMatchSnapshot();
|
|
});
|
|
|
|
it('should support custom attribute', () => {
|
|
const { asFragment } = render(
|
|
<Breadcrumb data-custom="custom">
|
|
<Breadcrumb.Item data-custom="custom-item">xxx</Breadcrumb.Item>
|
|
<Breadcrumb.Item>yyy</Breadcrumb.Item>
|
|
</Breadcrumb>,
|
|
);
|
|
expect(asFragment().firstChild).toMatchSnapshot();
|
|
});
|
|
|
|
it('should support React.Fragment and falsy children', () => {
|
|
const { asFragment } = render(
|
|
<Breadcrumb>
|
|
<>
|
|
<Breadcrumb.Item>yyy</Breadcrumb.Item>
|
|
<Breadcrumb.Item>yyy</Breadcrumb.Item>
|
|
</>
|
|
<Breadcrumb.Item>yyy</Breadcrumb.Item>
|
|
{0}
|
|
{null}
|
|
{undefined}
|
|
</Breadcrumb>,
|
|
);
|
|
expect(asFragment().firstChild).toMatchSnapshot();
|
|
});
|
|
|
|
// https://github.com/ant-design/ant-design/issues/25975
|
|
it('should support Breadcrumb.Item default separator', () => {
|
|
const MockComponent: React.FC = () => (
|
|
<span>
|
|
<Breadcrumb.Item>Mock Node</Breadcrumb.Item>
|
|
</span>
|
|
);
|
|
const { asFragment } = render(
|
|
<Breadcrumb>
|
|
<Breadcrumb.Item>Location</Breadcrumb.Item>
|
|
<MockComponent />
|
|
<Breadcrumb.Item>Application Center</Breadcrumb.Item>
|
|
</Breadcrumb>,
|
|
);
|
|
expect(asFragment().firstChild).toMatchSnapshot();
|
|
});
|
|
it('should support string `0` and number `0`', () => {
|
|
const { container } = render(
|
|
<Breadcrumb>
|
|
<Breadcrumb.Item>{0}</Breadcrumb.Item>
|
|
<Breadcrumb.Item>0</Breadcrumb.Item>
|
|
</Breadcrumb>,
|
|
);
|
|
expect(container.querySelectorAll('.ant-breadcrumb-link')[0].textContent).toBe('0');
|
|
expect(container.querySelectorAll('.ant-breadcrumb-link')[1].textContent).toBe('0');
|
|
expect(container.firstChild).toMatchSnapshot();
|
|
});
|
|
|
|
it('should console Error when `overlay` in props', () => {
|
|
const errSpy = jest.spyOn(console, 'error').mockImplementation(() => {});
|
|
render(
|
|
<Breadcrumb>
|
|
<Breadcrumb.Item overlay={<div>test</div>} />
|
|
</Breadcrumb>,
|
|
);
|
|
expect(errSpy).toHaveBeenCalledWith(
|
|
'Warning: [antd: Breadcrumb.Item] `overlay` is deprecated. Please use `menu` instead.',
|
|
);
|
|
errSpy.mockRestore();
|
|
});
|
|
|
|
it('should not console Error when `overlay` not in props', () => {
|
|
const errSpy = jest.spyOn(console, 'error').mockImplementation(() => {});
|
|
render(<Breadcrumb routes={[{ path: '/', breadcrumbName: 'Test' }]} />);
|
|
expect(errSpy).not.toHaveBeenCalled();
|
|
errSpy.mockRestore();
|
|
});
|
|
});
|