mapillary-js/test/component/direction/DirectionComponent.test.ts
2021-03-28 18:55:20 +02:00

153 lines
6.7 KiB
TypeScript

import { throwError as observableThrowError, of as observableOf, Subject } from "rxjs";
import { DirectionComponent } from "../../../src/component/direction/DirectionComponent";
import { DirectionDOMRenderer } from "../../../src/component/direction/DirectionDOMRenderer";
import { ImageCache } from "../../../src/graph/ImageCache";
import { Sequence } from "../../../src/graph/Sequence";
import { Container } from "../../../src/viewer/Container";
import { Navigator } from "../../../src/viewer/Navigator";
import { Image } from "../../../src/graph/Image";
import { ContainerMockCreator } from "../../helper/ContainerMockCreator";
import { NavigatorMockCreator } from "../../helper/NavigatorMockCreator";
import { ImageHelper } from "../../helper/ImageHelper";
describe("DirectionComponent.ctor", () => {
it("should be defined", () => {
const directionComponent: DirectionComponent =
new DirectionComponent(
DirectionComponent.componentName,
new ContainerMockCreator().create(),
new NavigatorMockCreator().create());
expect(directionComponent).toBeDefined();
});
});
describe("DirectionComponent.deactivate", () => {
it("should deactivate properly", () => {
const directionComponent: DirectionComponent =
new DirectionComponent(
DirectionComponent.componentName,
new ContainerMockCreator().create(),
new NavigatorMockCreator().create());
directionComponent.activate();
directionComponent.deactivate();
});
});
describe("DirectionComponent.activate", () => {
it("should set edges when image spatial edges emits", () => {
const containerMock: Container = new ContainerMockCreator().create();
const navigatorMock: Navigator = new NavigatorMockCreator().create();
const renderer: DirectionDOMRenderer = new DirectionDOMRenderer({}, { height: 1, width: 1 });
const setEdgesSpy: jasmine.Spy = spyOn(renderer, "setEdges").and.stub();
const directionComponent: DirectionComponent =
new DirectionComponent(
DirectionComponent.componentName,
containerMock,
navigatorMock,
renderer);
directionComponent.activate();
const image: Image = new ImageHelper().createImage();
image.initializeCache(new ImageCache(undefined));
image.cacheSpatialEdges([]);
(<Subject<Image>>navigatorMock.stateService.currentImage$).next(image);
expect(setEdgesSpy.calls.count()).toBe(1);
expect(setEdgesSpy.calls.argsFor(0)[1]).toBe(null);
});
it("should set edges when distinguishing sequence with cached sequence", () => {
const containerMock: Container = new ContainerMockCreator().create();
const navigatorMock: Navigator = new NavigatorMockCreator().create();
const renderer: DirectionDOMRenderer = new DirectionDOMRenderer({ distinguishSequence: true }, { height: 1, width: 1 });
const setEdgesSpy: jasmine.Spy = spyOn(renderer, "setEdges").and.stub();
const directionComponent: DirectionComponent =
new DirectionComponent(
DirectionComponent.componentName,
containerMock,
navigatorMock,
renderer);
directionComponent.configure({ distinguishSequence: true });
directionComponent.activate();
const sequence: Sequence = new Sequence({ id: "skey", image_ids: [] });
(<jasmine.Spy>navigatorMock.graphService.cacheSequence$).and.returnValue(observableOf<Sequence>(sequence));
const image: Image = new ImageHelper().createImage();
image.initializeCache(new ImageCache(undefined));
image.cacheSpatialEdges([]);
(<Subject<Image>>navigatorMock.stateService.currentImage$).next(image);
expect(setEdgesSpy.calls.count()).toBe(1);
expect(setEdgesSpy.calls.argsFor(0)[1]).toBe(sequence);
});
it("should set edges when distinguishing sequence with uncached sequence", () => {
const containerMock: Container = new ContainerMockCreator().create();
const navigatorMock: Navigator = new NavigatorMockCreator().create();
const renderer: DirectionDOMRenderer = new DirectionDOMRenderer({ distinguishSequence: true }, { height: 1, width: 1 });
const setEdgesSpy: jasmine.Spy = spyOn(renderer, "setEdges").and.stub();
const directionComponent: DirectionComponent =
new DirectionComponent(
DirectionComponent.componentName,
containerMock,
navigatorMock,
renderer);
directionComponent.configure({ distinguishSequence: true });
directionComponent.activate();
const sequence: Sequence = new Sequence({ id: "skey", image_ids: [] });
const cacheSequence$: Subject<Sequence> = new Subject<Sequence>();
(<jasmine.Spy>navigatorMock.graphService.cacheSequence$).and.returnValue(cacheSequence$);
const image: Image = new ImageHelper().createImage();
image.initializeCache(new ImageCache(undefined));
image.cacheSpatialEdges([]);
(<Subject<Image>>navigatorMock.stateService.currentImage$).next(image);
cacheSequence$.next(sequence);
cacheSequence$.complete();
expect(setEdgesSpy.calls.count()).toBe(1);
expect(setEdgesSpy.calls.argsFor(0)[1]).toBe(sequence);
});
it("should set edges when distinguishing sequence and cache sequence throws", () => {
spyOn(console, "error").and.stub();
const containerMock: Container = new ContainerMockCreator().create();
const navigatorMock: Navigator = new NavigatorMockCreator().create();
const renderer: DirectionDOMRenderer = new DirectionDOMRenderer({ distinguishSequence: true }, { height: 1, width: 1 });
const setEdgesSpy: jasmine.Spy = spyOn(renderer, "setEdges").and.stub();
const directionComponent: DirectionComponent =
new DirectionComponent(
DirectionComponent.componentName,
containerMock,
navigatorMock,
renderer);
directionComponent.configure({ distinguishSequence: true });
directionComponent.activate();
(<jasmine.Spy>navigatorMock.graphService.cacheSequence$).and.returnValue(observableThrowError(new Error("Failed to cache seq.")));
const image: Image = new ImageHelper().createImage();
image.initializeCache(new ImageCache(undefined));
image.cacheSpatialEdges([]);
(<Subject<Image>>navigatorMock.stateService.currentImage$).next(image);
expect(setEdgesSpy.calls.count()).toBe(1);
expect(setEdgesSpy.calls.argsFor(0)[1]).toBe(null);
});
});