mapillary-js/spec/graph/Node.spec.ts
2016-10-24 16:37:39 +02:00

314 lines
8.5 KiB
TypeScript

/// <reference path="../../typings/index.d.ts" />
import {ICoreNode, IFillNode} from "../../src/API";
import {IMesh, Node, NodeCache} from "../../src/Graph";
let createCoreNode: () => ICoreNode = (): ICoreNode => {
return {
cl: { lat: 0, lon: 0},
key: "key",
l: { lat: 0, lon: 0 },
sequence: { key: "skey" },
};
};
let createFillNode: () => IFillNode = (): IFillNode => {
return {
atomic_scale: 0,
c_rotation: [0, 0, 0],
ca: 0,
calt: 0,
captured_at: 0,
cca: 0,
cfocal: 0,
gpano: null,
height: 0,
merge_cc: 0,
merge_version: 0,
orientation: 0,
user: { key: "key", username: "username"},
width: 0,
};
};
describe("Node", () => {
it("should create a node", () => {
let coreNode: ICoreNode = createCoreNode();
let node: Node = new Node(coreNode);
expect(node).toBeDefined();
});
});
describe("Node.full", () => {
it("should make node full", () => {
let coreNode: ICoreNode = createCoreNode();
let node: Node = new Node(coreNode);
expect(node.full).toBe(false);
let fillNode: IFillNode = createFillNode();
node.makeFull(fillNode);
expect(node.full).toBe(true);
});
it("should throw when fill is null", () => {
let coreNode: ICoreNode = createCoreNode();
let node: Node = new Node(coreNode);
expect(() => { node.makeFull(null); }).toThrowError(Error);
});
});
describe("Node.dispose", () => {
it("should clear core and fill properties", () => {
let coreNode: ICoreNode = createCoreNode();
let node: Node = new Node(coreNode);
let fillNode: IFillNode = createFillNode();
node.makeFull(fillNode);
node.dispose();
expect(node.full).toBe(false);
expect(() => { return node.key; }).toThrowError(Error);
});
it("should dipose cache", () => {
let coreNode: ICoreNode = createCoreNode();
let node: Node = new Node(coreNode);
let nodeCache: NodeCache = new NodeCache();
let disposeSpy: jasmine.Spy = spyOn(nodeCache, "dispose");
disposeSpy.and.stub();
node.initializeCache(nodeCache);
node.dispose();
expect(disposeSpy.calls.count()).toBe(1);
});
});
describe("Node.fullPano", () => {
it("should not be a full pano when gpano does not exist", () => {
let coreNode: ICoreNode = createCoreNode();
let node: Node = new Node(coreNode);
let fillNode: IFillNode = createFillNode();
fillNode.gpano = null;
node.makeFull(fillNode);
expect(node.fullPano).toBe(false);
});
it("should not be full pano when cropped left", () => {
let coreNode: ICoreNode = createCoreNode();
let node: Node = new Node(coreNode);
let fillNode: IFillNode = createFillNode();
fillNode.gpano = {
CroppedAreaImageHeightPixels: 1,
CroppedAreaImageWidthPixels: 1,
CroppedAreaLeftPixels: 0.5,
CroppedAreaTopPixels: 0,
FullPanoHeightPixels: 1,
FullPanoWidthPixels: 1,
};
node.makeFull(fillNode);
expect(node.fullPano).toBe(false);
});
it("should not be full pano when cropped top", () => {
let coreNode: ICoreNode = createCoreNode();
let node: Node = new Node(coreNode);
let fillNode: IFillNode = createFillNode();
fillNode.gpano = {
CroppedAreaImageHeightPixels: 1,
CroppedAreaImageWidthPixels: 1,
CroppedAreaLeftPixels: 0,
CroppedAreaTopPixels: 0.5,
FullPanoHeightPixels: 1,
FullPanoWidthPixels: 1,
};
node.makeFull(fillNode);
expect(node.fullPano).toBe(false);
});
it("should not be full pano when cropped right", () => {
let coreNode: ICoreNode = createCoreNode();
let node: Node = new Node(coreNode);
let fillNode: IFillNode = createFillNode();
fillNode.gpano = {
CroppedAreaImageHeightPixels: 1,
CroppedAreaImageWidthPixels: 0.5,
CroppedAreaLeftPixels: 0,
CroppedAreaTopPixels: 0,
FullPanoHeightPixels: 1,
FullPanoWidthPixels: 1,
};
node.makeFull(fillNode);
expect(node.fullPano).toBe(false);
});
it("should not be full pano when cropped bottom", () => {
let coreNode: ICoreNode = createCoreNode();
let node: Node = new Node(coreNode);
let fillNode: IFillNode = createFillNode();
fillNode.gpano = {
CroppedAreaImageHeightPixels: 0.5,
CroppedAreaImageWidthPixels: 1,
CroppedAreaLeftPixels: 0,
CroppedAreaTopPixels: 0,
FullPanoHeightPixels: 1,
FullPanoWidthPixels: 1,
};
node.makeFull(fillNode);
expect(node.fullPano).toBe(false);
});
it("should be full pano", () => {
let coreNode: ICoreNode = createCoreNode();
let node: Node = new Node(coreNode);
let fillNode: IFillNode = createFillNode();
fillNode.gpano = {
CroppedAreaImageHeightPixels: 1,
CroppedAreaImageWidthPixels: 1,
CroppedAreaLeftPixels: 0,
CroppedAreaTopPixels: 0,
FullPanoHeightPixels: 1,
FullPanoWidthPixels: 1,
};
node.makeFull(fillNode);
expect(node.fullPano).toBe(true);
});
});
describe("Node.pano", () => {
it("should not be a pano when gpano does not exist", () => {
let coreNode: ICoreNode = createCoreNode();
let node: Node = new Node(coreNode);
let fillNode: IFillNode = createFillNode();
fillNode.gpano = null;
node.makeFull(fillNode);
expect(node.pano).toBe(false);
});
it("should be a pano", () => {
let coreNode: ICoreNode = createCoreNode();
let node: Node = new Node(coreNode);
let fillNode: IFillNode = createFillNode();
fillNode.gpano = {
CroppedAreaImageHeightPixels: 0.5,
CroppedAreaImageWidthPixels: 0.5,
CroppedAreaLeftPixels: 0.25,
CroppedAreaTopPixels: 0.25,
FullPanoHeightPixels: 1,
FullPanoWidthPixels: 1,
};
node.makeFull(fillNode);
expect(node.pano).toBe(true);
});
});
describe("Node.merged", () => {
it("should not be merged when not full", () => {
let coreNode: ICoreNode = createCoreNode();
let node: Node = new Node(coreNode);
expect(node.merged).toBe(false);
});
it("should not be merged because merge version is zero", () => {
let coreNode: ICoreNode = createCoreNode();
let node: Node = new Node(coreNode);
let fillNode: IFillNode = createFillNode();
fillNode.merge_version = 0;
node.makeFull(fillNode);
expect(node.merged).toBe(false);
});
it("should be merged because merge version present and larger than zero", () => {
let coreNode: ICoreNode = createCoreNode();
let node: Node = new Node(coreNode);
let fillNode: IFillNode = createFillNode();
fillNode.merge_version = 7;
node.makeFull(fillNode);
expect(node.merged).toBe(true);
});
});
describe("Node.assetsCached", () => {
it("should not be cached when core", () => {
let coreNode: ICoreNode = createCoreNode();
let node: Node = new Node(coreNode);
expect(node.assetsCached).toBe(false);
});
class NodeCacheMock extends NodeCache {
protected _overridingImage: HTMLImageElement;
protected _overridingMesh: IMesh;
public get image(): HTMLImageElement {
return this._overridingImage;
}
public set image(value: HTMLImageElement) {
this._overridingImage = value;
}
public get mesh(): IMesh {
return this._overridingMesh;
}
public set mesh(value: IMesh) {
this._overridingMesh = value;
}
}
it("should be cached when assets set", () => {
let coreNode: ICoreNode = createCoreNode();
let node: Node = new Node(coreNode);
let fillNode: IFillNode = createFillNode();
node.makeFull(fillNode);
let nodeCache: NodeCacheMock = new NodeCacheMock();
nodeCache.image = new Image();
nodeCache.mesh = { faces: [], vertices: [] };
node.initializeCache(nodeCache);
expect(node.assetsCached).toBe(true);
});
});