2019-12-07 21:02:00 +02:00
|
|
|
import expect from 'app/test/unexpected';
|
2019-12-07 13:28:52 +02:00
|
|
|
import React from 'react';
|
2019-12-07 21:02:00 +02:00
|
|
|
import reducer from 'app/components/ui/popup/reducer';
|
|
|
|
import { create, destroy } from 'app/components/ui/popup/actions';
|
2016-05-01 20:50:55 +03:00
|
|
|
|
|
|
|
describe('popup/reducer', () => {
|
2019-11-27 11:03:32 +02:00
|
|
|
it('should have no popups by default', () => {
|
2019-12-07 13:28:52 +02:00
|
|
|
const actual = reducer(undefined, {
|
|
|
|
type: 'init',
|
|
|
|
});
|
2019-11-27 11:03:32 +02:00
|
|
|
|
|
|
|
expect(actual.popups, 'to be an', 'array');
|
|
|
|
expect(actual.popups, 'to be empty');
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('#create', () => {
|
|
|
|
it('should create popup', () => {
|
|
|
|
const actual = reducer(
|
|
|
|
undefined,
|
|
|
|
create({
|
|
|
|
Popup: FakeComponent,
|
|
|
|
}),
|
|
|
|
);
|
|
|
|
|
|
|
|
expect(actual.popups[0], 'to equal', {
|
|
|
|
Popup: FakeComponent,
|
|
|
|
});
|
|
|
|
});
|
2016-05-01 20:50:55 +03:00
|
|
|
|
2019-11-27 11:03:32 +02:00
|
|
|
it('should create multiple popups', () => {
|
|
|
|
let actual = reducer(
|
|
|
|
undefined,
|
|
|
|
create({
|
|
|
|
Popup: FakeComponent,
|
|
|
|
}),
|
|
|
|
);
|
|
|
|
actual = reducer(
|
|
|
|
actual,
|
|
|
|
create({
|
|
|
|
Popup: FakeComponent,
|
|
|
|
}),
|
|
|
|
);
|
|
|
|
|
|
|
|
expect(actual.popups[1], 'to equal', {
|
|
|
|
Popup: FakeComponent,
|
|
|
|
});
|
2016-05-01 20:50:55 +03:00
|
|
|
});
|
|
|
|
|
2019-11-27 11:03:32 +02:00
|
|
|
it('throws when no type provided', () => {
|
|
|
|
expect(
|
2019-12-07 13:28:52 +02:00
|
|
|
() =>
|
|
|
|
reducer(
|
|
|
|
undefined,
|
|
|
|
// @ts-ignore
|
|
|
|
create({}),
|
|
|
|
),
|
2019-11-27 11:03:32 +02:00
|
|
|
'to throw',
|
|
|
|
'Popup is required',
|
|
|
|
);
|
2016-05-01 20:50:55 +03:00
|
|
|
});
|
2019-11-27 11:03:32 +02:00
|
|
|
});
|
2016-05-01 20:50:55 +03:00
|
|
|
|
2019-11-27 11:03:32 +02:00
|
|
|
describe('#destroy', () => {
|
|
|
|
let state;
|
|
|
|
let popup;
|
2016-05-01 20:50:55 +03:00
|
|
|
|
2019-11-27 11:03:32 +02:00
|
|
|
beforeEach(() => {
|
|
|
|
state = reducer(state, create({ Popup: FakeComponent }));
|
|
|
|
popup = state.popups[0];
|
|
|
|
});
|
2016-05-01 20:50:55 +03:00
|
|
|
|
2019-11-27 11:03:32 +02:00
|
|
|
it('should remove popup', () => {
|
|
|
|
expect(state.popups, 'to have length', 1);
|
2016-05-01 20:50:55 +03:00
|
|
|
|
2019-11-27 11:03:32 +02:00
|
|
|
state = reducer(state, destroy(popup));
|
2016-05-01 20:50:55 +03:00
|
|
|
|
2019-11-27 11:03:32 +02:00
|
|
|
expect(state.popups, 'to have length', 0);
|
|
|
|
});
|
2016-05-01 20:50:55 +03:00
|
|
|
|
2019-11-27 11:03:32 +02:00
|
|
|
it('should not remove something, that it should not', () => {
|
|
|
|
state = reducer(
|
|
|
|
state,
|
|
|
|
create({
|
|
|
|
Popup: FakeComponent,
|
|
|
|
}),
|
|
|
|
);
|
2016-05-01 20:50:55 +03:00
|
|
|
|
2019-11-27 11:03:32 +02:00
|
|
|
state = reducer(state, destroy(popup));
|
2016-05-01 20:50:55 +03:00
|
|
|
|
2019-11-27 11:03:32 +02:00
|
|
|
expect(state.popups, 'to have length', 1);
|
|
|
|
expect(state.popups[0], 'not to be', popup);
|
2016-05-01 20:50:55 +03:00
|
|
|
});
|
2019-11-27 11:03:32 +02:00
|
|
|
});
|
2016-05-01 20:50:55 +03:00
|
|
|
});
|
2016-05-11 08:26:44 +03:00
|
|
|
|
2019-12-07 13:28:52 +02:00
|
|
|
function FakeComponent() {
|
|
|
|
return <span />;
|
|
|
|
}
|