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.
449 lines
13 KiB
JavaScript
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);
|
|
});
|
|
});
|
|
});
|