mirror of
				https://github.com/mermaid-js/mermaid.git
				synced 2025-10-25 17:04:19 +02:00 
			
		
		
		
	 595f7680e9
			
		
	
	595f7680e9
	
	
	
		
			
			The if-check for arrowMarkerAbsolute in the flowchart-v2 code is in dagre-wrapper. Unfortunately, I can't seem to find a way to find the local conf (e.g. the one set via `flowRenderer.setConf()`, so instead I'm using global mermaid config from `src/config`. Flowchart v1 arrowMarkerAbsolute=true is still broken, but I'm not really sure how to fix that.
		
			
				
	
	
		
			130 lines
		
	
	
		
			3.6 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			130 lines
		
	
	
		
			3.6 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| import { renderGraph } from '../../helpers/util';
 | |
| describe('Configuration', () => {
 | |
|   describe('arrowMarkerAbsolute', () => {
 | |
|     it('should handle default value false of arrowMarkerAbsolute', () => {
 | |
|       renderGraph(
 | |
|         `graph TD
 | |
|         A[Christmas] -->|Get money| B(Go shopping)
 | |
|         B --> C{Let me think}
 | |
|         C -->|One| D[Laptop]
 | |
|         C -->|Two| E[iPhone]
 | |
|         C -->|Three| F[fa:fa-car Car]
 | |
|         `,
 | |
|         {}
 | |
|       );
 | |
| 
 | |
|       // Check the marker-end property to make sure it is properly set to
 | |
|       // start with #
 | |
|       cy.get('.edgePaths').within(() => {
 | |
|         cy.get('path')
 | |
|           .first()
 | |
|           .should('have.attr', 'marker-end')
 | |
|           .should('exist')
 | |
|           .and('include', 'url(#');
 | |
|       });
 | |
|     });
 | |
|     it('should handle default value false of arrowMarkerAbsolute', () => {
 | |
|       renderGraph(
 | |
|         `graph TD
 | |
|         A[Christmas] -->|Get money| B(Go shopping)
 | |
|         B --> C{Let me think}
 | |
|         C -->|One| D[Laptop]
 | |
|         C -->|Two| E[iPhone]
 | |
|         C -->|Three| F[fa:fa-car Car]
 | |
|         `,
 | |
|         {}
 | |
|       );
 | |
| 
 | |
|       // Check the marker-end property to make sure it is properly set to
 | |
|       // start with #
 | |
|       cy.get('.edgePaths').within(() => {
 | |
|         cy.get('path')
 | |
|           .first()
 | |
|           .should('have.attr', 'marker-end')
 | |
|           .should('exist')
 | |
|           .and('include', 'url(#');
 | |
|       });
 | |
|     });
 | |
|     it('should handle arrowMarkerAbsolute explicitly set to false', () => {
 | |
|       renderGraph(
 | |
|         `graph TD
 | |
|         A[Christmas] -->|Get money| B(Go shopping)
 | |
|         B --> C{Let me think}
 | |
|         C -->|One| D[Laptop]
 | |
|         C -->|Two| E[iPhone]
 | |
|         C -->|Three| F[fa:fa-car Car]
 | |
|         `,
 | |
|         {
 | |
|           arrowMarkerAbsolute: false,
 | |
|         }
 | |
|       );
 | |
| 
 | |
|       // Check the marker-end property to make sure it is properly set to
 | |
|       // start with #
 | |
|       cy.get('.edgePaths').within(() => {
 | |
|         cy.get('path')
 | |
|           .first()
 | |
|           .should('have.attr', 'marker-end')
 | |
|           .should('exist')
 | |
|           .and('include', 'url(#');
 | |
|       });
 | |
|     });
 | |
|     it('should handle arrowMarkerAbsolute explicitly set to "false" as false', () => {
 | |
|       renderGraph(
 | |
|         `graph TD
 | |
|         A[Christmas] -->|Get money| B(Go shopping)
 | |
|         B --> C{Let me think}
 | |
|         C -->|One| D[Laptop]
 | |
|         C -->|Two| E[iPhone]
 | |
|         C -->|Three| F[fa:fa-car Car]
 | |
|         `,
 | |
|         {
 | |
|           arrowMarkerAbsolute: 'false',
 | |
|         }
 | |
|       );
 | |
| 
 | |
|       // Check the marker-end property to make sure it is properly set to
 | |
|       // start with #
 | |
|       cy.get('.edgePaths').within(() => {
 | |
|         cy.get('path')
 | |
|           .first()
 | |
|           .should('have.attr', 'marker-end')
 | |
|           .should('exist')
 | |
|           .and('include', 'url(#');
 | |
|       });
 | |
|     });
 | |
|     it('should handle arrowMarkerAbsolute set to true', () => {
 | |
|       renderGraph(
 | |
|         `flowchart TD
 | |
|         A[Christmas] -->|Get money| B(Go shopping)
 | |
|         B --> C{Let me think}
 | |
|         C -->|One| D[Laptop]
 | |
|         C -->|Two| E[iPhone]
 | |
|         C -->|Three| F[fa:fa-car Car]
 | |
|         `,
 | |
|         {
 | |
|           arrowMarkerAbsolute: true,
 | |
|         }
 | |
|       );
 | |
| 
 | |
|       cy.get('.edgePaths').within(() => {
 | |
|         cy.get('path')
 | |
|           .first()
 | |
|           .should('have.attr', 'marker-end')
 | |
|           .should('exist')
 | |
|           .and('include', 'url(http://localhost');
 | |
|       });
 | |
|     });
 | |
|     it('should not taint the initial configuration when using multiple directives', () => {
 | |
|       const url = 'http://localhost:9000/regression/issue-1874.html';
 | |
|       cy.viewport(1440, 1024);
 | |
|       cy.visit(url);
 | |
| 
 | |
|       cy.get('svg');
 | |
|       cy.matchImageSnapshot(
 | |
|         'configuration.spec-should-not-taint-initial-configuration-when-using-multiple-directives'
 | |
|       );
 | |
|     });
 | |
|   });
 | |
| });
 |