2017-07-11 22:56:07 +03:00
|
|
|
import React from 'react';
|
|
|
|
import sinon from 'sinon';
|
2020-05-21 21:08:47 +03:00
|
|
|
import uxpect from 'app/test/unexpected';
|
|
|
|
import { render, screen } from '@testing-library/react';
|
2019-12-07 21:02:00 +02:00
|
|
|
import authFlow from 'app/services/authFlow';
|
2017-07-11 22:56:07 +03:00
|
|
|
|
|
|
|
import AuthFlowRouteContents from './AuthFlowRouteContents';
|
|
|
|
|
|
|
|
describe('AuthFlowRouteContents', () => {
|
2020-05-24 02:08:24 +03:00
|
|
|
beforeEach(() => {
|
|
|
|
sinon.stub(authFlow, 'handleRequest');
|
|
|
|
});
|
|
|
|
|
|
|
|
afterEach(() => {
|
|
|
|
(authFlow.handleRequest as any).restore();
|
|
|
|
});
|
|
|
|
|
|
|
|
let componentProps: { [key: string]: any };
|
|
|
|
|
|
|
|
function Component(props: { [key: string]: any }) {
|
|
|
|
componentProps = props;
|
|
|
|
|
|
|
|
return <div data-testid="test-component" />;
|
|
|
|
}
|
|
|
|
|
|
|
|
it('should render component if route allowed', () => {
|
|
|
|
const authRequest = {
|
|
|
|
path: '/path',
|
|
|
|
params: { foo: 1 },
|
|
|
|
query: new URLSearchParams(),
|
|
|
|
};
|
|
|
|
|
|
|
|
const routerProps: any = {
|
|
|
|
location: {
|
|
|
|
pathname: authRequest.path,
|
|
|
|
search: '',
|
|
|
|
query: new URLSearchParams(),
|
|
|
|
},
|
|
|
|
match: {
|
|
|
|
params: authRequest.params,
|
|
|
|
},
|
|
|
|
};
|
|
|
|
|
|
|
|
(authFlow.handleRequest as any).callsArg(2);
|
|
|
|
|
|
|
|
render(<AuthFlowRouteContents routerProps={routerProps} component={Component} />);
|
|
|
|
|
|
|
|
const component = screen.getByTestId('test-component');
|
|
|
|
|
|
|
|
uxpect(authFlow.handleRequest, 'to have a call satisfying', [
|
|
|
|
{
|
|
|
|
...authRequest,
|
|
|
|
query: uxpect.it('to be a', URLSearchParams),
|
|
|
|
},
|
|
|
|
uxpect.it('to be a function'),
|
|
|
|
uxpect.it('to be a function'),
|
|
|
|
]);
|
|
|
|
|
|
|
|
expect(component).toBeInTheDocument();
|
|
|
|
uxpect(componentProps, 'to equal', routerProps);
|
|
|
|
});
|
2017-07-11 22:56:07 +03:00
|
|
|
});
|