vuecssuiant-designantdreactantantd-vueenterprisefrontendui-designvue-antdvue-antd-uivue3vuecomponent
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
131 lines
3.3 KiB
131 lines
3.3 KiB
import { mount } from '@vue/test-utils'; |
|
import Breadcrumb from '../index'; |
|
|
|
describe('Breadcrumb', () => { |
|
const errorSpy = jest.spyOn(console, 'error').mockImplementation(() => {}); |
|
|
|
afterEach(() => { |
|
errorSpy.mockReset(); |
|
}); |
|
|
|
afterAll(() => { |
|
errorSpy.mockRestore(); |
|
}); |
|
|
|
// // https://github.com/airbnb/enzyme/issues/875 |
|
it('warns on non-Breadcrumb.Item and non-Breadcrumb.Separator children', () => { |
|
mount({ |
|
render() { |
|
return ( |
|
<Breadcrumb> |
|
<div>foo</div> |
|
</Breadcrumb> |
|
); |
|
}, |
|
}); |
|
expect(errorSpy.mock.calls).toHaveLength(1); |
|
expect(errorSpy.mock.calls[0][0]).toMatch( |
|
"Warning: [ant-design-vue: Breadcrumb] Only accepts Breadcrumb.Item and Breadcrumb.Separator as it's children", |
|
); |
|
}); |
|
|
|
// https:// github.com/ant-design/ant-design/issues/5015 |
|
it('should allow Breadcrumb.Item is null or undefined', () => { |
|
const wrapper = mount({ |
|
render() { |
|
return ( |
|
<Breadcrumb> |
|
{null} |
|
<Breadcrumb.Item>Home</Breadcrumb.Item> |
|
{undefined} |
|
</Breadcrumb> |
|
); |
|
}, |
|
}); |
|
expect(errorSpy).not.toHaveBeenCalled(); |
|
expect(wrapper.html()).toMatchSnapshot(); |
|
}); |
|
|
|
// https://github.com/ant-design/ant-design/issues/5542 |
|
it('should not display Breadcrumb Item when its children is falsy', () => { |
|
const wrapper = mount({ |
|
render() { |
|
return ( |
|
<Breadcrumb> |
|
<Breadcrumb.Item /> |
|
<Breadcrumb.Item>xxx</Breadcrumb.Item> |
|
<Breadcrumb.Item>yyy</Breadcrumb.Item> |
|
</Breadcrumb> |
|
); |
|
}, |
|
}); |
|
expect(wrapper.html()).toMatchSnapshot(); |
|
}); |
|
it('should render a menu', () => { |
|
const routes = [ |
|
{ |
|
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', |
|
}, |
|
]; |
|
const wrapper = mount(Breadcrumb, { props: { routes } }); |
|
expect(wrapper.html()).toMatchSnapshot(); |
|
}); |
|
|
|
it('should support custom attribute', () => { |
|
const wrapper = mount({ |
|
render() { |
|
return ( |
|
<Breadcrumb data-custom="custom"> |
|
<Breadcrumb.Item data-custom="custom-item">xxx</Breadcrumb.Item> |
|
<Breadcrumb.Item>yyy</Breadcrumb.Item> |
|
</Breadcrumb> |
|
); |
|
}, |
|
}); |
|
expect(wrapper.html()).toMatchSnapshot(); |
|
}); |
|
|
|
// https://github.com/ant-design/ant-design/issues/25975 |
|
it('should support Breadcrumb.Item default separator', () => { |
|
const MockComponent = () => ( |
|
<span> |
|
<Breadcrumb.Item>Mock Node</Breadcrumb.Item> |
|
</span> |
|
); |
|
const wrapper = mount({ |
|
render() { |
|
return ( |
|
<Breadcrumb> |
|
<Breadcrumb.Item>Location</Breadcrumb.Item> |
|
<MockComponent /> |
|
<Breadcrumb.Item>Application Center</Breadcrumb.Item> |
|
</Breadcrumb> |
|
); |
|
}, |
|
}); |
|
expect(wrapper.html()).toMatchSnapshot(); |
|
}); |
|
});
|
|
|