mirror of
https://github.com/maputnik/editor.git
synced 2025-12-06 06:10:00 +00:00
This replaces PR: - #785 Before:  After:  This is based on the geocoder example in maplibre docs: https://maplibre.org/maplibre-gl-js/docs/examples/geocoder/
183 lines
5.3 KiB
TypeScript
183 lines
5.3 KiB
TypeScript
import { CypressHelper } from "@shellygo/cypress-test-utils";
|
|
import { Assertable, then } from "@shellygo/cypress-test-utils/assertable";
|
|
import MaputnikCypressHelper from "./maputnik-cypress-helper";
|
|
import ModalDriver from "./modal-driver";
|
|
const baseUrl = "http://localhost:8888/";
|
|
|
|
const styleFromWindow = (win: Window) => {
|
|
const styleId = win.localStorage.getItem("maputnik:latest_style");
|
|
const styleItem = win.localStorage.getItem(`maputnik:style:${styleId}`);
|
|
const obj = JSON.parse(styleItem || "");
|
|
return obj;
|
|
};
|
|
|
|
export class MaputnikAssertable<T> extends Assertable<T> {
|
|
shouldEqualToStoredStyle = () =>
|
|
then(
|
|
new CypressHelper().get.window().then((win) => {
|
|
const style = styleFromWindow(win);
|
|
then(this.chainable).shouldDeepNestedInclude(style);
|
|
})
|
|
);
|
|
}
|
|
|
|
export class MaputnikDriver {
|
|
private helper = new MaputnikCypressHelper();
|
|
private modalDriver = new ModalDriver();
|
|
|
|
public beforeAndAfter = () => {
|
|
beforeEach(() => {
|
|
this.given.setupMockBackedResponses();
|
|
this.when.setStyle("both");
|
|
});
|
|
};
|
|
|
|
public then = (chainable: Cypress.Chainable<any>) =>
|
|
new MaputnikAssertable(chainable);
|
|
|
|
public given = {
|
|
...this.helper.given,
|
|
setupMockBackedResponses: () => {
|
|
this.helper.given.interceptAndMockResponse({
|
|
method: "GET",
|
|
url: baseUrl + "example-style.json",
|
|
response: {
|
|
fixture: "example-style.json",
|
|
},
|
|
alias: "example-style.json",
|
|
});
|
|
this.helper.given.interceptAndMockResponse({
|
|
method: "GET",
|
|
url: baseUrl + "example-layer-style.json",
|
|
response: {
|
|
fixture: "example-layer-style.json",
|
|
},
|
|
});
|
|
this.helper.given.interceptAndMockResponse({
|
|
method: "GET",
|
|
url: baseUrl + "geojson-style.json",
|
|
response: {
|
|
fixture: "geojson-style.json",
|
|
},
|
|
});
|
|
this.helper.given.interceptAndMockResponse({
|
|
method: "GET",
|
|
url: baseUrl + "raster-style.json",
|
|
response: {
|
|
fixture: "raster-style.json",
|
|
},
|
|
});
|
|
this.helper.given.interceptAndMockResponse({
|
|
method: "GET",
|
|
url: baseUrl + "geojson-raster-style.json",
|
|
response: {
|
|
fixture: "geojson-raster-style.json",
|
|
},
|
|
});
|
|
this.helper.given.interceptAndMockResponse({
|
|
method: "GET",
|
|
url: "*example.local/*",
|
|
response: [],
|
|
});
|
|
this.helper.given.interceptAndMockResponse({
|
|
method: "GET",
|
|
url: "*example.com/*",
|
|
response: [],
|
|
});
|
|
},
|
|
};
|
|
|
|
public when = {
|
|
...this.helper.when,
|
|
modal: this.modalDriver.when,
|
|
within: (selector: string, fn: () => void) => {
|
|
this.helper.when.within(fn, selector);
|
|
},
|
|
tab: () => this.helper.get.element("body").tab(),
|
|
waitForExampleFileResponse: () => {
|
|
this.helper.when.waitForResponse("example-style.json");
|
|
},
|
|
chooseExampleFile: () => {
|
|
this.helper.get
|
|
.bySelector("type", "file")
|
|
.selectFile("cypress/fixtures/example-style.json", { force: true });
|
|
},
|
|
setStyle: (
|
|
styleProperties: "geojson" | "raster" | "both" | "layer" | "",
|
|
zoom?: number
|
|
) => {
|
|
let url = "?debug";
|
|
switch (styleProperties) {
|
|
case "geojson":
|
|
url += `&style=${baseUrl}geojson-style.json`;
|
|
break;
|
|
case "raster":
|
|
url += `&style=${baseUrl}raster-style.json`;
|
|
break;
|
|
case "both":
|
|
url += `&style=${baseUrl}geojson-raster-style.json`;
|
|
break;
|
|
case "layer":
|
|
url += `&style=${baseUrl}/example-layer-style.json`;
|
|
break;
|
|
}
|
|
if (zoom) {
|
|
url += `#${zoom}/41.3805/2.1635`;
|
|
}
|
|
this.helper.when.visit(baseUrl + url);
|
|
if (styleProperties) {
|
|
this.helper.when.acceptConfirm();
|
|
}
|
|
// when methods should not include assertions
|
|
this.helper.get.elementByTestId("toolbar:link").should("be.visible");
|
|
},
|
|
|
|
typeKeys: (keys: string) => this.helper.get.element("body").type(keys),
|
|
|
|
clickZoomIn: () => {
|
|
this.helper.get.element(".maplibregl-ctrl-zoom-in").click();
|
|
},
|
|
|
|
selectWithin: (selector: string, value: string) => {
|
|
this.when.within(selector, () => {
|
|
this.helper.get.element("select").select(value);
|
|
});
|
|
},
|
|
|
|
select: (selector: string, value: string) => {
|
|
this.helper.get.elementByTestId(selector).select(value);
|
|
},
|
|
|
|
focus: (selector: string) => {
|
|
this.helper.when.focus(selector);
|
|
},
|
|
|
|
setValue: (selector: string, text: string) => {
|
|
this.helper.get
|
|
.elementByTestId(selector)
|
|
.clear()
|
|
.type(text, { parseSpecialCharSequences: false });
|
|
},
|
|
};
|
|
|
|
public get = {
|
|
...this.helper.get,
|
|
isMac: () => {
|
|
return Cypress.platform === "darwin";
|
|
},
|
|
|
|
styleFromLocalStorage: () =>
|
|
this.helper.get.window().then((win) => styleFromWindow(win)),
|
|
|
|
exampleFileUrl: () => {
|
|
return baseUrl + "example-style.json";
|
|
},
|
|
skipTargetLayerList: () =>
|
|
this.helper.get.elementByTestId("skip-target-layer-list"),
|
|
skipTargetLayerEditor: () =>
|
|
this.helper.get.elementByTestId("skip-target-layer-editor"),
|
|
canvas: () => this.helper.get.element("canvas"),
|
|
searchControl: () => this.helper.get.element('.maplibregl-ctrl-geocoder')
|
|
};
|
|
}
|