mirror of
				https://github.com/mermaid-js/mermaid.git
				synced 2025-10-26 16:34:08 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			145 lines
		
	
	
		
			4.0 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			145 lines
		
	
	
		
			4.0 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| import { imgSnapshotTest, renderGraph } from '../../helpers/util.ts';
 | |
| 
 | |
| describe('Sankey Diagram', () => {
 | |
|   it('should render a simple example', () => {
 | |
|     imgSnapshotTest(
 | |
|       `
 | |
|       sankey-beta
 | |
|       
 | |
|       sourceNode,targetNode,10
 | |
|       `,
 | |
|       {}
 | |
|     );
 | |
|   });
 | |
| 
 | |
|   describe('when given a linkColor', function () {
 | |
|     this.beforeAll(() => {
 | |
|       cy.wrap(
 | |
|         `sankey-beta
 | |
|       a,b,10
 | |
|       `
 | |
|       ).as('graph');
 | |
|     });
 | |
| 
 | |
|     it('links should use hex color', function () {
 | |
|       renderGraph(this.graph, { sankey: { linkColor: '#636465' } });
 | |
| 
 | |
|       cy.get('.link path').should((link) => {
 | |
|         expect(link.attr('stroke')).to.equal('#636465');
 | |
|       });
 | |
|     });
 | |
| 
 | |
|     it('links should be the same color as source node', function () {
 | |
|       renderGraph(this.graph, { sankey: { linkColor: 'source' } });
 | |
| 
 | |
|       cy.get('.link path').then((link) => {
 | |
|         cy.get('.node[id="node-1"] rect').should((node) =>
 | |
|           expect(link.attr('stroke')).to.equal(node.attr('fill'))
 | |
|         );
 | |
|       });
 | |
|     });
 | |
| 
 | |
|     it('links should be the same color as target node', function () {
 | |
|       renderGraph(this.graph, { sankey: { linkColor: 'target' } });
 | |
| 
 | |
|       cy.get('.link path').then((link) => {
 | |
|         cy.get('.node[id="node-2"] rect').should((node) =>
 | |
|           expect(link.attr('stroke')).to.equal(node.attr('fill'))
 | |
|         );
 | |
|       });
 | |
|     });
 | |
| 
 | |
|     it('links must be gradient', function () {
 | |
|       renderGraph(this.graph, { sankey: { linkColor: 'gradient' } });
 | |
| 
 | |
|       cy.get('.link path').should((link) => {
 | |
|         expect(link.attr('stroke')).to.equal('url(#linearGradient-3)');
 | |
|       });
 | |
|     });
 | |
|   });
 | |
| 
 | |
|   describe('when given a nodeAlignment', function () {
 | |
|     this.beforeAll(() => {
 | |
|       cy.wrap(
 | |
|         `
 | |
|         sankey-beta
 | |
|         
 | |
|         a,b,8
 | |
|         b,c,8
 | |
|         c,d,8
 | |
|         d,e,8
 | |
|         
 | |
|         x,c,4
 | |
|         c,y,4  
 | |
|         `
 | |
|       ).as('graph');
 | |
|     });
 | |
| 
 | |
|     this.afterEach(() => {
 | |
|       cy.get('.node[id="node-1"]').should((node) => {
 | |
|         expect(node.attr('x')).to.equal('0');
 | |
|       });
 | |
|       cy.get('.node[id="node-2"]').should((node) => {
 | |
|         expect(node.attr('x')).to.equal('100');
 | |
|       });
 | |
|       cy.get('.node[id="node-3"]').should((node) => {
 | |
|         expect(node.attr('x')).to.equal('200');
 | |
|       });
 | |
|       cy.get('.node[id="node-4"]').should((node) => {
 | |
|         expect(node.attr('x')).to.equal('300');
 | |
|       });
 | |
|       cy.get('.node[id="node-5"]').should((node) => {
 | |
|         expect(node.attr('x')).to.equal('400');
 | |
|       });
 | |
|     });
 | |
| 
 | |
|     it('should justify nodes', function () {
 | |
|       renderGraph(this.graph, {
 | |
|         sankey: { nodeAlignment: 'justify', width: 410, useMaxWidth: false },
 | |
|       });
 | |
|       cy.get('.node[id="node-6"]').should((node) => {
 | |
|         expect(node.attr('x')).to.equal('0');
 | |
|       });
 | |
|       cy.get('.node[id="node-7"]').should((node) => {
 | |
|         expect(node.attr('x')).to.equal('400');
 | |
|       });
 | |
|     });
 | |
| 
 | |
|     it('should align nodes left', function () {
 | |
|       renderGraph(this.graph, {
 | |
|         sankey: { nodeAlignment: 'left', width: 410, useMaxWidth: false },
 | |
|       });
 | |
|       cy.get('.node[id="node-6"]').should((node) => {
 | |
|         expect(node.attr('x')).to.equal('0');
 | |
|       });
 | |
|       cy.get('.node[id="node-7"]').should((node) => {
 | |
|         expect(node.attr('x')).to.equal('300');
 | |
|       });
 | |
|     });
 | |
| 
 | |
|     it('should align nodes right', function () {
 | |
|       renderGraph(this.graph, {
 | |
|         sankey: { nodeAlignment: 'right', width: 410, useMaxWidth: false },
 | |
|       });
 | |
|       cy.get('.node[id="node-6"]').should((node) => {
 | |
|         expect(node.attr('x')).to.equal('100');
 | |
|       });
 | |
|       cy.get('.node[id="node-7"]').should((node) => {
 | |
|         expect(node.attr('x')).to.equal('400');
 | |
|       });
 | |
|     });
 | |
| 
 | |
|     it('should center nodes', function () {
 | |
|       renderGraph(this.graph, {
 | |
|         sankey: { nodeAlignment: 'center', width: 410, useMaxWidth: false },
 | |
|       });
 | |
|       cy.get('.node[id="node-6"]').should((node) => {
 | |
|         expect(node.attr('x')).to.equal('100');
 | |
|       });
 | |
|       cy.get('.node[id="node-7"]').should((node) => {
 | |
|         expect(node.attr('x')).to.equal('300');
 | |
|       });
 | |
|     });
 | |
|   });
 | |
| });
 | 
