mirror of https://github.com/Squidex/squidex.git
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.
134 lines
4.4 KiB
134 lines
4.4 KiB
/*
|
|
* Squidex Headless CMS
|
|
*
|
|
* @license
|
|
* Copyright (c) Squidex UG (haftungsbeschränkt). All rights reserved.
|
|
*/
|
|
|
|
import { DialogService, RuleEventsDto, RuleEventsState, RulesService } from '@app/shared/internal';
|
|
import { of, throwError } from 'rxjs';
|
|
import { onErrorResumeNext } from 'rxjs/operators';
|
|
import { IMock, It, Mock, Times } from 'typemoq';
|
|
import { createRuleEvent } from './../services/rules.service.spec';
|
|
import { TestValues } from './_test-helpers';
|
|
|
|
describe('RuleEventsState', () => {
|
|
const {
|
|
app,
|
|
appsState,
|
|
} = TestValues;
|
|
|
|
const oldRuleEvents = [
|
|
createRuleEvent(1),
|
|
createRuleEvent(2),
|
|
];
|
|
|
|
let dialogs: IMock<DialogService>;
|
|
let rulesService: IMock<RulesService>;
|
|
let ruleEventsState: RuleEventsState;
|
|
|
|
beforeEach(() => {
|
|
dialogs = Mock.ofType<DialogService>();
|
|
|
|
rulesService = Mock.ofType<RulesService>();
|
|
rulesService.setup(x => x.getEvents(app, 30, 0, undefined))
|
|
.returns(() => of(new RuleEventsDto(200, oldRuleEvents)));
|
|
|
|
ruleEventsState = new RuleEventsState(appsState.object, dialogs.object, rulesService.object);
|
|
ruleEventsState.load().subscribe();
|
|
});
|
|
|
|
it('should load rule events', () => {
|
|
expect(ruleEventsState.snapshot.ruleEvents).toEqual(oldRuleEvents);
|
|
expect(ruleEventsState.snapshot.isLoaded).toBeTruthy();
|
|
expect(ruleEventsState.snapshot.isLoading).toBeFalsy();
|
|
expect(ruleEventsState.snapshot.total).toEqual(200);
|
|
|
|
dialogs.verify(x => x.notifyInfo(It.isAnyString()), Times.never());
|
|
});
|
|
|
|
it('should reset loading state if loading failed', () => {
|
|
rulesService.setup(x => x.getEvents(app, 30, 0, undefined))
|
|
.returns(() => throwError(() => 'Service Error'));
|
|
|
|
ruleEventsState.load().pipe(onErrorResumeNext()).subscribe();
|
|
|
|
expect(ruleEventsState.snapshot.isLoading).toBeFalsy();
|
|
});
|
|
|
|
it('should show notification on load if reload is true', () => {
|
|
ruleEventsState.load(true).subscribe();
|
|
|
|
expect().nothing();
|
|
|
|
dialogs.verify(x => x.notifyInfo(It.isAnyString()), Times.once());
|
|
});
|
|
|
|
it('should load with new pagination if paging', () => {
|
|
rulesService.setup(x => x.getEvents(app, 30, 30, undefined))
|
|
.returns(() => of(new RuleEventsDto(200, [])));
|
|
|
|
ruleEventsState.page({ page: 1, pageSize: 30 }).subscribe();
|
|
|
|
expect().nothing();
|
|
|
|
rulesService.verify(x => x.getEvents(app, 30, 30, undefined), Times.once());
|
|
rulesService.verify(x => x.getEvents(app, 30, 0, undefined), Times.once());
|
|
});
|
|
|
|
it('should load with rule id if filtered', () => {
|
|
rulesService.setup(x => x.getEvents(app, 30, 0, '12'))
|
|
.returns(() => of(new RuleEventsDto(200, [])));
|
|
|
|
ruleEventsState.filterByRule('12').subscribe();
|
|
|
|
expect().nothing();
|
|
|
|
rulesService.verify(x => x.getEvents(app, 30, 0, '12'), Times.once());
|
|
});
|
|
|
|
it('should not load again if rule id has not changed', () => {
|
|
rulesService.setup(x => x.getEvents(app, 30, 0, '12'))
|
|
.returns(() => of(new RuleEventsDto(200, [])));
|
|
|
|
ruleEventsState.filterByRule('12').subscribe();
|
|
ruleEventsState.filterByRule('12').subscribe();
|
|
|
|
expect().nothing();
|
|
|
|
rulesService.verify(x => x.getEvents(app, 30, 0, '12'), Times.once());
|
|
});
|
|
|
|
it('should call service if enqueuing event', () => {
|
|
rulesService.setup(x => x.enqueueEvent(app, oldRuleEvents[0]))
|
|
.returns(() => of({}));
|
|
|
|
ruleEventsState.enqueue(oldRuleEvents[0]).subscribe();
|
|
|
|
expect().nothing();
|
|
|
|
rulesService.verify(x => x.enqueueEvent(app, oldRuleEvents[0]), Times.once());
|
|
});
|
|
|
|
it('should call service if cancelling event', () => {
|
|
rulesService.setup(x => x.cancelEvents(app, oldRuleEvents[0]))
|
|
.returns(() => of({}));
|
|
|
|
ruleEventsState.cancel(oldRuleEvents[0]).subscribe();
|
|
|
|
expect().nothing();
|
|
|
|
rulesService.verify(x => x.cancelEvents(app, oldRuleEvents[0]), Times.once());
|
|
});
|
|
|
|
it('should call service if cancelling all events', () => {
|
|
rulesService.setup(x => x.cancelEvents(app, It.isAny()))
|
|
.returns(() => of({}));
|
|
|
|
ruleEventsState.cancelAll().subscribe();
|
|
|
|
expect().nothing();
|
|
|
|
rulesService.verify(x => x.cancelEvents(app, It.isAny()), Times.once());
|
|
});
|
|
});
|
|
|