2019-09-18 18:25:06 +02:00
|
|
|
import { Base64 } from 'js-base64';
|
2019-09-11 18:53:05 +02:00
|
|
|
|
|
|
|
export const mermaidUrl = (graphStr, options, api) => {
|
|
|
|
const obj = {
|
|
|
|
code: graphStr,
|
2021-11-18 19:17:00 +01:00
|
|
|
mermaid: options,
|
2019-09-18 18:25:06 +02:00
|
|
|
};
|
|
|
|
const objStr = JSON.stringify(obj);
|
|
|
|
let url = 'http://localhost:9000/e2e.html?graph=' + Base64.encodeURI(objStr);
|
2019-09-11 18:53:05 +02:00
|
|
|
if (api) {
|
2019-09-18 18:25:06 +02:00
|
|
|
url = 'http://localhost:9000/xss.html?graph=' + graphStr;
|
2019-09-11 18:53:05 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
if (options.listUrl) {
|
2019-09-18 18:25:06 +02:00
|
|
|
cy.log(options.listId, ' ', url);
|
2019-09-11 18:53:05 +02:00
|
|
|
}
|
|
|
|
|
2019-09-18 18:25:06 +02:00
|
|
|
return url;
|
|
|
|
};
|
2019-09-11 18:53:05 +02:00
|
|
|
|
2020-08-16 21:49:36 +02:00
|
|
|
export const imgSnapshotTest = (graphStr, _options, api) => {
|
2020-08-23 20:02:51 +02:00
|
|
|
cy.log(_options);
|
2020-08-16 21:49:36 +02:00
|
|
|
const options = Object.assign(_options);
|
|
|
|
if (!options.fontFamily) {
|
|
|
|
options.fontFamily = 'courier';
|
|
|
|
}
|
|
|
|
if (!options.sequence) {
|
|
|
|
options.sequence = {};
|
|
|
|
}
|
|
|
|
if (!options.sequence || (options.sequence && !options.sequence.actorFontFamily)) {
|
|
|
|
options.sequence.actorFontFamily = 'courier';
|
|
|
|
}
|
|
|
|
if (options.sequence && !options.sequence.noteFontFamily) {
|
|
|
|
options.sequence.noteFontFamily = 'courier';
|
|
|
|
}
|
|
|
|
options.sequence.actorFontFamily = 'courier';
|
|
|
|
options.sequence.noteFontFamily = 'courier';
|
|
|
|
options.sequence.messageFontFamily = 'courier';
|
|
|
|
if (options.sequence && !options.sequence.actorFontFamily) {
|
|
|
|
options.sequence.actorFontFamily = 'courier';
|
|
|
|
}
|
|
|
|
if (!options.fontSize) {
|
|
|
|
options.fontSize = '16px';
|
|
|
|
}
|
2020-08-23 20:02:51 +02:00
|
|
|
cy.log(options);
|
2019-09-18 18:25:06 +02:00
|
|
|
const url = mermaidUrl(graphStr, options, api);
|
2019-09-11 18:53:05 +02:00
|
|
|
|
|
|
|
cy.visit(url);
|
2019-09-18 18:25:06 +02:00
|
|
|
cy.get('svg');
|
|
|
|
cy.percySnapshot();
|
|
|
|
};
|
2019-11-20 19:06:46 +01:00
|
|
|
|
|
|
|
export const renderGraph = (graphStr, options, api) => {
|
|
|
|
const url = mermaidUrl(graphStr, options, api);
|
|
|
|
|
|
|
|
cy.visit(url);
|
|
|
|
};
|