mirror of
				https://github.com/mermaid-js/mermaid.git
				synced 2025-10-25 08:54:07 +02:00 
			
		
		
		
	
		
			
				
	
	
		
			139 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			139 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| const utf8ToB64 = (str) => {
 | |
|   return window.btoa(unescape(encodeURIComponent(str)));
 | |
| };
 | |
| 
 | |
| const batchId = 'mermid-batch' + new Date().getTime();
 | |
| 
 | |
| export const mermaidUrl = (graphStr, options, api) => {
 | |
|   const obj = {
 | |
|     code: graphStr,
 | |
|     mermaid: options,
 | |
|   };
 | |
|   const objStr = JSON.stringify(obj);
 | |
|   let url = 'http://localhost:9000/e2e.html?graph=' + utf8ToB64(objStr);
 | |
|   if (api) {
 | |
|     url = 'http://localhost:9000/xss.html?graph=' + graphStr;
 | |
|   }
 | |
| 
 | |
|   if (options.listUrl) {
 | |
|     cy.log(options.listId, ' ', url);
 | |
|   }
 | |
| 
 | |
|   return url;
 | |
| };
 | |
| 
 | |
| export const imgSnapshotTest = (graphStr, _options, api = false, validation) => {
 | |
|   cy.log(_options);
 | |
|   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';
 | |
|   }
 | |
|   const useAppli = Cypress.env('useAppli');
 | |
|   //const useAppli = false;
 | |
|   cy.log('Hello ' + useAppli ? 'Appli' : 'image-snapshot');
 | |
|   const name = (options.name || cy.state('runnable').fullTitle()).replace(/\s+/g, '-');
 | |
| 
 | |
|   if (useAppli) {
 | |
|     cy.log('Opening eyes ' + Cypress.spec.name + ' --- ' + name);
 | |
|     cy.eyesOpen({
 | |
|       appName: 'Mermaid',
 | |
|       testName: name,
 | |
|       batchName: Cypress.spec.name,
 | |
|       batchId: batchId + Cypress.spec.name,
 | |
|     });
 | |
|   }
 | |
| 
 | |
|   const url = mermaidUrl(graphStr, options, api);
 | |
| 
 | |
|   cy.visit(url);
 | |
|   if (validation) cy.get('svg').should(validation);
 | |
|   cy.get('svg');
 | |
|   // Default name to test title
 | |
| 
 | |
|   if (useAppli) {
 | |
|     cy.log('Check eyes' + Cypress.spec.name);
 | |
|     cy.eyesCheckWindow('Click!');
 | |
|     cy.log('Closing eyes: ' + Cypress.spec.name);
 | |
|     cy.eyesClose();
 | |
|   } else {
 | |
|     cy.matchImageSnapshot(name);
 | |
|   }
 | |
| };
 | |
| 
 | |
| export const urlSnapshotTest = (url, _options, api = false, validation) => {
 | |
|   cy.log(_options);
 | |
|   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';
 | |
|   }
 | |
|   const useAppli = Cypress.env('useAppli');
 | |
|   cy.log('Hello ' + useAppli ? 'Appli' : 'image-snapshot');
 | |
|   const name = (options.name || cy.state('runnable').fullTitle()).replace(/\s+/g, '-');
 | |
| 
 | |
|   if (useAppli) {
 | |
|     cy.log('Opening eyes 2' + Cypress.spec.name);
 | |
|     cy.eyesOpen({
 | |
|       appName: 'Mermaid',
 | |
|       testName: name,
 | |
|       batchName: Cypress.spec.name,
 | |
|       batchId: batchId + Cypress.spec.name,
 | |
|     });
 | |
|   }
 | |
| 
 | |
|   cy.visit(url);
 | |
|   if (validation) cy.get('svg').should(validation);
 | |
|   cy.get('body');
 | |
|   // Default name to test title
 | |
| 
 | |
|   if (useAppli) {
 | |
|     cy.log('Check eyes 2' + Cypress.spec.name);
 | |
|     cy.eyesCheckWindow('Click!');
 | |
|     cy.log('Closing eyes 2' + Cypress.spec.name);
 | |
|     cy.eyesClose();
 | |
|   } else {
 | |
|     cy.matchImageSnapshot(name);
 | |
|   }
 | |
| };
 | |
| 
 | |
| export const renderGraph = (graphStr, options, api) => {
 | |
|   const url = mermaidUrl(graphStr, options, api);
 | |
| 
 | |
|   cy.visit(url);
 | |
| };
 | 
