You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
Cesium-Prequel/Specs/Scene/MapboxStyleImageryProviderS...

449 lines
13 KiB
JavaScript

import { Math as CesiumMath } from "../../Source/Cesium.js";
import { Rectangle } from "../../Source/Cesium.js";
import { Request } from "../../Source/Cesium.js";
import { RequestScheduler } from "../../Source/Cesium.js";
import { Resource } from "../../Source/Cesium.js";
import { WebMercatorTilingScheme } from "../../Source/Cesium.js";
import { Imagery } from "../../Source/Cesium.js";
import { ImageryLayer } from "../../Source/Cesium.js";
import { ImageryProvider } from "../../Source/Cesium.js";
import { ImageryState } from "../../Source/Cesium.js";
import { MapboxStyleImageryProvider } from "../../Source/Cesium.js";
import pollToPromise from "../pollToPromise.js";
describe("Scene/MapboxStyleImageryProvider", function () {
beforeEach(function () {
RequestScheduler.clearForSpecs();
});
afterEach(function () {
Resource._Implementations.createImage =
Resource._DefaultImplementations.createImage;
});
it("conforms to ImageryProvider interface", function () {
expect(MapboxStyleImageryProvider).toConformToInterface(ImageryProvider);
});
it("requires the styleId to be specified", function () {
expect(function () {
return new MapboxStyleImageryProvider({ accessToken: "test-token" });
}).toThrowDeveloperError("styleId is required");
});
it("resolves readyPromise", function () {
var provider = new MapboxStyleImageryProvider({
accessToken: "test-token",
url: "made/up/mapbox/server/",
styleId: "test-id",
});
return provider.readyPromise.then(function (result) {
expect(result).toBe(true);
expect(provider.ready).toBe(true);
});
});
it("resolves readyPromise with Resource", function () {
var resource = new Resource({
url: "made/up/mapbox/server/",
});
var provider = new MapboxStyleImageryProvider({
accessToken: "test-token",
url: resource,
styleId: "test-id",
});
return provider.readyPromise.then(function (result) {
expect(result).toBe(true);
expect(provider.ready).toBe(true);
});
});
it("returns valid value for hasAlphaChannel", function () {
var provider = new MapboxStyleImageryProvider({
accessToken: "test-token",
url: "made/up/mapbox/server/",
styleId: "test-id",
});
return pollToPromise(function () {
return provider.ready;
}).then(function () {
expect(typeof provider.hasAlphaChannel).toBe("boolean");
});
});
it("supports a slash at the end of the URL", function () {
var provider = new MapboxStyleImageryProvider({
accessToken: "test-token",
url: "made/up/mapbox/server/",
styleId: "test-id",
});
return pollToPromise(function () {
return provider.ready;
}).then(function () {
spyOn(Resource._Implementations, "createImage").and.callFake(function (
request,
crossOrigin,
deferred
) {
expect(request.url).not.toContain("//");
// Just return any old image.
Resource._DefaultImplementations.createImage(
new Request({ url: "Data/Images/Red16x16.png" }),
crossOrigin,
deferred
);
});
return provider.requestImage(0, 0, 0).then(function (image) {
expect(Resource._Implementations.createImage).toHaveBeenCalled();
expect(image).toBeImageOrImageBitmap();
});
});
});
it("supports no slash at the endof the URL", function () {
var provider = new MapboxStyleImageryProvider({
accessToken: "test-token",
url: "made/up/mapbox/server",
styleId: "test-id",
});
return pollToPromise(function () {
return provider.ready;
}).then(function () {
spyOn(Resource._Implementations, "createImage").and.callFake(function (
request,
crossOrigin,
deferred
) {
expect(request.url).toContain("made/up/mapbox/server/");
// Just return any old image.
Resource._DefaultImplementations.createImage(
new Request({ url: "Data/Images/Red16x16.png" }),
crossOrigin,
deferred
);
});
return provider.requestImage(0, 0, 0).then(function (image) {
expect(Resource._Implementations.createImage).toHaveBeenCalled();
expect(image).toBeImageOrImageBitmap();
});
});
});
it("requestImage returns a promise for an image and loads it for cross-origin use", function () {
var provider = new MapboxStyleImageryProvider({
accessToken: "test-token",
url: "made/up/mapbox/server/",
styleId: "test-id",
});
expect(provider.url).toEqual(
"made/up/mapbox/server/mapbox/test-id/tiles/512/{z}/{x}/{y}?access_token=test-token"
);
return pollToPromise(function () {
return provider.ready;
}).then(function () {
expect(provider.tileWidth).toEqual(256);
expect(provider.tileHeight).toEqual(256);
expect(provider.maximumLevel).toBeUndefined();
expect(provider.tilingScheme).toBeInstanceOf(WebMercatorTilingScheme);
expect(provider.rectangle).toEqual(
new WebMercatorTilingScheme().rectangle
);
spyOn(Resource._Implementations, "createImage").and.callFake(function (
request,
crossOrigin,
deferred
) {
// Just return any old image.
Resource._DefaultImplementations.createImage(
new Request({ url: "Data/Images/Red16x16.png" }),
crossOrigin,
deferred
);
});
return provider.requestImage(0, 0, 0).then(function (image) {
expect(Resource._Implementations.createImage).toHaveBeenCalled();
expect(image).toBeImageOrImageBitmap();
});
});
});
it("rectangle passed to constructor does not affect tile numbering", function () {
var rectangle = new Rectangle(0.1, 0.2, 0.3, 0.4);
var provider = new MapboxStyleImageryProvider({
accessToken: "test-token",
url: "made/up/mapbox/server/",
styleId: "test-id",
rectangle: rectangle,
});
return pollToPromise(function () {
return provider.ready;
}).then(function () {
expect(provider.tileWidth).toEqual(256);
expect(provider.tileHeight).toEqual(256);
expect(provider.maximumLevel).toBeUndefined();
expect(provider.tilingScheme).toBeInstanceOf(WebMercatorTilingScheme);
expect(provider.rectangle).toEqualEpsilon(
rectangle,
CesiumMath.EPSILON14
);
expect(provider.tileDiscardPolicy).toBeUndefined();
spyOn(Resource._Implementations, "createImage").and.callFake(function (
request,
crossOrigin,
deferred
) {
expect(request.url).toContain("/0/0/0");
// Just return any old image.
Resource._DefaultImplementations.createImage(
new Request({ url: "Data/Images/Red16x16.png" }),
crossOrigin,
deferred
);
});
return provider.requestImage(0, 0, 0).then(function (image) {
expect(Resource._Implementations.createImage).toHaveBeenCalled();
expect(image).toBeImageOrImageBitmap();
});
});
});
it("uses maximumLevel passed to constructor", function () {
var provider = new MapboxStyleImageryProvider({
accessToken: "test-token",
url: "made/up/mapbox/server/",
styleId: "test-id",
maximumLevel: 5,
});
expect(provider.maximumLevel).toEqual(5);
});
it("uses minimumLevel passed to constructor", function () {
var provider = new MapboxStyleImageryProvider({
accessToken: "test-token",
url: "made/up/mapbox/server/",
styleId: "test-id",
minimumLevel: 1,
});
expect(provider.minimumLevel).toEqual(1);
});
it("when no credit is supplied, the provider adds a default credit", function () {
var provider = new MapboxStyleImageryProvider({
accessToken: "test-token",
url: "made/up/mapbox/server/",
styleId: "test-id",
});
expect(provider.credit).toBe(MapboxStyleImageryProvider._defaultCredit);
});
it("turns the supplied credit into a logo", function () {
var creditText = "Thanks to our awesome made up source of this imagery!";
var providerWithCredit = new MapboxStyleImageryProvider({
accessToken: "test-token",
url: "made/up/mapbox/server/",
styleId: "test-id",
credit: creditText,
});
expect(providerWithCredit.credit.html).toEqual(creditText);
});
it("raises error event when image cannot be loaded", function () {
var provider = new MapboxStyleImageryProvider({
accessToken: "test-token",
url: "made/up/mapbox/server/",
styleId: "test-id",
});
var layer = new ImageryLayer(provider);
var tries = 0;
provider.errorEvent.addEventListener(function (error) {
expect(error.timesRetried).toEqual(tries);
++tries;
if (tries < 3) {
error.retry = true;
}
setTimeout(function () {
RequestScheduler.update();
}, 1);
});
Resource._Implementations.createImage = function (
request,
crossOrigin,
deferred
) {
if (tries === 2) {
// Succeed after 2 tries
Resource._DefaultImplementations.createImage(
new Request({ url: "Data/Images/Red16x16.png" }),
crossOrigin,
deferred
);
} else {
// fail
setTimeout(function () {
deferred.reject();
}, 1);
}
};
return pollToPromise(function () {
return provider.ready;
}).then(function () {
var imagery = new Imagery(layer, 0, 0, 0);
imagery.addReference();
layer._requestImagery(imagery);
RequestScheduler.update();
return pollToPromise(function () {
return imagery.state === ImageryState.RECEIVED;
}).then(function () {
expect(imagery.image).toBeImageOrImageBitmap();
expect(tries).toEqual(2);
imagery.releaseReference();
});
});
});
it("contains specified url", function () {
var provider = new MapboxStyleImageryProvider({
accessToken: "test-token",
url: "http://fake.map.com",
styleId: "test-id",
});
return pollToPromise(function () {
return provider.ready;
}).then(function () {
spyOn(Resource._Implementations, "createImage").and.callFake(function (
request,
crossOrigin,
deferred
) {
expect(request.url).toContain("http://fake.map.com");
// Just return any old image.
Resource._DefaultImplementations.createImage(
new Request({ url: "Data/Images/Red16x16.png" }),
crossOrigin,
deferred
);
});
return provider.requestImage(0, 0, 0);
});
});
it("contains specified username", function () {
var provider = new MapboxStyleImageryProvider({
accessToken: "test-token",
styleId: "test-id",
username: "fakeUsername",
});
return pollToPromise(function () {
return provider.ready;
}).then(function () {
spyOn(Resource._Implementations, "createImage").and.callFake(function (
request,
crossOrigin,
deferred
) {
expect(request.url).toContain(
"https://api.mapbox.com/styles/v1/fakeUsername"
);
// Just return any old image.
Resource._DefaultImplementations.createImage(
new Request({ url: "Data/Images/Red16x16.png" }),
crossOrigin,
deferred
);
});
return provider.requestImage(0, 0, 0);
});
});
it("contains specified tilesize", function () {
var provider = new MapboxStyleImageryProvider({
accessToken: "test-token",
styleId: "test-id",
tilesize: 256,
});
return pollToPromise(function () {
return provider.ready;
}).then(function () {
spyOn(Resource._Implementations, "createImage").and.callFake(function (
request,
crossOrigin,
deferred
) {
expect(request.url).toContain(
"https://api.mapbox.com/styles/v1/mapbox/test-id/tiles/256"
);
// Just return any old image.
Resource._DefaultImplementations.createImage(
new Request({ url: "Data/Images/Red16x16.png" }),
crossOrigin,
deferred
);
});
return provider.requestImage(0, 0, 0);
});
});
it("enables @2x scale factor", function () {
var provider = new MapboxStyleImageryProvider({
accessToken: "test-token",
styleId: "test-id",
scaleFactor: true,
});
return pollToPromise(function () {
return provider.ready;
}).then(function () {
spyOn(Resource._Implementations, "createImage").and.callFake(function (
request,
crossOrigin,
deferred
) {
expect(request.url).toContain(
"https://api.mapbox.com/styles/v1/mapbox/test-id/tiles/512/0/0/0@2x"
);
// Just return any old image.
Resource._DefaultImplementations.createImage(
new Request({ url: "Data/Images/Red16x16.png" }),
crossOrigin,
deferred
);
});
return provider.requestImage(0, 0, 0);
});
});
});