У меня есть этот упрощенный render()
метод:
render() {
return (
<React.Fragment>
<Router>
<div>
<Route path='/abc' component={Test} />
<Route path='/def' render={() => (
<div>Hello</div>
)} />
</div>
</Router>
</React.Fragment>
)
}
И этот ферментный тест:
test('Render <Test> on /abc', () => {
const wrapper = mount(
<MemoryRouter initialEntries={['/abc']} >
<App />
</MemoryRouter>
);
console.log(wrapper.debug());
expect(wrapper.find(Test)).to.have.lengthOf(1);
});
Однако mount()
не выполняет рендеринг ни компонента Test
на маршруте /abc
, ни <div>Hello</div>
на маршруте /def
.
Вывод из console.log(wrapper.debug());
:
<MemoryRouter initialEntries={{...}}>
<Router history={{...}}>
<App>
<BrowserRouter>
<Router history={{...}}>
<div>
<Route path="/abc" component={[Function: Test]} />
<Route path="/def" render={[Function: render]} />
</div>
</Router>
</BrowserRouter>
</App>
</Router>
</MemoryRouter>
Как проверить, что приложение будет отображать Test
компонент на /abc
маршруте?