import { imgSnapshotTest } from '../../helpers/util'; /* eslint-disable no-useless-escape */ describe('Block diagram', () => { it('BL1: should calculate the block widths', () => { imgSnapshotTest( `block-beta columns 2 block id2["I am a wide one"] id1 end id["Next row"] ` ); }); it('BL2: should handle colums statement in sub-blocks', () => { imgSnapshotTest( `block-beta id1["Hello"] block columns 3 id2["to"] id3["the"] id4["World"] id5["World"] end `, {} ); }); it('BL3: should align block widths and handle colums statement in sub-blocks', () => { imgSnapshotTest( `block-beta block columns 1 id1 id2 id2.1 end id3 id4 `, {} ); }); it('BL4: should align block widths and handle colums statements in deeper sub-blocks then 1 level', () => { imgSnapshotTest( `block-beta columns 1 block columns 1 block columns 3 id1 id2 id2.1(("XYZ")) end id48 end id3 `, {} ); }); it('BL5: should align block widths and handle colums statements in deeper sub-blocks then 1 level (alt)', () => { imgSnapshotTest( `block-beta columns 1 block id1 id2 block columns 1 id3("Wider then") id5(("id5")) end end id4 `, {} ); }); it('BL6: should handle block arrows and spece statements', () => { imgSnapshotTest( `block-beta columns 3 space:3 ida idb idc id1 id2 blockArrowId<["Label"]>(right) blockArrowId2<["Label"]>(left) blockArrowId3<["Label"]>(up) blockArrowId4<["Label"]>(down) blockArrowId5<["Label"]>(x) blockArrowId6<["Label"]>(y) blockArrowId6<["Label"]>(x, down) `, {} ); }); it('BL7: should handle different types of edges', () => { imgSnapshotTest( `block-beta columns 3 A space:5 A --o B A --> C A --x D `, {} ); }); it('BL8: should handle sub-blocks without columns statements', () => { imgSnapshotTest( `block-beta columns 2 C A B block D E end `, {} ); }); it('BL9: should handle edges from blocks in sub blocks to other blocks', () => { imgSnapshotTest( `block-beta columns 3 B space block D end D --> B `, {} ); }); it('BL10: should handle edges from composite blocks', () => { imgSnapshotTest( `block-beta columns 3 B space block BL D end BL --> B `, {} ); }); it('BL11: should handle edges to composite blocks', () => { imgSnapshotTest( `block-beta columns 3 B space block BL D end B --> BL `, {} ); }); it('BL12: edges should handle labels', () => { imgSnapshotTest( `block-beta A space A -- "apa" --> E `, {} ); }); it('BL13: should handle block arrows in different directions', () => { imgSnapshotTest( `block-beta columns 3 space blockArrowId1<["down"]>(down) space blockArrowId2<["right"]>(right) blockArrowId3<["Sync"]>(x, y) blockArrowId4<["left"]>(left) space blockArrowId5<["up"]>(up) space blockArrowId6<["x"]>(x) space blockArrowId7<["y"]>(y) `, {} ); }); it('BL14: should style statements and class statements', () => { imgSnapshotTest( `block-beta A B classDef blue fill:#66f,stroke:#333,stroke-width:2px; class A blue style B fill:#f9F,stroke:#333,stroke-width:4px `, {} ); }); it('BL15: width alignment - D and E should share available space', () => { imgSnapshotTest( `block-beta block D E end db("This is the text in the box") `, {} ); }); it('BL16: width alignment - C should be as wide as the composite block', () => { imgSnapshotTest( `block-beta block A("This is the text") B end C `, {} ); }); it('BL16: width alignment - blocks shold be equal in width', () => { imgSnapshotTest( `block-beta A("This is the text") B C `, {} ); }); it('BL17: block types 1 - square, rounded and circle', () => { imgSnapshotTest( `block-beta A["square"] B("rounded") C(("circle")) `, {} ); }); it('BL18: block types 2 - odd, diamond and hexagon', () => { imgSnapshotTest( `block-beta A>"rect_left_inv_arrow"] B{"diamond"} C{{"hexagon"}} `, {} ); }); it('BL19: block types 3 - stadium', () => { imgSnapshotTest( `block-beta A(["stadium"]) `, {} ); }); it('BL20: block types 4 - lean right, lean left, trapezoid and inv trapezoid', () => { imgSnapshotTest( `block-beta A[/"lean right"/] B[\"lean left"\] C[/"trapezoid"\] D[\"trapezoid alt"/] `, {} ); }); it('BL21: block types 1 - square, rounded and circle', () => { imgSnapshotTest( `block-beta A["square"] B("rounded") C(("circle")) `, {} ); }); it('BL22: sizing - it should be possible to make a block wider', () => { imgSnapshotTest( `block-beta A("rounded"):2 B:2 C `, {} ); }); it('BL23: sizing - it should be possible to make a composite block wider', () => { imgSnapshotTest( `block-beta block:2 A end B `, {} ); }); it('BL24: block in the middle with space on each side', () => { imgSnapshotTest( `block-beta columns 3 space middle["In the middle"] space `, {} ); }); it('BL25: space and an edge', () => { imgSnapshotTest( `block-beta columns 5 A space B A --x B `, {} ); }); it('BL26: block sizes for regular blocks', () => { imgSnapshotTest( `block-beta columns 3 a["A wide one"] b:2 c:2 d `, {} ); }); it('BL27: composite block with a set width - f should use the available space', () => { imgSnapshotTest( `block-beta columns 3 a:3 block:e:3 f end g `, {} ); }); it('BL23: composite block with a set width - f and g should split the available space', () => { imgSnapshotTest( `block-beta columns 3 a:3 block:e:3 f g end h i j `, {} ); }); });