2019-09-11 18:53:05 +02:00
|
|
|
/// <reference types="Cypress" />
|
|
|
|
|
2023-03-11 14:54:21 +01:00
|
|
|
import { imgSnapshotTest, renderGraph } from '../../helpers/util.js';
|
2019-09-11 18:53:05 +02:00
|
|
|
|
2019-12-21 20:39:32 +01:00
|
|
|
context('Sequence diagram', () => {
|
2023-01-05 15:40:40 +01:00
|
|
|
it('should render a sequence diagram with boxes', () => {
|
|
|
|
renderGraph(
|
|
|
|
`
|
|
|
|
sequenceDiagram
|
|
|
|
box LightGrey Alice and Bob
|
|
|
|
participant Alice
|
|
|
|
participant Bob
|
|
|
|
end
|
|
|
|
participant John as John<br/>Second Line
|
|
|
|
Alice ->> Bob: Hello Bob, how are you?
|
|
|
|
Bob-->>John: How about you John?
|
|
|
|
Bob--x Alice: I am good thanks!
|
|
|
|
Bob-x John: I am good thanks!
|
|
|
|
Note right of John: Bob thinks a long<br/>long time, so long<br/>that the text does<br/>not fit on a row.
|
|
|
|
Bob-->Alice: Checking with John...
|
|
|
|
alt either this
|
|
|
|
Alice->>John: Yes
|
|
|
|
else or this
|
|
|
|
Alice->>John: No
|
|
|
|
else or this will happen
|
|
|
|
Alice->John: Maybe
|
|
|
|
end
|
|
|
|
par this happens in parallel
|
|
|
|
Alice -->> Bob: Parallel message 1
|
|
|
|
and
|
|
|
|
Alice -->> John: Parallel message 2
|
|
|
|
end
|
|
|
|
`,
|
|
|
|
{ sequence: { useMaxWidth: false } }
|
|
|
|
);
|
|
|
|
cy.get('svg').should((svg) => {
|
|
|
|
const width = parseFloat(svg.attr('width'));
|
|
|
|
expect(width).to.be.within(830 * 0.95, 830 * 1.05);
|
|
|
|
expect(svg).to.not.have.attr('style');
|
|
|
|
});
|
|
|
|
});
|
2019-12-21 20:39:32 +01:00
|
|
|
it('should render a simple sequence diagram', () => {
|
2019-09-18 18:25:06 +02:00
|
|
|
imgSnapshotTest(
|
|
|
|
`
|
2019-09-11 18:53:05 +02:00
|
|
|
sequenceDiagram
|
|
|
|
participant Alice
|
|
|
|
participant Bob
|
|
|
|
participant John as John<br/>Second Line
|
|
|
|
Alice ->> Bob: Hello Bob, how are you?
|
|
|
|
Bob-->>John: How about you John?
|
|
|
|
Bob--x Alice: I am good thanks!
|
|
|
|
Bob-x John: I am good thanks!
|
|
|
|
Note right of John: Bob thinks a long<br/>long time, so long<br/>that the text does<br/>not fit on a row.
|
|
|
|
Bob-->Alice: Checking with John...
|
|
|
|
alt either this
|
|
|
|
Alice->>John: Yes
|
|
|
|
else or this
|
|
|
|
Alice->>John: No
|
|
|
|
else or this will happen
|
|
|
|
Alice->John: Maybe
|
|
|
|
end
|
|
|
|
par this happens in parallel
|
|
|
|
Alice -->> Bob: Parallel message 1
|
|
|
|
and
|
|
|
|
Alice -->> John: Parallel message 2
|
|
|
|
end
|
2019-09-18 18:25:06 +02:00
|
|
|
`,
|
2021-11-18 19:17:00 +01:00
|
|
|
{ sequence: { actorFontFamily: 'courier' } }
|
2019-09-18 18:25:06 +02:00
|
|
|
);
|
|
|
|
});
|
2019-12-21 20:39:32 +01:00
|
|
|
it('should handle different line breaks', () => {
|
|
|
|
imgSnapshotTest(
|
|
|
|
`
|
|
|
|
sequenceDiagram
|
|
|
|
participant 1 as multiline<br>using #lt;br#gt;
|
|
|
|
participant 2 as multiline<br/>using #lt;br/#gt;
|
|
|
|
participant 3 as multiline<br />using #lt;br /#gt;
|
2019-12-23 08:52:15 -08:00
|
|
|
participant 4 as multiline<br \t/>using #lt;br \t/#gt;
|
2019-12-21 20:39:32 +01:00
|
|
|
1->>2: multiline<br>using #lt;br#gt;
|
|
|
|
note right of 2: multiline<br>using #lt;br#gt;
|
|
|
|
2->>3: multiline<br/>using #lt;br/#gt;
|
|
|
|
note right of 3: multiline<br/>using #lt;br/#gt;
|
2019-12-23 08:52:15 -08:00
|
|
|
3->>4: multiline<br />using #lt;br /#gt;
|
|
|
|
note right of 4: multiline<br />using #lt;br /#gt;
|
|
|
|
4->>1: multiline<br />using #lt;br /#gt;
|
|
|
|
note right of 1: multiline<br \t/>using #lt;br \t/#gt;
|
2019-12-21 20:39:32 +01:00
|
|
|
`,
|
|
|
|
{}
|
|
|
|
);
|
|
|
|
});
|
2020-12-12 02:01:40 -05:00
|
|
|
it('should handle line breaks and wrap annotations', () => {
|
|
|
|
imgSnapshotTest(
|
|
|
|
`
|
|
|
|
sequenceDiagram
|
|
|
|
participant Alice
|
|
|
|
participant Bob
|
|
|
|
participant John as John<br/>Second Line
|
|
|
|
Alice ->> Bob: Hello Bob, how are you?
|
|
|
|
Bob-->>John: How about you John?
|
|
|
|
Note right of John: John thinks a long<br/>long time, so long<br/>that the text does<br/>not fit on a row.
|
|
|
|
Bob-->Alice: Checking with John...
|
|
|
|
Note over John:wrap: John looks like he's still thinking, so Bob prods him a bit.
|
|
|
|
Bob-x John: Hey John -<br/>we're still waiting to know<br/>how you're doing
|
|
|
|
Note over John:nowrap: John's trying hard not to break his train of thought.
|
|
|
|
Bob-x John:wrap: John! Are you still debating about how you're doing? How long does it take??
|
|
|
|
Note over John: After a few more moments, John<br/>finally snaps out of it.
|
|
|
|
`,
|
|
|
|
{}
|
|
|
|
);
|
2021-11-18 19:17:00 +01:00
|
|
|
});
|
2020-04-23 18:31:22 +03:00
|
|
|
it('should render loops with a slight margin', () => {
|
|
|
|
imgSnapshotTest(
|
|
|
|
`
|
|
|
|
sequenceDiagram
|
2022-06-27 12:29:50 +09:00
|
|
|
Alice->>Bob: Extremely utterly long line of longness which had previously overflown the actor box as it is much longer than what it should be
|
2020-04-23 18:31:22 +03:00
|
|
|
loop Loopy
|
|
|
|
Bob->>Alice: Pasten
|
|
|
|
end `,
|
2023-02-21 07:00:51 +01:00
|
|
|
{
|
|
|
|
sequence: {
|
|
|
|
wrap: true,
|
|
|
|
},
|
|
|
|
}
|
2020-04-23 18:31:22 +03:00
|
|
|
);
|
|
|
|
});
|
|
|
|
context('font settings', () => {
|
|
|
|
it('should render different note fonts when configured', () => {
|
|
|
|
imgSnapshotTest(
|
|
|
|
`
|
|
|
|
sequenceDiagram
|
|
|
|
Alice->>Bob: I'm short
|
|
|
|
note left of Alice: I should have bigger fonts
|
|
|
|
Bob->>Alice: Short as well
|
|
|
|
`,
|
|
|
|
{ sequence: { noteFontSize: 18, noteFontFamily: 'Arial' } }
|
|
|
|
);
|
|
|
|
});
|
|
|
|
it('should render different message fonts when configured', () => {
|
|
|
|
imgSnapshotTest(
|
|
|
|
`
|
|
|
|
sequenceDiagram
|
|
|
|
Alice->>Bob: I'm short
|
|
|
|
Bob->>Alice: Short as well
|
|
|
|
`,
|
|
|
|
{ sequence: { messageFontSize: 18, messageFontFamily: 'Arial' } }
|
|
|
|
);
|
|
|
|
});
|
|
|
|
it('should render different actor fonts when configured', () => {
|
|
|
|
imgSnapshotTest(
|
|
|
|
`
|
|
|
|
sequenceDiagram
|
|
|
|
Alice->>Bob: I'm short
|
|
|
|
Bob->>Alice: Short as well
|
|
|
|
`,
|
2020-08-16 21:49:36 +02:00
|
|
|
{ sequence: { actorFontSize: 18, actorFontFamily: 'times' } }
|
2020-04-23 18:31:22 +03:00
|
|
|
);
|
|
|
|
});
|
|
|
|
it('should render notes aligned to the left when configured', () => {
|
|
|
|
imgSnapshotTest(
|
|
|
|
`
|
|
|
|
sequenceDiagram
|
|
|
|
Alice->>Bob: I'm short
|
|
|
|
note left of Alice: I am left aligned
|
|
|
|
Bob->>Alice: Short as well
|
|
|
|
`,
|
|
|
|
{ sequence: { noteAlign: 'left' } }
|
|
|
|
);
|
|
|
|
});
|
Fix #3011: Support left- and right-alignment for multi-line messages and notes
Previously, messages and notes that had multiple lines (via `<br>`-tags) were only displayed correctly
when using the default `center` value for the `messageAlign` and `noteAlign` configuration options.
Using `left` or `right` for the alignment options caused the text to collapse and become illegible,
as outlined in issue #3011.
This comes as a side-effect from how the internal `valign` text-rendering option was configured for
messages and notes:
```js
// Example from `sequenceRenderer.js: drawMessage()`
textObj.anchor = conf.messageAlign;
textObj.valign = conf.messageAlign;
```
Both the `anchor` option (which controls left-right alignment) and the `valign` option (which controls
vertical top-down placement) were set to the same value, the user-provided `messageAlign` config option.
While `left` and `right` are valid values for the `anchor` option, they were effectively no-ops for the
`valign` option, which only supports `top`, `start`, `middle`, `center`, `bottom`, and `end`.
To fix the issue, the `valign` property is now always set to `center` for notes and messages.
Similarly, the `dominantBaseline` option of texts is now always set to `middle`, rather than setting it to
either `text-{before,after}-edge`, which caused left-aligned multi-line text to always be "top-left" aligned
inside a note (or "bottom-right" when attempting to right-align).
Now, texts in messages and notes are always vertically centered and alignment options correctly apply for
both single and multi-line content.
2022-07-03 11:41:18 +02:00
|
|
|
it('should render multi-line notes aligned to the left when configured', () => {
|
|
|
|
imgSnapshotTest(
|
|
|
|
`
|
|
|
|
sequenceDiagram
|
|
|
|
Alice->>Bob: I'm short
|
|
|
|
note left of Alice: I am left aligned<br>but also<br>multiline
|
|
|
|
Bob->>Alice: Short as well
|
|
|
|
`,
|
|
|
|
{ sequence: { noteAlign: 'left' } }
|
|
|
|
);
|
|
|
|
});
|
2020-04-23 18:31:22 +03:00
|
|
|
it('should render notes aligned to the right when configured', () => {
|
|
|
|
imgSnapshotTest(
|
|
|
|
`
|
|
|
|
sequenceDiagram
|
|
|
|
Alice->>Bob: I'm short
|
|
|
|
note left of Alice: I am right aligned
|
|
|
|
Bob->>Alice: Short as well
|
|
|
|
`,
|
|
|
|
{ sequence: { noteAlign: 'right' } }
|
|
|
|
);
|
|
|
|
});
|
Fix #3011: Support left- and right-alignment for multi-line messages and notes
Previously, messages and notes that had multiple lines (via `<br>`-tags) were only displayed correctly
when using the default `center` value for the `messageAlign` and `noteAlign` configuration options.
Using `left` or `right` for the alignment options caused the text to collapse and become illegible,
as outlined in issue #3011.
This comes as a side-effect from how the internal `valign` text-rendering option was configured for
messages and notes:
```js
// Example from `sequenceRenderer.js: drawMessage()`
textObj.anchor = conf.messageAlign;
textObj.valign = conf.messageAlign;
```
Both the `anchor` option (which controls left-right alignment) and the `valign` option (which controls
vertical top-down placement) were set to the same value, the user-provided `messageAlign` config option.
While `left` and `right` are valid values for the `anchor` option, they were effectively no-ops for the
`valign` option, which only supports `top`, `start`, `middle`, `center`, `bottom`, and `end`.
To fix the issue, the `valign` property is now always set to `center` for notes and messages.
Similarly, the `dominantBaseline` option of texts is now always set to `middle`, rather than setting it to
either `text-{before,after}-edge`, which caused left-aligned multi-line text to always be "top-left" aligned
inside a note (or "bottom-right" when attempting to right-align).
Now, texts in messages and notes are always vertically centered and alignment options correctly apply for
both single and multi-line content.
2022-07-03 11:41:18 +02:00
|
|
|
it('should render multi-line notes aligned to the right when configured', () => {
|
|
|
|
imgSnapshotTest(
|
|
|
|
`
|
|
|
|
sequenceDiagram
|
|
|
|
Alice->>Bob: I'm short
|
|
|
|
note left of Alice: I am right aligned<br>but also<br>multiline
|
|
|
|
Bob->>Alice: Short as well
|
|
|
|
`,
|
|
|
|
{ sequence: { noteAlign: 'right' } }
|
|
|
|
);
|
|
|
|
});
|
|
|
|
it('should render multi-line messages aligned to the left when configured', () => {
|
|
|
|
imgSnapshotTest(
|
|
|
|
`
|
|
|
|
sequenceDiagram
|
|
|
|
Alice->>Bob: I'm short<br>but also<br>multiline
|
|
|
|
Bob->>Alice: Short as well<br>and also<br>multiline
|
|
|
|
`,
|
|
|
|
{ sequence: { messageAlign: 'left' } }
|
|
|
|
);
|
|
|
|
});
|
|
|
|
it('should render multi-line messages aligned to the right when configured', () => {
|
|
|
|
imgSnapshotTest(
|
|
|
|
`
|
|
|
|
sequenceDiagram
|
|
|
|
Alice->>Bob: I'm short<br>but also<br>multiline
|
|
|
|
Bob->>Alice: Short as well<br>and also<br>multiline
|
|
|
|
`,
|
|
|
|
{ sequence: { messageAlign: 'right' } }
|
|
|
|
);
|
|
|
|
});
|
2020-04-23 18:31:22 +03:00
|
|
|
});
|
|
|
|
context('auth width scaling', () => {
|
|
|
|
it('should render long actor descriptions', () => {
|
|
|
|
imgSnapshotTest(
|
|
|
|
`
|
|
|
|
sequenceDiagram
|
2022-06-27 12:29:50 +09:00
|
|
|
participant A as Extremely utterly long line of longness which had previously overflown the actor box as it is much longer than what it should be
|
2020-04-23 18:31:22 +03:00
|
|
|
A->>Bob: Hola
|
|
|
|
Bob-->A: Pasten !
|
2020-06-17 05:54:24 -04:00
|
|
|
`,
|
2021-11-18 19:17:00 +01:00
|
|
|
{ logLevel: 0 }
|
2020-06-17 05:54:24 -04:00
|
|
|
);
|
|
|
|
});
|
2020-06-17 18:12:01 -04:00
|
|
|
it('should wrap (inline) long actor descriptions', () => {
|
|
|
|
imgSnapshotTest(
|
|
|
|
`
|
|
|
|
sequenceDiagram
|
2022-06-27 12:29:50 +09:00
|
|
|
participant A as wrap:Extremely utterly long line of longness which had previously overflown the actor box as it is much longer than what it should be
|
2020-06-17 18:12:01 -04:00
|
|
|
A->>Bob: Hola
|
|
|
|
Bob-->A: Pasten !
|
|
|
|
`,
|
2021-11-18 19:17:00 +01:00
|
|
|
{ logLevel: 0 }
|
2020-06-17 18:12:01 -04:00
|
|
|
);
|
|
|
|
});
|
|
|
|
it('should wrap (directive) long actor descriptions', () => {
|
2020-06-17 05:54:24 -04:00
|
|
|
imgSnapshotTest(
|
|
|
|
`
|
2020-06-26 09:26:56 -04:00
|
|
|
%%{init: {'config': {'wrap': true }}}%%
|
2020-06-17 05:54:24 -04:00
|
|
|
sequenceDiagram
|
2022-06-27 12:29:50 +09:00
|
|
|
participant A as Extremely utterly long line of longness which had previously overflown the actor box as it is much longer than what it should be
|
2020-06-17 05:54:24 -04:00
|
|
|
A->>Bob: Hola
|
|
|
|
Bob-->A: Pasten !
|
2020-04-23 18:31:22 +03:00
|
|
|
`,
|
|
|
|
{}
|
|
|
|
);
|
|
|
|
});
|
2021-09-18 07:51:15 +02:00
|
|
|
it('should be possible to use actor symbols instead of boxes', () => {
|
|
|
|
imgSnapshotTest(
|
|
|
|
`
|
|
|
|
sequenceDiagram
|
|
|
|
actor Alice
|
|
|
|
actor Bob
|
|
|
|
Alice->>Bob: Hi Bob
|
|
|
|
Bob->>Alice: Hi Alice
|
|
|
|
`,
|
|
|
|
{}
|
|
|
|
);
|
|
|
|
});
|
2020-04-23 18:31:22 +03:00
|
|
|
it('should render long notes left of actor', () => {
|
|
|
|
imgSnapshotTest(
|
|
|
|
`
|
|
|
|
sequenceDiagram
|
|
|
|
Alice->>Bob: Hola
|
2022-06-27 12:29:50 +09:00
|
|
|
Note left of Alice: Extremely utterly long line of longness which had previously overflown the actor box as it is much longer than what it should be
|
2020-04-23 18:31:22 +03:00
|
|
|
Bob->>Alice: I'm short though
|
|
|
|
`,
|
|
|
|
{}
|
|
|
|
);
|
|
|
|
});
|
2020-06-17 05:54:24 -04:00
|
|
|
it('should render long notes wrapped (inline) left of actor', () => {
|
|
|
|
imgSnapshotTest(
|
|
|
|
`
|
|
|
|
sequenceDiagram
|
|
|
|
Alice->>Bob: Hola
|
2022-06-27 12:29:50 +09:00
|
|
|
Note left of Alice:wrap: Extremely utterly long line of longness which had previously overflown the actor box as it is much longer than what it should be
|
2020-06-17 05:54:24 -04:00
|
|
|
Bob->>Alice: I'm short though
|
|
|
|
`,
|
|
|
|
{}
|
|
|
|
);
|
|
|
|
});
|
2020-04-23 18:31:22 +03:00
|
|
|
it('should render long notes right of actor', () => {
|
|
|
|
imgSnapshotTest(
|
|
|
|
`
|
|
|
|
sequenceDiagram
|
|
|
|
Alice->>Bob: Hola
|
2022-06-27 12:29:50 +09:00
|
|
|
Note right of Alice: Extremely utterly long line of longness which had previously overflown the actor box as it is much longer than what it should be
|
2020-04-23 18:31:22 +03:00
|
|
|
Bob->>Alice: I'm short though
|
|
|
|
`,
|
|
|
|
{}
|
|
|
|
);
|
|
|
|
});
|
2020-06-17 05:54:24 -04:00
|
|
|
it('should render long notes wrapped (inline) right of actor', () => {
|
|
|
|
imgSnapshotTest(
|
|
|
|
`
|
|
|
|
sequenceDiagram
|
|
|
|
Alice->>Bob: Hola
|
2022-06-27 12:29:50 +09:00
|
|
|
Note right of Alice:wrap: Extremely utterly long line of longness which had previously overflown the actor box as it is much longer than what it should be
|
2020-06-17 05:54:24 -04:00
|
|
|
Bob->>Alice: I'm short though
|
|
|
|
`,
|
|
|
|
{}
|
|
|
|
);
|
|
|
|
});
|
2020-04-23 18:31:22 +03:00
|
|
|
it('should render long notes over actor', () => {
|
|
|
|
imgSnapshotTest(
|
|
|
|
`
|
|
|
|
sequenceDiagram
|
|
|
|
Alice->>Bob: Hola
|
2022-06-27 12:29:50 +09:00
|
|
|
Note over Alice: Extremely utterly long line of longness which had previously overflown the actor box as it is much longer than what it should be
|
2020-04-23 18:31:22 +03:00
|
|
|
Bob->>Alice: I'm short though
|
|
|
|
`,
|
|
|
|
{}
|
|
|
|
);
|
|
|
|
});
|
2020-06-17 05:54:24 -04:00
|
|
|
it('should render long notes wrapped (inline) over actor', () => {
|
|
|
|
imgSnapshotTest(
|
|
|
|
`
|
|
|
|
sequenceDiagram
|
|
|
|
Alice->>Bob: Hola
|
2022-06-27 12:29:50 +09:00
|
|
|
Note over Alice:wrap: Extremely utterly long line of longness which had previously overflown the actor box as it is much longer than what it should be
|
2020-06-17 05:54:24 -04:00
|
|
|
Bob->>Alice: I'm short though
|
|
|
|
`,
|
|
|
|
{}
|
|
|
|
);
|
|
|
|
});
|
2020-04-23 18:31:22 +03:00
|
|
|
it('should render long messages from an actor to the left to one to the right', () => {
|
|
|
|
imgSnapshotTest(
|
|
|
|
`
|
|
|
|
sequenceDiagram
|
2022-06-27 12:29:50 +09:00
|
|
|
Alice->>Bob: Extremely utterly long line of longness which had previously overflown the actor box as it is much longer than what it should be
|
2020-04-23 18:31:22 +03:00
|
|
|
Bob->>Alice: I'm short though
|
|
|
|
`,
|
|
|
|
{}
|
|
|
|
);
|
|
|
|
});
|
2020-06-17 05:54:24 -04:00
|
|
|
it('should render long messages wrapped (inline) from an actor to the left to one to the right', () => {
|
|
|
|
imgSnapshotTest(
|
|
|
|
`
|
|
|
|
sequenceDiagram
|
2022-06-27 12:29:50 +09:00
|
|
|
Alice->>Bob:wrap:Extremely utterly long line of longness which had previously overflown the actor box as it is much longer than what it should be
|
2020-06-17 05:54:24 -04:00
|
|
|
Bob->>Alice: I'm short though
|
|
|
|
`,
|
|
|
|
{}
|
|
|
|
);
|
|
|
|
});
|
2020-04-23 18:31:22 +03:00
|
|
|
it('should render long messages from an actor to the right to one to the left', () => {
|
|
|
|
imgSnapshotTest(
|
|
|
|
`
|
|
|
|
sequenceDiagram
|
|
|
|
Alice->>Bob: I'm short
|
2022-06-27 12:29:50 +09:00
|
|
|
Bob->>Alice: Extremely utterly long line of longness which had previously overflown the actor box as it is much longer than what it should be
|
2020-04-23 18:31:22 +03:00
|
|
|
`,
|
|
|
|
{}
|
|
|
|
);
|
|
|
|
});
|
2020-06-17 05:54:24 -04:00
|
|
|
it('should render long messages wrapped (inline) from an actor to the right to one to the left', () => {
|
|
|
|
imgSnapshotTest(
|
|
|
|
`
|
|
|
|
sequenceDiagram
|
|
|
|
Alice->>Bob: I'm short
|
2022-06-27 12:29:50 +09:00
|
|
|
Bob->>Alice:wrap: Extremely utterly long line of longness which had previously overflown the actor box as it is much longer than what it should be
|
2020-06-17 05:54:24 -04:00
|
|
|
`,
|
|
|
|
{}
|
|
|
|
);
|
|
|
|
});
|
2020-04-23 18:31:22 +03:00
|
|
|
});
|
2019-09-11 18:53:05 +02:00
|
|
|
context('background rects', () => {
|
|
|
|
it('should render a single and nested rects', () => {
|
2019-09-18 18:25:06 +02:00
|
|
|
imgSnapshotTest(
|
|
|
|
`
|
2019-09-11 18:53:05 +02:00
|
|
|
sequenceDiagram
|
|
|
|
participant A
|
|
|
|
participant B
|
|
|
|
participant C
|
|
|
|
participant D
|
|
|
|
participant E
|
|
|
|
participant G
|
|
|
|
|
|
|
|
A ->>+ B: Task 1
|
|
|
|
rect rgb(178, 102, 255)
|
|
|
|
B ->>+ C: Task 2
|
|
|
|
C -->>- B: Return
|
|
|
|
end
|
|
|
|
|
|
|
|
A ->> D: Task 3
|
|
|
|
rect rgb(0, 128, 255)
|
|
|
|
D ->>+ E: Task 4
|
|
|
|
rect rgb(0, 204, 0)
|
|
|
|
E ->>+ G: Task 5
|
|
|
|
G -->>- E: Return
|
|
|
|
end
|
|
|
|
E ->> E: Task 6
|
|
|
|
end
|
|
|
|
D -->> A: Complete
|
2019-09-18 18:25:06 +02:00
|
|
|
`,
|
|
|
|
{}
|
|
|
|
);
|
|
|
|
});
|
2020-06-17 18:12:01 -04:00
|
|
|
it('should render a single and nested opt with long test overflowing', () => {
|
|
|
|
imgSnapshotTest(
|
|
|
|
`
|
|
|
|
sequenceDiagram
|
|
|
|
participant A
|
|
|
|
participant B
|
|
|
|
participant C
|
|
|
|
participant D
|
|
|
|
participant E
|
|
|
|
participant G
|
|
|
|
|
|
|
|
A ->>+ B: Task 1
|
|
|
|
opt this is an opt with a long title that will overflow
|
|
|
|
B ->>+ C: Task 2
|
|
|
|
C -->>- B: Return
|
|
|
|
end
|
|
|
|
|
|
|
|
A ->> D: Task 3
|
|
|
|
opt this is another opt with a long title that will overflow
|
|
|
|
D ->>+ E: Task 4
|
|
|
|
opt this is a nested opt with a long title that will overflow
|
|
|
|
E ->>+ G: Task 5
|
|
|
|
G -->>- E: Return
|
|
|
|
end
|
|
|
|
E ->> E: Task 6
|
|
|
|
end
|
|
|
|
D -->> A: Complete
|
|
|
|
`,
|
|
|
|
{}
|
|
|
|
);
|
|
|
|
});
|
|
|
|
it('should render a single and nested opt with long test wrapping', () => {
|
|
|
|
imgSnapshotTest(
|
|
|
|
`
|
2020-06-26 09:26:56 -04:00
|
|
|
%%{init: { 'config': { 'wrap': true } } }%%
|
2020-06-17 18:12:01 -04:00
|
|
|
sequenceDiagram
|
|
|
|
participant A
|
|
|
|
participant B
|
|
|
|
participant C
|
|
|
|
participant D
|
|
|
|
participant E
|
|
|
|
participant G
|
|
|
|
|
|
|
|
A ->>+ B: Task 1
|
|
|
|
opt this is an opt with a long title that will overflow
|
|
|
|
B ->>+ C: Task 2
|
|
|
|
C -->>- B: Return
|
|
|
|
end
|
|
|
|
|
|
|
|
A ->> D: Task 3
|
|
|
|
opt this is another opt with a long title that will overflow
|
|
|
|
D ->>+ E: Task 4
|
|
|
|
opt this is a nested opt with a long title that will overflow
|
|
|
|
E ->>+ G: Task 5
|
|
|
|
G -->>- E: Return
|
|
|
|
end
|
|
|
|
E ->> E: Task 6
|
|
|
|
end
|
|
|
|
D -->> A: Complete
|
|
|
|
`,
|
|
|
|
{}
|
|
|
|
);
|
|
|
|
});
|
2019-09-11 18:53:05 +02:00
|
|
|
it('should render rect around and inside loops', () => {
|
2019-09-18 18:25:06 +02:00
|
|
|
imgSnapshotTest(
|
|
|
|
`
|
2019-09-11 18:53:05 +02:00
|
|
|
sequenceDiagram
|
|
|
|
A ->> B: 1
|
|
|
|
rect rgb(204, 0, 102)
|
|
|
|
loop check C
|
|
|
|
C ->> C: Every 10 seconds
|
|
|
|
end
|
|
|
|
end
|
|
|
|
A ->> B: 2
|
|
|
|
loop check D
|
|
|
|
C ->> D: 3
|
|
|
|
rect rgb(153, 153, 255)
|
|
|
|
D -->> D: 5
|
|
|
|
D --> C: 4
|
|
|
|
end
|
|
|
|
end
|
2019-09-18 18:25:06 +02:00
|
|
|
`,
|
|
|
|
{}
|
|
|
|
);
|
|
|
|
});
|
2019-09-11 18:53:05 +02:00
|
|
|
it('should render rect around and inside alts', () => {
|
2019-09-18 18:25:06 +02:00
|
|
|
imgSnapshotTest(
|
|
|
|
`
|
2019-09-11 18:53:05 +02:00
|
|
|
sequenceDiagram
|
|
|
|
A ->> B: 1
|
|
|
|
rect rgb(204, 0, 102)
|
|
|
|
alt yes
|
|
|
|
C ->> C: 1
|
|
|
|
else no
|
|
|
|
rect rgb(0, 204, 204)
|
|
|
|
C ->> C: 0
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
B ->> A: Return
|
2019-09-18 18:25:06 +02:00
|
|
|
`,
|
|
|
|
{}
|
|
|
|
);
|
|
|
|
});
|
2019-09-11 18:53:05 +02:00
|
|
|
it('should render rect around and inside opts', () => {
|
2019-09-18 18:25:06 +02:00
|
|
|
imgSnapshotTest(
|
|
|
|
`
|
2019-09-11 18:53:05 +02:00
|
|
|
sequenceDiagram
|
|
|
|
A ->> B: 1
|
|
|
|
rect rgb(204, 0, 102)
|
|
|
|
opt maybe
|
|
|
|
C -->> D: Do something
|
|
|
|
rect rgb(0, 204, 204)
|
|
|
|
C ->> C: 0
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
opt possibly
|
|
|
|
rect rgb(0, 204, 204)
|
|
|
|
C ->> C: 0
|
|
|
|
end
|
|
|
|
end
|
|
|
|
B ->> A: Return
|
2019-09-18 18:25:06 +02:00
|
|
|
`,
|
|
|
|
{}
|
|
|
|
);
|
|
|
|
});
|
2022-05-21 09:31:06 +02:00
|
|
|
it('should render rect around and inside criticals', () => {
|
|
|
|
imgSnapshotTest(
|
|
|
|
`
|
|
|
|
sequenceDiagram
|
|
|
|
A ->> B: 1
|
|
|
|
rect rgb(204, 0, 102)
|
|
|
|
critical yes
|
|
|
|
C ->> C: 1
|
|
|
|
option no
|
|
|
|
rect rgb(0, 204, 204)
|
|
|
|
C ->> C: 0
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
B ->> A: Return
|
|
|
|
`,
|
|
|
|
{}
|
|
|
|
);
|
|
|
|
});
|
|
|
|
it('should render rect around and inside breaks', () => {
|
|
|
|
imgSnapshotTest(
|
|
|
|
`
|
|
|
|
sequenceDiagram
|
|
|
|
A ->> B: 1
|
|
|
|
rect rgb(204, 0, 102)
|
|
|
|
break yes
|
|
|
|
rect rgb(0, 204, 204)
|
|
|
|
C ->> C: 0
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
B ->> A: Return
|
|
|
|
`,
|
|
|
|
{}
|
|
|
|
);
|
|
|
|
});
|
2020-02-16 15:26:08 +01:00
|
|
|
it('should render autonumber when configured with such', () => {
|
|
|
|
imgSnapshotTest(
|
|
|
|
`
|
|
|
|
sequenceDiagram
|
|
|
|
Alice->>John: Hello John, how are you?
|
|
|
|
loop Healthcheck
|
|
|
|
John->>John: Fight against hypochondria
|
|
|
|
end
|
|
|
|
Note right of John: Rational thoughts!
|
|
|
|
John-->>Alice: Great!
|
|
|
|
John->>Bob: How about you?
|
|
|
|
Bob-->>John: Jolly good!
|
|
|
|
`,
|
2020-04-23 18:31:22 +03:00
|
|
|
{ sequence: { actorMargin: 50, showSequenceNumbers: true } }
|
2020-02-16 15:26:08 +01:00
|
|
|
);
|
|
|
|
});
|
|
|
|
it('should render autonumber when autonumber keyword is used', () => {
|
|
|
|
imgSnapshotTest(
|
|
|
|
`
|
|
|
|
sequenceDiagram
|
|
|
|
autonumber
|
|
|
|
Alice->>John: Hello John, how are you?
|
|
|
|
loop Healthcheck
|
|
|
|
John->>John: Fight against hypochondria
|
|
|
|
end
|
|
|
|
Note right of John: Rational thoughts!
|
|
|
|
John-->>Alice: Great!
|
|
|
|
John->>Bob: How about you?
|
|
|
|
Bob-->>John: Jolly good!
|
|
|
|
`,
|
2020-04-23 18:31:22 +03:00
|
|
|
{}
|
2020-02-16 15:26:08 +01:00
|
|
|
);
|
|
|
|
});
|
2020-04-04 21:53:31 +02:00
|
|
|
it('should render autonumber with different line breaks', () => {
|
|
|
|
imgSnapshotTest(
|
|
|
|
`
|
|
|
|
sequenceDiagram
|
|
|
|
autonumber
|
|
|
|
Alice->>John: Hello John,<br>how are you?
|
|
|
|
Alice->>John: John,<br/>can you hear me?
|
|
|
|
John-->>Alice: Hi Alice,<br />I can hear you!
|
|
|
|
John-->>Alice: I feel great!
|
|
|
|
`,
|
2020-04-23 18:31:22 +03:00
|
|
|
{}
|
2020-04-04 21:53:31 +02:00
|
|
|
);
|
|
|
|
});
|
2020-06-17 18:12:01 -04:00
|
|
|
it('should render dark theme from init directive and configure font size 24 font', () => {
|
2020-06-17 05:54:24 -04:00
|
|
|
imgSnapshotTest(
|
|
|
|
`
|
2020-06-17 18:12:01 -04:00
|
|
|
%%{init: {'theme': 'dark', 'config': {'fontSize': 24}}}%%
|
2020-06-17 05:54:24 -04:00
|
|
|
sequenceDiagram
|
|
|
|
Alice->>John: Hello John, how are you?
|
|
|
|
Alice->>John: John, can you hear me?
|
|
|
|
John-->>Alice: Hi Alice, I can hear you!
|
|
|
|
John-->>Alice: I feel great!
|
|
|
|
`,
|
|
|
|
{}
|
|
|
|
);
|
|
|
|
});
|
|
|
|
it('should render with wrapping enabled', () => {
|
|
|
|
imgSnapshotTest(
|
|
|
|
`
|
2020-06-26 09:26:56 -04:00
|
|
|
%%{init: { 'config': { 'wrap': true }}}%%
|
2020-06-17 05:54:24 -04:00
|
|
|
sequenceDiagram
|
|
|
|
participant A as Alice, the talkative one
|
|
|
|
A->>John: Hello John, how are you today? I'm feeling quite verbose today.
|
|
|
|
A->>John: John, can you hear me? If you are not available, we can talk later.
|
|
|
|
John-->>A: Hi Alice, I can hear you! I was finishing up an important meeting.
|
|
|
|
John-->>A: I feel great! I was not ignoring you. I am sorry you had to wait for a response.
|
|
|
|
`,
|
|
|
|
{}
|
|
|
|
);
|
|
|
|
});
|
2020-06-17 18:14:10 -04:00
|
|
|
it('should render with an init directive', () => {
|
|
|
|
imgSnapshotTest(
|
2021-11-18 19:17:00 +01:00
|
|
|
`%%{init: { "theme": "dark", 'config': { "fontFamily": "Menlo", "fontSize": 18, "fontWeight": 400, "wrap": true }}}%%
|
2020-06-17 18:14:10 -04:00
|
|
|
sequenceDiagram
|
|
|
|
Alice->>Bob: Hello Bob, how are you? If you are not available right now, I can leave you a message. Please get back to me as soon as you can!
|
|
|
|
Note left of Alice: Bob thinks
|
|
|
|
Bob->>Alice: Fine!`,
|
|
|
|
{}
|
2021-11-18 19:17:00 +01:00
|
|
|
);
|
2020-06-17 18:14:10 -04:00
|
|
|
});
|
2019-09-18 18:25:06 +02:00
|
|
|
});
|
2020-06-14 22:50:45 +02:00
|
|
|
context('directives', () => {
|
2021-11-18 19:17:00 +01:00
|
|
|
it('should override config with directive settings', () => {
|
2020-06-14 22:50:45 +02:00
|
|
|
imgSnapshotTest(
|
|
|
|
`
|
2020-06-22 15:38:54 -04:00
|
|
|
%%{init: { "config": { "mirrorActors": true }}}%%
|
2020-06-14 22:50:45 +02:00
|
|
|
sequenceDiagram
|
|
|
|
Alice->>Bob: I'm short
|
|
|
|
note left of Alice: config set to mirrorActors: false<br/>directive set to mirrorActors: true
|
|
|
|
Bob->>Alice: Short as well
|
|
|
|
`,
|
2021-11-18 19:17:00 +01:00
|
|
|
{
|
|
|
|
logLevel: 0,
|
|
|
|
sequence: { mirrorActors: false, noteFontSize: 18, noteFontFamily: 'Arial' },
|
|
|
|
}
|
2020-06-14 22:50:45 +02:00
|
|
|
);
|
|
|
|
});
|
2022-03-31 19:14:37 +02:00
|
|
|
it('should override config with directive settings 2', () => {
|
2020-06-14 23:37:08 +02:00
|
|
|
imgSnapshotTest(
|
|
|
|
`
|
2020-06-26 09:26:56 -04:00
|
|
|
%%{init: { "config": { "mirrorActors": false, "wrap": true }}}%%
|
2020-06-14 23:37:08 +02:00
|
|
|
sequenceDiagram
|
|
|
|
Alice->>Bob: I'm short
|
2020-06-26 09:26:56 -04:00
|
|
|
note left of Alice: config: mirrorActors=true<br/>directive: mirrorActors=false
|
2020-06-14 23:37:08 +02:00
|
|
|
Bob->>Alice: Short as well
|
|
|
|
`,
|
2021-11-18 19:17:00 +01:00
|
|
|
{ logLevel: 0, sequence: { mirrorActors: true, noteFontSize: 18, noteFontFamily: 'Arial' } }
|
2020-06-14 23:37:08 +02:00
|
|
|
);
|
|
|
|
});
|
2020-06-14 22:50:45 +02:00
|
|
|
});
|
2021-08-27 10:56:56 -07:00
|
|
|
context('links', () => {
|
2021-10-07 21:48:44 +02:00
|
|
|
it('should support actor links and properties EXPERIMENTAL: USE WITH CAUTION', () => {
|
2021-11-18 19:17:00 +01:00
|
|
|
//Be aware that the syntax for "properties" is likely to be changed.
|
2021-08-27 10:56:56 -07:00
|
|
|
imgSnapshotTest(
|
|
|
|
`
|
|
|
|
%%{init: { "config": { "mirrorActors": true, "forceMenus": true }}}%%
|
|
|
|
sequenceDiagram
|
|
|
|
participant a as Alice
|
|
|
|
participant j as John
|
|
|
|
note right of a: Hello world!
|
|
|
|
properties a: {"class": "internal-service-actor", "type": "@clock"}
|
|
|
|
properties j: {"class": "external-service-actor", "type": "@computer"}
|
|
|
|
links a: {"Repo": "https://www.contoso.com/repo", "Swagger": "https://www.contoso.com/swagger"}
|
|
|
|
links j: {"Repo": "https://www.contoso.com/repo"}
|
|
|
|
links a: {"Dashboard": "https://www.contoso.com/dashboard", "On-Call": "https://www.contoso.com/oncall"}
|
2021-09-10 16:27:07 -07:00
|
|
|
link a: Contacts @ https://contacts.contoso.com/?contact=alice@contoso.com
|
2021-08-27 10:56:56 -07:00
|
|
|
a->>j: Hello John, how are you?
|
|
|
|
j-->>a: Great!
|
|
|
|
`,
|
|
|
|
{ logLevel: 0, sequence: { mirrorActors: true, noteFontSize: 18, noteFontFamily: 'Arial' } }
|
|
|
|
);
|
|
|
|
});
|
2021-10-07 21:48:44 +02:00
|
|
|
it('should support actor links and properties when not mirrored EXPERIMENTAL: USE WITH CAUTION', () => {
|
2021-11-18 19:17:00 +01:00
|
|
|
//Be aware that the syntax for "properties" is likely to be changed.
|
2021-08-27 10:56:56 -07:00
|
|
|
imgSnapshotTest(
|
|
|
|
`
|
|
|
|
%%{init: { "config": { "mirrorActors": false, "forceMenus": true, "wrap": true }}}%%
|
|
|
|
sequenceDiagram
|
|
|
|
participant a as Alice
|
|
|
|
participant j as John
|
|
|
|
note right of a: Hello world!
|
|
|
|
properties a: {"class": "internal-service-actor", "type": "@clock"}
|
|
|
|
properties j: {"class": "external-service-actor", "type": "@computer"}
|
|
|
|
links a: {"Repo": "https://www.contoso.com/repo", "Swagger": "https://www.contoso.com/swagger"}
|
|
|
|
links j: {"Repo": "https://www.contoso.com/repo"}
|
|
|
|
links a: {"Dashboard": "https://www.contoso.com/dashboard", "On-Call": "https://www.contoso.com/oncall"}
|
|
|
|
a->>j: Hello John, how are you?
|
|
|
|
j-->>a: Great!
|
|
|
|
`,
|
2021-11-18 19:17:00 +01:00
|
|
|
{
|
|
|
|
logLevel: 0,
|
|
|
|
sequence: { mirrorActors: false, noteFontSize: 18, noteFontFamily: 'Arial' },
|
|
|
|
}
|
2021-08-27 10:56:56 -07:00
|
|
|
);
|
|
|
|
});
|
2022-04-14 19:19:18 -07:00
|
|
|
it("shouldn't display unused participants", () => {
|
|
|
|
//Be aware that the syntax for "properties" is likely to be changed.
|
|
|
|
imgSnapshotTest(
|
|
|
|
`
|
2022-04-28 18:45:18 +02:00
|
|
|
%%{init: { "config": { "sequence": {"hideUnusedParticipants": true }}}}%%
|
2022-04-14 19:19:18 -07:00
|
|
|
sequenceDiagram
|
|
|
|
participant a
|
|
|
|
`,
|
|
|
|
{
|
|
|
|
logLevel: 0,
|
|
|
|
sequence: { mirrorActors: false, noteFontSize: 18, noteFontFamily: 'Arial' },
|
2022-04-28 18:45:18 +02:00
|
|
|
}
|
2022-04-14 19:19:18 -07:00
|
|
|
);
|
|
|
|
});
|
2021-08-27 10:56:56 -07:00
|
|
|
});
|
2020-08-25 17:05:01 +02:00
|
|
|
context('svg size', () => {
|
|
|
|
it('should render a sequence diagram when useMaxWidth is true (default)', () => {
|
|
|
|
renderGraph(
|
|
|
|
`
|
|
|
|
sequenceDiagram
|
|
|
|
participant Alice
|
|
|
|
participant Bob
|
|
|
|
participant John as John<br/>Second Line
|
|
|
|
Alice ->> Bob: Hello Bob, how are you?
|
|
|
|
Bob-->>John: How about you John?
|
|
|
|
Bob--x Alice: I am good thanks!
|
|
|
|
Bob-x John: I am good thanks!
|
|
|
|
Note right of John: Bob thinks a long<br/>long time, so long<br/>that the text does<br/>not fit on a row.
|
|
|
|
Bob-->Alice: Checking with John...
|
|
|
|
alt either this
|
|
|
|
Alice->>John: Yes
|
|
|
|
else or this
|
|
|
|
Alice->>John: No
|
|
|
|
else or this will happen
|
|
|
|
Alice->John: Maybe
|
|
|
|
end
|
|
|
|
par this happens in parallel
|
|
|
|
Alice -->> Bob: Parallel message 1
|
|
|
|
and
|
|
|
|
Alice -->> John: Parallel message 2
|
|
|
|
end
|
|
|
|
`,
|
|
|
|
{ sequence: { useMaxWidth: true } }
|
|
|
|
);
|
2021-11-18 19:17:00 +01:00
|
|
|
cy.get('svg').should((svg) => {
|
|
|
|
expect(svg).to.have.attr('width', '100%');
|
2022-08-28 11:25:09 +02:00
|
|
|
// expect(svg).to.have.attr('height');
|
|
|
|
// const height = parseFloat(svg.attr('height'));
|
|
|
|
// expect(height).to.be.within(920, 971);
|
2021-11-18 19:17:00 +01:00
|
|
|
const style = svg.attr('style');
|
|
|
|
expect(style).to.match(/^max-width: [\d.]+px;$/);
|
|
|
|
const maxWidthValue = parseFloat(style.match(/[\d.]+/g).join(''));
|
|
|
|
// use within because the absolute value can be slightly different depending on the environment ±5%
|
|
|
|
expect(maxWidthValue).to.be.within(820 * 0.95, 820 * 1.05);
|
|
|
|
});
|
2020-08-25 17:05:01 +02:00
|
|
|
});
|
|
|
|
it('should render a sequence diagram when useMaxWidth is false', () => {
|
|
|
|
renderGraph(
|
|
|
|
`
|
|
|
|
sequenceDiagram
|
|
|
|
participant Alice
|
|
|
|
participant Bob
|
|
|
|
participant John as John<br/>Second Line
|
|
|
|
Alice ->> Bob: Hello Bob, how are you?
|
|
|
|
Bob-->>John: How about you John?
|
|
|
|
Bob--x Alice: I am good thanks!
|
|
|
|
Bob-x John: I am good thanks!
|
|
|
|
Note right of John: Bob thinks a long<br/>long time, so long<br/>that the text does<br/>not fit on a row.
|
|
|
|
Bob-->Alice: Checking with John...
|
|
|
|
alt either this
|
|
|
|
Alice->>John: Yes
|
|
|
|
else or this
|
|
|
|
Alice->>John: No
|
|
|
|
else or this will happen
|
|
|
|
Alice->John: Maybe
|
|
|
|
end
|
|
|
|
par this happens in parallel
|
|
|
|
Alice -->> Bob: Parallel message 1
|
|
|
|
and
|
|
|
|
Alice -->> John: Parallel message 2
|
|
|
|
end
|
|
|
|
`,
|
|
|
|
{ sequence: { useMaxWidth: false } }
|
|
|
|
);
|
2021-11-18 19:17:00 +01:00
|
|
|
cy.get('svg').should((svg) => {
|
2022-08-28 11:25:09 +02:00
|
|
|
// const height = parseFloat(svg.attr('height'));
|
2021-11-18 19:17:00 +01:00
|
|
|
const width = parseFloat(svg.attr('width'));
|
2022-08-28 11:25:09 +02:00
|
|
|
// expect(height).to.be.within(920, 971);
|
2021-11-18 19:17:00 +01:00
|
|
|
// use within because the absolute value can be slightly different depending on the environment ±5%
|
|
|
|
expect(width).to.be.within(820 * 0.95, 820 * 1.05);
|
|
|
|
expect(svg).to.not.have.attr('style');
|
|
|
|
});
|
2020-08-25 17:05:01 +02:00
|
|
|
});
|
|
|
|
});
|
2019-09-18 18:25:06 +02:00
|
|
|
});
|