knsv/mermaid

View on GitHub
cypress/integration/rendering/block.spec.js

Summary

Maintainability
B
4 hrs
Test Coverage
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
      `,
      {}
    );
  });
});