mirror of
				https://github.com/mermaid-js/mermaid.git
				synced 2025-10-25 00:44:10 +02:00 
			
		
		
		
	
		
			
				
	
	
		
			345 lines
		
	
	
		
			11 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			345 lines
		
	
	
		
			11 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| import { imgSnapshotTest, renderGraph } from '../../helpers/util.js';
 | |
| 
 | |
| describe('Gantt diagram', () => {
 | |
|   beforeEach(() => {
 | |
|     cy.clock(new Date('1010-10-10').getTime());
 | |
|   });
 | |
|   it('should render a gantt chart', () => {
 | |
|     imgSnapshotTest(
 | |
|       `
 | |
|     gantt
 | |
|       dateFormat  YYYY-MM-DD
 | |
|       axisFormat  %d/%m
 | |
|       title Adding GANTT diagram to mermaid
 | |
|       excludes weekdays 2014-01-10
 | |
| 
 | |
|       section A section
 | |
|       Completed task            :done,    des1, 2014-01-06,2014-01-08
 | |
|       Active task               :active,  des2, 2014-01-09, 3d
 | |
|       Future task               :         des3, after des2, 5d
 | |
|       Future task2               :         des4, after des3, 5d
 | |
| 
 | |
|       section Critical tasks
 | |
|       Completed task in the critical line :crit, done, 2014-01-06,24h
 | |
|       Implement parser and jison :crit, done, after des1, 2d
 | |
|       Create tests for parser             :crit, active, 3d
 | |
|       Future task in critical line        :crit, 5d
 | |
|       Create tests for renderer           :2d
 | |
|       Add to mermaid                      :1d
 | |
| 
 | |
|       section Documentation
 | |
|       Describe gantt syntax               :active, a1, after des1, 3d
 | |
|       Add gantt diagram to demo page      :after a1  , 20h
 | |
|       Add another diagram to demo page    :doc1, after a1  , 48h
 | |
| 
 | |
|       section Last section
 | |
|       Describe gantt syntax               :after doc1, 3d
 | |
|       Add gantt diagram to demo page      : 20h
 | |
|       Add another diagram to demo page    : 48h
 | |
|       `,
 | |
|       {}
 | |
|     );
 | |
|   });
 | |
|   it('Handle multiline section titles with different line breaks', () => {
 | |
|     imgSnapshotTest(
 | |
|       `
 | |
|       gantt
 | |
|       dateFormat  YYYY-MM-DD
 | |
|       axisFormat  %d/%m
 | |
|       title       GANTT diagram with multiline section titles
 | |
|       excludes    weekdays 2014-01-10
 | |
| 
 | |
|       section A section<br>multiline
 | |
|       Completed task            : done,    des1, 2014-01-06,2014-01-08
 | |
|       Active task               : active,  des2, 2014-01-09, 3d
 | |
|       Future task               :          des3, after des2, 5d
 | |
|       Future task2              :          des4, after des3, 5d
 | |
| 
 | |
|       section Critical tasks<br/>multiline
 | |
|       Completed task in the critical line : crit, done, 2014-01-06, 24h
 | |
|       Implement parser and jison          : crit, done, after des1, 2d
 | |
|       Create tests for parser             : crit, active, 3d
 | |
|       Future task in critical line        : crit, 5d
 | |
|       Create tests for renderer           : 2d
 | |
|       Add to mermaid                      : 1d
 | |
| 
 | |
|       section Documentation<br />multiline
 | |
|       Describe gantt syntax               : active, a1, after des1, 3d
 | |
|       Add gantt diagram to demo page      : after a1, 20h
 | |
|       Add another diagram to demo page    : doc1, after a1, 48h
 | |
| 
 | |
|       section Last section<br	/>multiline
 | |
|       Describe gantt syntax               : after doc1, 3d
 | |
|       Add gantt diagram to demo page      : 20h
 | |
|       Add another diagram to demo page    : 48h
 | |
|       `,
 | |
|       {}
 | |
|     );
 | |
|   });
 | |
|   it('Multiple dependencies syntax', () => {
 | |
|     imgSnapshotTest(
 | |
|       `
 | |
|       gantt
 | |
|       dateFormat  YYYY-MM-DD
 | |
|       axisFormat  %d/%m
 | |
|       title Adding GANTT diagram to mermaid
 | |
|       excludes weekdays 2014-01-10
 | |
| 
 | |
|       apple :a, 2017-07-20, 1w
 | |
|       banana :crit, b, 2017-07-23, 1d
 | |
|       cherry :active, c, after b a, 1d
 | |
|       `,
 | |
|       {}
 | |
|     );
 | |
|   });
 | |
|   it('should render a gantt chart for issue #1060', () => {
 | |
|     imgSnapshotTest(
 | |
|       `
 | |
|       gantt
 | |
|       excludes weekdays 2017-01-10
 | |
|       title Projects Timeline
 | |
| 
 | |
|       section asdf
 | |
|           specs :done, :ps, 2019-05-10, 50d
 | |
|           Plasma      :pc, 2019-06-20, 60d
 | |
|           Rollup  :or, 2019-08-20, 50d
 | |
| 
 | |
|       section CEL
 | |
| 
 | |
|           plasma-chamber      :done, :pc, 2019-05-20, 60d
 | |
|           Plasma Implementation (Rust)      :por, 2019-06-20, 120d
 | |
|           Predicates (Atomic Swap)      :pred, 2019-07-20, 60d
 | |
| 
 | |
|       section DEX
 | |
| 
 | |
|           History zkSNARK  :hs, 2019-08-10, 40d
 | |
|           Exit           :vs, after hs, 60d
 | |
|           PredicateSpec          :ps, 2019-09-1, 20d
 | |
|           PlasmaIntegration     :pi, after ps,40d
 | |
| 
 | |
| 
 | |
|       section Events
 | |
| 
 | |
|       ETHBoston :done, :eb, 2019-09-08, 3d
 | |
|       DevCon :active, :dc, 2019-10-08, 3d
 | |
| 
 | |
|       section Plasma Calls & updates
 | |
|           OVM      :ovm, 2019-07-12, 120d
 | |
|       Plasma call 26 :pc26, 2019-08-21, 1d
 | |
|       Plasma call 27 :pc27, 2019-09-03, 1d
 | |
|       Plasma call 28 :pc28, 2019-09-17, 1d
 | |
|         `,
 | |
|       {}
 | |
|     );
 | |
|   });
 | |
| 
 | |
|   it('should hide today marker', () => {
 | |
|     imgSnapshotTest(
 | |
|       `
 | |
|       gantt
 | |
|         title Hide today marker (vertical line should not be visible)
 | |
|         dateFormat YYYY-MM-DD
 | |
|         axisFormat %d
 | |
|         todayMarker off
 | |
|         section Section1
 | |
|          Today: 1, -1h
 | |
|       `,
 | |
|       {}
 | |
|     );
 | |
|   });
 | |
| 
 | |
|   it('should style today marker', () => {
 | |
|     imgSnapshotTest(
 | |
|       `
 | |
|     gantt
 | |
|       title Style today marker (vertical line should be 5px wide and half-transparent blue)
 | |
|       dateFormat YYYY-MM-DD
 | |
|       axisFormat %d
 | |
|       todayMarker stroke-width:5px,stroke:#00f,opacity:0.5
 | |
|       section Section1
 | |
|        Today: 1, -1h
 | |
|       `,
 | |
|       {}
 | |
|     );
 | |
|   });
 | |
| 
 | |
|   it('should handle milliseconds', () => {
 | |
|     imgSnapshotTest(
 | |
|       `
 | |
|     gantt
 | |
|       title A Gantt Diagram
 | |
|       dateFormat x
 | |
|       axisFormat %L
 | |
|       section Section
 | |
|       A task           :a1, 0, 30ms
 | |
|       Another task     :after a1, 20ms
 | |
|       section Another
 | |
|       Another another task      :b1, 20, 12ms
 | |
|       Another another another task     :after b1, 24ms
 | |
|         `,
 | |
|       {}
 | |
|     );
 | |
|   });
 | |
| 
 | |
|   it('should render a gantt diagram when useMaxWidth is true (default)', () => {
 | |
|     renderGraph(
 | |
|       `
 | |
|     gantt
 | |
|       dateFormat  YYYY-MM-DD
 | |
|       axisFormat  %d/%m
 | |
|       title Adding GANTT diagram to mermaid
 | |
|       excludes weekdays 2014-01-10
 | |
| 
 | |
|       section A section
 | |
|       Completed task            :done,    des1, 2014-01-06,2014-01-08
 | |
|       Active task               :active,  des2, 2014-01-09, 3d
 | |
|       Future task               :         des3, after des2, 5d
 | |
|       Future task2               :         des4, after des3, 5d
 | |
| 
 | |
|       section Critical tasks
 | |
|       Completed task in the critical line :crit, done, 2014-01-06,24h
 | |
|       Implement parser and jison :crit, done, after des1, 2d
 | |
|       Create tests for parser             :crit, active, 3d
 | |
|       Future task in critical line        :crit, 5d
 | |
|       Create tests for renderer           :2d
 | |
|       Add to mermaid                      :1d
 | |
| 
 | |
|       section Documentation
 | |
|       Describe gantt syntax               :active, a1, after des1, 3d
 | |
|       Add gantt diagram to demo page      :after a1  , 20h
 | |
|       Add another diagram to demo page    :doc1, after a1  , 48h
 | |
| 
 | |
|       section Last section
 | |
|       Describe gantt syntax               :after doc1, 3d
 | |
|       Add gantt diagram to demo page      : 20h
 | |
|       Add another diagram to demo page    : 48h
 | |
|       `,
 | |
|       { gantt: { useMaxWidth: true } }
 | |
|     );
 | |
|     cy.get('svg').should((svg) => {
 | |
|       expect(svg).to.have.attr('width', '100%');
 | |
|       // expect(svg).to.have.attr('height');
 | |
|       // use within because the absolute value can be slightly different depending on the environment ±5%
 | |
|       // const height = parseFloat(svg.attr('height'));
 | |
|       // expect(height).to.be.within(484 * 0.95, 484 * 1.05);
 | |
|       const style = svg.attr('style');
 | |
|       expect(style).to.match(/^max-width: [\d.]+px;$/);
 | |
|       const maxWidthValue = parseFloat(style.match(/[\d.]+/g).join(''));
 | |
|       expect(maxWidthValue).to.be.within(984 * 0.95, 984 * 1.05);
 | |
|     });
 | |
|   });
 | |
| 
 | |
|   it('should render a gantt diagram when useMaxWidth is false', () => {
 | |
|     renderGraph(
 | |
|       `
 | |
|     gantt
 | |
|       dateFormat  YYYY-MM-DD
 | |
|       axisFormat  %d/%m
 | |
|       title Adding GANTT diagram to mermaid
 | |
|       excludes weekdays 2014-01-10
 | |
| 
 | |
|       section A section
 | |
|       Completed task            :done,    des1, 2014-01-06,2014-01-08
 | |
|       Active task               :active,  des2, 2014-01-09, 3d
 | |
|       Future task               :         des3, after des2, 5d
 | |
|       Future task2               :         des4, after des3, 5d
 | |
| 
 | |
|       section Critical tasks
 | |
|       Completed task in the critical line :crit, done, 2014-01-06,24h
 | |
|       Implement parser and jison :crit, done, after des1, 2d
 | |
|       Create tests for parser             :crit, active, 3d
 | |
|       Future task in critical line        :crit, 5d
 | |
|       Create tests for renderer           :2d
 | |
|       Add to mermaid                      :1d
 | |
| 
 | |
|       section Documentation
 | |
|       Describe gantt syntax               :active, a1, after des1, 3d
 | |
|       Add gantt diagram to demo page      :after a1  , 20h
 | |
|       Add another diagram to demo page    :doc1, after a1  , 48h
 | |
| 
 | |
|       section Last section
 | |
|       Describe gantt syntax               :after doc1, 3d
 | |
|       Add gantt diagram to demo page      : 20h
 | |
|       Add another diagram to demo page    : 48h
 | |
|       `,
 | |
|       { gantt: { useMaxWidth: false } }
 | |
|     );
 | |
|     cy.get('svg').should((svg) => {
 | |
|       // const height = parseFloat(svg.attr('height'));
 | |
|       const width = parseFloat(svg.attr('width'));
 | |
|       // use within because the absolute value can be slightly different depending on the environment ±5%
 | |
|       // expect(height).to.be.within(484 * 0.95, 484 * 1.05);
 | |
|       expect(width).to.be.within(984 * 0.95, 984 * 1.05);
 | |
|       expect(svg).to.not.have.attr('style');
 | |
|     });
 | |
|   });
 | |
|   it('should render a gantt diagram with data labels at the top when topAxis is true', () => {
 | |
|     imgSnapshotTest(
 | |
|       `
 | |
|     gantt
 | |
|       dateFormat  YYYY-MM-DD
 | |
|       axisFormat  %d/%m
 | |
|       title Adding GANTT diagram to mermaid
 | |
|       excludes weekdays 2014-01-10
 | |
| 
 | |
|       section A section
 | |
|       Completed task            :done,    des1, 2014-01-06,2014-01-08
 | |
|       Active task               :active,  des2, 2014-01-09, 3d
 | |
|       Future task               :         des3, after des2, 5d
 | |
|       Future task2               :         des4, after des3, 5d
 | |
| 
 | |
|       section Critical tasks
 | |
|       Completed task in the critical line :crit, done, 2014-01-06,24h
 | |
|       Implement parser and jison :crit, done, after des1, 2d
 | |
|       Create tests for parser             :crit, active, 3d
 | |
|       Future task in critical line        :crit, 5d
 | |
|       Create tests for renderer           :2d
 | |
|       Add to mermaid                      :1d
 | |
| 
 | |
|       section Documentation
 | |
|       Describe gantt syntax               :active, a1, after des1, 3d
 | |
|       Add gantt diagram to demo page      :after a1  , 20h
 | |
|       Add another diagram to demo page    :doc1, after a1  , 48h
 | |
| 
 | |
|       section Last section
 | |
|       Describe gantt syntax               :after doc1, 3d
 | |
|       Add gantt diagram to demo page      : 20h
 | |
|       Add another diagram to demo page    : 48h
 | |
|       `,
 | |
|       { gantt: { topAxis: true } }
 | |
|     );
 | |
|   });
 | |
| 
 | |
|   it('should render accessibility tags', function () {
 | |
|     const expectedTitle = 'Gantt Diagram';
 | |
|     const expectedAccDescription = 'Tasks for Q4';
 | |
|     renderGraph(
 | |
|       `
 | |
|       gantt
 | |
|       accTitle: ${expectedTitle}
 | |
|       accDescr: ${expectedAccDescription}
 | |
|       dateFormat  YYYY-MM-DD
 | |
|       section Section
 | |
|       A task :a1, 2014-01-01, 30d
 | |
|       `,
 | |
|       {}
 | |
|     );
 | |
|     cy.get('svg').should((svg) => {
 | |
|       const el = svg.get(0);
 | |
|       const children = Array.from(el.children);
 | |
| 
 | |
|       const titleEl = children.find(function (node) {
 | |
|         return node.tagName === 'title';
 | |
|       });
 | |
|       const descriptionEl = children.find(function (node) {
 | |
|         return node.tagName === 'desc';
 | |
|       });
 | |
| 
 | |
|       expect(titleEl).to.exist;
 | |
|       expect(titleEl.textContent).to.equal(expectedTitle);
 | |
|       expect(descriptionEl).to.exist;
 | |
|       expect(descriptionEl.textContent).to.equal(expectedAccDescription);
 | |
|     });
 | |
|   });
 | |
| });
 | 
