2020-05-21 21:08:47 +03:00
|
|
|
import React from 'react';
|
2017-06-07 23:09:11 +03:00
|
|
|
import sinon from 'sinon';
|
2019-12-07 21:02:00 +02:00
|
|
|
import expect from 'app/test/unexpected';
|
2020-05-21 21:08:47 +03:00
|
|
|
import { render, fireEvent, createEvent, screen } from '@testing-library/react';
|
|
|
|
import { TestContextProvider } from 'app/shell';
|
2017-06-07 23:09:11 +03:00
|
|
|
|
|
|
|
import RulesPage from './RulesPage';
|
|
|
|
|
|
|
|
describe('RulesPage', () => {
|
2020-05-24 02:08:24 +03:00
|
|
|
describe('#onRuleClick()', () => {
|
|
|
|
const id = 'rule-1-2';
|
|
|
|
const pathname = '/foo';
|
|
|
|
const search = '?bar';
|
|
|
|
let page: HTMLElement;
|
|
|
|
let replace: Function;
|
2019-11-27 11:03:32 +02:00
|
|
|
|
2020-05-24 02:08:24 +03:00
|
|
|
beforeEach(() => {
|
|
|
|
replace = sinon.stub().named('history.replace');
|
2019-11-27 11:03:32 +02:00
|
|
|
|
2020-05-24 02:08:24 +03:00
|
|
|
({ container: page } = render(
|
|
|
|
<TestContextProvider>
|
|
|
|
<RulesPage location={{ pathname, search } as any} history={{ replace }} />
|
|
|
|
</TestContextProvider>,
|
|
|
|
));
|
|
|
|
});
|
2019-11-27 11:03:32 +02:00
|
|
|
|
2020-05-24 02:08:24 +03:00
|
|
|
it('should update location on rule click', () => {
|
|
|
|
const expectedUrl = `/foo?bar#${id}`;
|
2019-11-27 11:03:32 +02:00
|
|
|
|
2020-05-24 02:08:24 +03:00
|
|
|
fireEvent.click(page.querySelector(`#${id}`) as HTMLElement);
|
2019-11-27 11:03:32 +02:00
|
|
|
|
2020-05-24 02:08:24 +03:00
|
|
|
expect(replace, 'to have a call satisfying', [expectedUrl]);
|
|
|
|
});
|
2019-11-27 11:03:32 +02:00
|
|
|
|
2020-05-24 02:08:24 +03:00
|
|
|
it('should not update location if link was clicked', () => {
|
|
|
|
fireEvent.click(screen.getByText('/register', { exact: false }));
|
2019-11-27 11:03:32 +02:00
|
|
|
|
2020-05-24 02:08:24 +03:00
|
|
|
expect(replace, 'was not called');
|
|
|
|
});
|
2019-11-27 11:03:32 +02:00
|
|
|
|
2020-05-24 02:08:24 +03:00
|
|
|
it('should not update location if defaultPrevented', () => {
|
|
|
|
const el = page.querySelector(`#${id}`) as HTMLElement;
|
|
|
|
const event = createEvent.click(el);
|
2019-11-27 11:03:32 +02:00
|
|
|
|
2020-05-24 02:08:24 +03:00
|
|
|
event.preventDefault();
|
|
|
|
|
|
|
|
fireEvent(el, event);
|
|
|
|
|
|
|
|
expect(replace, 'was not called');
|
|
|
|
});
|
2019-11-27 11:03:32 +02:00
|
|
|
|
2020-05-24 02:08:24 +03:00
|
|
|
it('should not update location if no id', () => {
|
|
|
|
const el = page.querySelector(`#${id}`) as HTMLElement;
|
2020-05-21 21:08:47 +03:00
|
|
|
|
2020-05-24 02:08:24 +03:00
|
|
|
el.id = '';
|
2019-11-27 11:03:32 +02:00
|
|
|
|
2020-05-24 02:08:24 +03:00
|
|
|
fireEvent.click(el);
|
2019-11-27 11:03:32 +02:00
|
|
|
|
2020-05-24 02:08:24 +03:00
|
|
|
expect(replace, 'was not called');
|
|
|
|
});
|
2019-11-27 11:03:32 +02:00
|
|
|
});
|
2017-06-07 23:09:11 +03:00
|
|
|
});
|