mermaid
Version:
Markdownish syntax for generating flowcharts, sequence diagrams and gantt charts.
363 lines (312 loc) • 44.4 kB
HTML
<html>
<head>
<title>mermaid.spec.js</title>
<meta http-equiv="content-type" content="text/html; charset=UTF-8">
<link rel="stylesheet" media="all" href="../doc-style.css" />
<script src="../doc-filelist.js"></script>
<script>
var relativeDir = "../", thisFile = "Users/knut/Documents/source/mermaid/src/mermaid.spec.js", defaultSidebar = true;
</script>
<script src="../doc-script.js"></script>
<script src="../mermaid.js"></script>
<link rel="stylesheet" href="../mermaid.css" />
</head>
<body>
<div id="sidebar_wrapper">
<div id="sidebar_switch">
<span class="tree">Files</span>
<span class="headings">Headings</span>
</div>
<div id="tree"></div>
<div id="headings">
<div class="heading h1">
<a href="#mermaid.spec.js">mermaid.spec.js</a>
</div>
</div>
</div>
<div id="sidebar-toggle"></div>
<div id="container"><div class="background highlight"></div>
<table cellpadding="0" cellspacing="0">
<tbody>
<tr>
<td class="docs">
<div class="pilwrap" id="mermaid.spec.js">
<h1>
<a href="#mermaid.spec.js" name="mermaid.spec.js" class="pilcrow">¶</a>mermaid.spec.js
</h1>
</div>
</td>
<td class="code highlight"></td>
</tr>
<tr>
<td class="docs">
<div class="pilwrap">
<a class="pilcrow" href="#section-1" id="section-1">¶</a>
</div>
<div class="dox">
<div class="summary"><p>Created by knut on 14-11-26.</p>
</div>
<div class="body">
</div>
</div>
<div class="dox">
<div class="summary"><p>Created by knut on 14-11-23.</p>
</div>
<div class="body">
</div>
</div>
</td>
<td class="code highlight"><div class="highlight"><pre><span class="kd">var</span> <span class="nx">rewire</span> <span class="o">=</span> <span class="nx">require</span><span class="p">(</span><span class="s2">"rewire"</span><span class="p">);</span>
<span class="kd">var</span> <span class="nx">utils</span> <span class="o">=</span> <span class="nx">require</span><span class="p">(</span><span class="s2">"./utils"</span><span class="p">);</span>
<span class="kd">var</span> <span class="nx">mermaid</span> <span class="o">=</span> <span class="nx">require</span><span class="p">(</span><span class="s2">"./mermaid"</span><span class="p">);</span>
<span class="kd">var</span> <span class="nx">log</span> <span class="o">=</span> <span class="nx">require</span><span class="p">(</span><span class="s1">'./logger'</span><span class="p">).</span><span class="nx">create</span><span class="p">();</span>
<span class="nx">describe</span><span class="p">(</span><span class="s1">'when using mermaid and '</span><span class="p">,</span><span class="kd">function</span><span class="p">()</span> <span class="p">{</span>
<span class="nx">describe</span><span class="p">(</span><span class="s1">'when detecting chart type '</span><span class="p">,</span><span class="kd">function</span><span class="p">()</span> <span class="p">{</span>
</pre></div>
</td>
</tr>
<tr>
<td class="docs">
<div class="pilwrap">
<a class="pilcrow" href="#section-2" id="section-2">¶</a>
</div>
<p>var mermaid;
var document;
var window;</p>
</td>
<td class="code highlight"><div class="highlight"><pre>
<span class="nx">beforeEach</span><span class="p">(</span><span class="kd">function</span> <span class="p">()</span> <span class="p">{</span>
<span class="kd">var</span> <span class="nx">MockBrowser</span> <span class="o">=</span> <span class="nx">require</span><span class="p">(</span><span class="s1">'mock-browser'</span><span class="p">).</span><span class="nx">mocks</span><span class="p">.</span><span class="nx">MockBrowser</span><span class="p">;</span>
<span class="kd">var</span> <span class="nx">mock</span> <span class="o">=</span> <span class="k">new</span> <span class="nx">MockBrowser</span><span class="p">();</span>
<span class="k">delete</span> <span class="nx">global</span><span class="p">.</span><span class="nx">mermaid_config</span><span class="p">;</span>
</pre></div>
</td>
</tr>
<tr>
<td class="docs">
<div class="pilwrap">
<a class="pilcrow" href="#section-3" id="section-3">¶</a>
</div>
<p>and in the run-code inside some object</p>
</td>
<td class="code highlight"><div class="highlight"><pre>
<span class="nb">document</span> <span class="o">=</span> <span class="nx">mock</span><span class="p">.</span><span class="nx">getDocument</span><span class="p">();</span>
<span class="nb">window</span> <span class="o">=</span> <span class="nx">mock</span><span class="p">.</span><span class="nx">getWindow</span><span class="p">();</span>
<span class="p">});</span>
<span class="nx">it</span><span class="p">(</span><span class="s1">'should not start rendering with mermaid_config.startOnLoad set to false'</span><span class="p">,</span> <span class="kd">function</span> <span class="p">()</span> <span class="p">{</span>
<span class="nx">mermaid</span> <span class="o">=</span> <span class="nx">rewire</span><span class="p">(</span><span class="s1">'./mermaid'</span><span class="p">);</span>
<span class="nx">mermaid_config</span> <span class="o">=</span><span class="p">{</span><span class="nx">startOnLoad</span> <span class="o">:</span> <span class="kc">false</span><span class="p">};</span>
<span class="nb">document</span><span class="p">.</span><span class="nx">body</span><span class="p">.</span><span class="nx">innerHTML</span> <span class="o">=</span> <span class="s1">'<div class="mermaid">graph TD;\na;</div>'</span><span class="p">;</span>
<span class="nx">spyOn</span><span class="p">(</span><span class="nx">global</span><span class="p">.</span><span class="nx">mermaid</span><span class="p">,</span><span class="s1">'init'</span><span class="p">);</span>
</pre></div>
</td>
</tr>
<tr>
<td class="docs">
<div class="pilwrap">
<a class="pilcrow" href="#section-4" id="section-4">¶</a>
</div>
<p>log.debug(mermaid);</p>
</td>
<td class="code highlight"><div class="highlight"><pre>
<span class="nx">mermaid</span><span class="p">.</span><span class="nx">contentLoaded</span><span class="p">();</span>
<span class="nx">expect</span><span class="p">(</span><span class="nx">global</span><span class="p">.</span><span class="nx">mermaid</span><span class="p">.</span><span class="nx">init</span><span class="p">).</span><span class="nx">not</span><span class="p">.</span><span class="nx">toHaveBeenCalled</span><span class="p">();</span>
<span class="p">});</span>
<span class="nx">it</span><span class="p">(</span><span class="s1">'should not start rendering with mermaid.startOnLoad set to false'</span><span class="p">,</span> <span class="kd">function</span> <span class="p">()</span> <span class="p">{</span>
<span class="nx">mermaid</span> <span class="o">=</span> <span class="nx">rewire</span><span class="p">(</span><span class="s1">'./mermaid'</span><span class="p">);</span>
<span class="nx">global</span><span class="p">.</span><span class="nx">mermaid</span><span class="p">.</span><span class="nx">startOnLoad</span> <span class="o">=</span> <span class="kc">false</span><span class="p">;</span>
<span class="nx">mermaid_config</span> <span class="o">=</span><span class="p">{</span><span class="nx">startOnLoad</span> <span class="o">:</span> <span class="kc">true</span><span class="p">};</span>
<span class="nb">document</span><span class="p">.</span><span class="nx">body</span><span class="p">.</span><span class="nx">innerHTML</span> <span class="o">=</span> <span class="s1">'<div class="mermaid">graph TD;\na;</div>'</span><span class="p">;</span>
<span class="nx">spyOn</span><span class="p">(</span><span class="nx">global</span><span class="p">.</span><span class="nx">mermaid</span><span class="p">,</span><span class="s1">'init'</span><span class="p">);</span>
<span class="nx">mermaid</span><span class="p">.</span><span class="nx">contentLoaded</span><span class="p">();</span>
<span class="nx">expect</span><span class="p">(</span><span class="nx">global</span><span class="p">.</span><span class="nx">mermaid</span><span class="p">.</span><span class="nx">init</span><span class="p">).</span><span class="nx">not</span><span class="p">.</span><span class="nx">toHaveBeenCalled</span><span class="p">();</span>
<span class="p">});</span>
<span class="nx">it</span><span class="p">(</span><span class="s1">'should start rendering with both startOnLoad set'</span><span class="p">,</span> <span class="kd">function</span> <span class="p">()</span> <span class="p">{</span>
<span class="nx">mermaid</span> <span class="o">=</span> <span class="nx">rewire</span><span class="p">(</span><span class="s1">'./mermaid'</span><span class="p">);</span>
<span class="nx">global</span><span class="p">.</span><span class="nx">mermaid</span><span class="p">.</span><span class="nx">startOnLoad</span> <span class="o">=</span> <span class="kc">true</span><span class="p">;</span>
<span class="nx">mermaid_config</span> <span class="o">=</span><span class="p">{</span><span class="nx">startOnLoad</span> <span class="o">:</span> <span class="kc">true</span><span class="p">};</span>
<span class="nb">document</span><span class="p">.</span><span class="nx">body</span><span class="p">.</span><span class="nx">innerHTML</span> <span class="o">=</span> <span class="s1">'<div class="mermaid">graph TD;\na;</div>'</span><span class="p">;</span>
<span class="nx">spyOn</span><span class="p">(</span><span class="nx">global</span><span class="p">.</span><span class="nx">mermaid</span><span class="p">,</span><span class="s1">'init'</span><span class="p">);</span>
<span class="nx">mermaid</span><span class="p">.</span><span class="nx">contentLoaded</span><span class="p">();</span>
<span class="nx">expect</span><span class="p">(</span><span class="nx">global</span><span class="p">.</span><span class="nx">mermaid</span><span class="p">.</span><span class="nx">init</span><span class="p">).</span><span class="nx">toHaveBeenCalled</span><span class="p">();</span>
<span class="p">});</span>
<span class="nx">it</span><span class="p">(</span><span class="s1">'should start rendering with mermaid.startOnLoad set and no mermaid_config defined'</span><span class="p">,</span> <span class="kd">function</span> <span class="p">()</span> <span class="p">{</span>
<span class="nx">mermaid</span> <span class="o">=</span> <span class="nx">rewire</span><span class="p">(</span><span class="s1">'./mermaid'</span><span class="p">);</span>
<span class="nx">global</span><span class="p">.</span><span class="nx">mermaid</span><span class="p">.</span><span class="nx">startOnLoad</span> <span class="o">=</span> <span class="kc">true</span><span class="p">;</span>
<span class="nb">document</span><span class="p">.</span><span class="nx">body</span><span class="p">.</span><span class="nx">innerHTML</span> <span class="o">=</span> <span class="s1">'<div class="mermaid">graph TD;\na;</div>'</span><span class="p">;</span>
<span class="nx">spyOn</span><span class="p">(</span><span class="nx">global</span><span class="p">.</span><span class="nx">mermaid</span><span class="p">,</span><span class="s1">'init'</span><span class="p">);</span>
<span class="nx">mermaid</span><span class="p">.</span><span class="nx">contentLoaded</span><span class="p">();</span>
<span class="nx">expect</span><span class="p">(</span><span class="nx">global</span><span class="p">.</span><span class="nx">mermaid</span><span class="p">.</span><span class="nx">init</span><span class="p">).</span><span class="nx">toHaveBeenCalled</span><span class="p">();</span>
<span class="p">});</span>
<span class="nx">it</span><span class="p">(</span><span class="s1">'should start rendering as a default with no changes performed'</span><span class="p">,</span> <span class="kd">function</span> <span class="p">()</span> <span class="p">{</span>
<span class="nx">mermaid</span> <span class="o">=</span> <span class="nx">rewire</span><span class="p">(</span><span class="s1">'./mermaid'</span><span class="p">);</span>
<span class="nb">document</span><span class="p">.</span><span class="nx">body</span><span class="p">.</span><span class="nx">innerHTML</span> <span class="o">=</span> <span class="s1">'<div class="mermaid">graph TD;\na;</div>'</span><span class="p">;</span>
<span class="nx">spyOn</span><span class="p">(</span><span class="nx">global</span><span class="p">.</span><span class="nx">mermaid</span><span class="p">,</span><span class="s1">'init'</span><span class="p">);</span>
<span class="nx">mermaid</span><span class="p">.</span><span class="nx">contentLoaded</span><span class="p">();</span>
<span class="nx">expect</span><span class="p">(</span><span class="nx">global</span><span class="p">.</span><span class="nx">mermaid</span><span class="p">.</span><span class="nx">init</span><span class="p">).</span><span class="nx">toHaveBeenCalled</span><span class="p">();</span>
<span class="p">});</span>
<span class="p">});</span>
<span class="nx">describe</span><span class="p">(</span><span class="s1">'when calling addEdges '</span><span class="p">,</span><span class="kd">function</span><span class="p">()</span> <span class="p">{</span>
<span class="kd">var</span> <span class="nx">mermaid</span><span class="p">;</span>
<span class="kd">var</span> <span class="nx">graph</span> <span class="o">=</span> <span class="nx">require</span><span class="p">(</span><span class="s1">'./diagrams/flowchart/graphDb'</span><span class="p">);</span>
<span class="kd">var</span> <span class="nx">flow</span> <span class="o">=</span> <span class="nx">require</span><span class="p">(</span><span class="s1">'./diagrams/flowchart/parser/flow'</span><span class="p">);</span>
<span class="kd">var</span> <span class="nx">flowRend</span> <span class="o">=</span> <span class="nx">require</span><span class="p">(</span><span class="s1">'./diagrams/flowchart/flowRenderer'</span><span class="p">);</span>
<span class="nx">beforeEach</span><span class="p">(</span><span class="kd">function</span> <span class="p">()</span> <span class="p">{</span>
<span class="nx">mermaid_config</span> <span class="o">=</span><span class="p">{</span><span class="nx">startOnLoad</span> <span class="o">:</span> <span class="kc">false</span><span class="p">};</span>
<span class="kd">var</span> <span class="nx">MockBrowser</span> <span class="o">=</span> <span class="nx">require</span><span class="p">(</span><span class="s1">'mock-browser'</span><span class="p">).</span><span class="nx">mocks</span><span class="p">.</span><span class="nx">MockBrowser</span><span class="p">;</span>
<span class="kd">var</span> <span class="nx">mock</span> <span class="o">=</span> <span class="k">new</span> <span class="nx">MockBrowser</span><span class="p">();</span>
<span class="nx">flow</span><span class="p">.</span><span class="nx">parser</span><span class="p">.</span><span class="nx">yy</span> <span class="o">=</span><span class="nx">graph</span><span class="p">;</span>
<span class="nx">graph</span><span class="p">.</span><span class="nx">clear</span><span class="p">();</span>
<span class="nb">document</span> <span class="o">=</span> <span class="nx">mock</span><span class="p">.</span><span class="nx">getDocument</span><span class="p">();</span>
<span class="nx">mermaid</span> <span class="o">=</span> <span class="nx">rewire</span><span class="p">(</span><span class="s1">'./mermaid'</span><span class="p">);</span>
<span class="p">});</span>
<span class="nx">it</span><span class="p">(</span><span class="s1">'it should handle edges with text'</span><span class="p">,</span> <span class="kd">function</span> <span class="p">()</span> <span class="p">{</span>
<span class="kd">var</span> <span class="nx">res</span> <span class="o">=</span> <span class="nx">flow</span><span class="p">.</span><span class="nx">parser</span><span class="p">.</span><span class="nx">parse</span><span class="p">(</span><span class="s1">'graph TD;A-->|text ex|B;'</span><span class="p">);</span>
<span class="kd">var</span> <span class="nx">vert</span> <span class="o">=</span> <span class="nx">flow</span><span class="p">.</span><span class="nx">parser</span><span class="p">.</span><span class="nx">yy</span><span class="p">.</span><span class="nx">getVertices</span><span class="p">();</span>
<span class="kd">var</span> <span class="nx">edges</span> <span class="o">=</span> <span class="nx">flow</span><span class="p">.</span><span class="nx">parser</span><span class="p">.</span><span class="nx">yy</span><span class="p">.</span><span class="nx">getEdges</span><span class="p">();</span>
<span class="kd">var</span> <span class="nx">mockG</span> <span class="o">=</span> <span class="p">{</span>
<span class="nx">setEdge</span><span class="o">:</span><span class="kd">function</span><span class="p">(</span><span class="nx">start</span><span class="p">,</span> <span class="nx">end</span><span class="p">,</span><span class="nx">options</span><span class="p">,</span><span class="nx">name</span><span class="p">){</span>
<span class="nx">expect</span><span class="p">(</span><span class="nx">start</span><span class="p">).</span><span class="nx">toBe</span><span class="p">(</span><span class="s1">'A'</span><span class="p">);</span>
<span class="nx">expect</span><span class="p">(</span><span class="nx">end</span><span class="p">).</span><span class="nx">toBe</span><span class="p">(</span><span class="s1">'B'</span><span class="p">);</span>
<span class="nx">expect</span><span class="p">(</span><span class="nx">options</span><span class="p">.</span><span class="nx">arrowhead</span><span class="p">).</span><span class="nx">toBe</span><span class="p">(</span><span class="s1">'normal'</span><span class="p">);</span>
<span class="nx">expect</span><span class="p">(</span><span class="nx">options</span><span class="p">.</span><span class="nx">label</span><span class="p">.</span><span class="nx">match</span><span class="p">(</span><span class="s1">'text ex'</span><span class="p">)).</span><span class="nx">toBeTruthy</span><span class="p">();</span>
<span class="p">}</span>
<span class="p">};</span>
<span class="nx">flowRend</span><span class="p">.</span><span class="nx">addEdges</span><span class="p">(</span><span class="nx">edges</span><span class="p">,</span><span class="nx">mockG</span><span class="p">);</span>
<span class="p">});</span>
<span class="nx">it</span><span class="p">(</span><span class="s1">'should handle edges without text'</span><span class="p">,</span> <span class="kd">function</span> <span class="p">()</span> <span class="p">{</span>
<span class="kd">var</span> <span class="nx">res</span> <span class="o">=</span> <span class="nx">flow</span><span class="p">.</span><span class="nx">parser</span><span class="p">.</span><span class="nx">parse</span><span class="p">(</span><span class="s1">'graph TD;A-->B;'</span><span class="p">);</span>
<span class="kd">var</span> <span class="nx">vert</span> <span class="o">=</span> <span class="nx">flow</span><span class="p">.</span><span class="nx">parser</span><span class="p">.</span><span class="nx">yy</span><span class="p">.</span><span class="nx">getVertices</span><span class="p">();</span>
<span class="kd">var</span> <span class="nx">edges</span> <span class="o">=</span> <span class="nx">flow</span><span class="p">.</span><span class="nx">parser</span><span class="p">.</span><span class="nx">yy</span><span class="p">.</span><span class="nx">getEdges</span><span class="p">();</span>
<span class="kd">var</span> <span class="nx">mockG</span> <span class="o">=</span> <span class="p">{</span>
<span class="nx">setEdge</span><span class="o">:</span><span class="kd">function</span><span class="p">(</span><span class="nx">start</span><span class="p">,</span> <span class="nx">end</span><span class="p">,</span><span class="nx">options</span><span class="p">,</span><span class="nx">name</span><span class="p">){</span>
<span class="nx">expect</span><span class="p">(</span><span class="nx">start</span><span class="p">).</span><span class="nx">toBe</span><span class="p">(</span><span class="s1">'A'</span><span class="p">);</span>
<span class="nx">expect</span><span class="p">(</span><span class="nx">end</span><span class="p">).</span><span class="nx">toBe</span><span class="p">(</span><span class="s1">'B'</span><span class="p">);</span>
<span class="nx">expect</span><span class="p">(</span><span class="nx">options</span><span class="p">.</span><span class="nx">arrowhead</span><span class="p">).</span><span class="nx">toBe</span><span class="p">(</span><span class="s1">'normal'</span><span class="p">);</span>
<span class="p">}</span>
<span class="p">};</span>
<span class="nx">flowRend</span><span class="p">.</span><span class="nx">addEdges</span><span class="p">(</span><span class="nx">edges</span><span class="p">,</span><span class="nx">mockG</span><span class="p">);</span>
<span class="p">});</span>
<span class="nx">it</span><span class="p">(</span><span class="s1">'should handle open-ended edges'</span><span class="p">,</span> <span class="kd">function</span> <span class="p">()</span> <span class="p">{</span>
<span class="kd">var</span> <span class="nx">res</span> <span class="o">=</span> <span class="nx">flow</span><span class="p">.</span><span class="nx">parser</span><span class="p">.</span><span class="nx">parse</span><span class="p">(</span><span class="s1">'graph TD;A---B;'</span><span class="p">);</span>
<span class="kd">var</span> <span class="nx">vert</span> <span class="o">=</span> <span class="nx">flow</span><span class="p">.</span><span class="nx">parser</span><span class="p">.</span><span class="nx">yy</span><span class="p">.</span><span class="nx">getVertices</span><span class="p">();</span>
<span class="kd">var</span> <span class="nx">edges</span> <span class="o">=</span> <span class="nx">flow</span><span class="p">.</span><span class="nx">parser</span><span class="p">.</span><span class="nx">yy</span><span class="p">.</span><span class="nx">getEdges</span><span class="p">();</span>
<span class="kd">var</span> <span class="nx">mockG</span> <span class="o">=</span> <span class="p">{</span>
<span class="nx">setEdge</span><span class="o">:</span><span class="kd">function</span><span class="p">(</span><span class="nx">start</span><span class="p">,</span> <span class="nx">end</span><span class="p">,</span><span class="nx">options</span><span class="p">,</span><span class="nx">name</span><span class="p">){</span>
<span class="nx">expect</span><span class="p">(</span><span class="nx">start</span><span class="p">).</span><span class="nx">toBe</span><span class="p">(</span><span class="s1">'A'</span><span class="p">);</span>
<span class="nx">expect</span><span class="p">(</span><span class="nx">end</span><span class="p">).</span><span class="nx">toBe</span><span class="p">(</span><span class="s1">'B'</span><span class="p">);</span>
<span class="nx">expect</span><span class="p">(</span><span class="nx">options</span><span class="p">.</span><span class="nx">arrowhead</span><span class="p">).</span><span class="nx">toBe</span><span class="p">(</span><span class="s1">'none'</span><span class="p">);</span>
<span class="p">}</span>
<span class="p">};</span>
<span class="nx">flowRend</span><span class="p">.</span><span class="nx">addEdges</span><span class="p">(</span><span class="nx">edges</span><span class="p">,</span><span class="nx">mockG</span><span class="p">);</span>
<span class="p">});</span>
<span class="nx">it</span><span class="p">(</span><span class="s1">'should handle edges with styles defined'</span><span class="p">,</span> <span class="kd">function</span> <span class="p">()</span> <span class="p">{</span>
<span class="kd">var</span> <span class="nx">res</span> <span class="o">=</span> <span class="nx">flow</span><span class="p">.</span><span class="nx">parser</span><span class="p">.</span><span class="nx">parse</span><span class="p">(</span><span class="s1">'graph TD;A---B; linkStyle 0 stroke:val1,stroke-width:val2;'</span><span class="p">);</span>
<span class="kd">var</span> <span class="nx">vert</span> <span class="o">=</span> <span class="nx">flow</span><span class="p">.</span><span class="nx">parser</span><span class="p">.</span><span class="nx">yy</span><span class="p">.</span><span class="nx">getVertices</span><span class="p">();</span>
<span class="kd">var</span> <span class="nx">edges</span> <span class="o">=</span> <span class="nx">flow</span><span class="p">.</span><span class="nx">parser</span><span class="p">.</span><span class="nx">yy</span><span class="p">.</span><span class="nx">getEdges</span><span class="p">();</span>
<span class="kd">var</span> <span class="nx">mockG</span> <span class="o">=</span> <span class="p">{</span>
<span class="nx">setEdge</span><span class="o">:</span><span class="kd">function</span><span class="p">(</span><span class="nx">start</span><span class="p">,</span> <span class="nx">end</span><span class="p">,</span><span class="nx">options</span><span class="p">,</span><span class="nx">name</span><span class="p">){</span>
<span class="nx">expect</span><span class="p">(</span><span class="nx">start</span><span class="p">).</span><span class="nx">toBe</span><span class="p">(</span><span class="s1">'A'</span><span class="p">);</span>
<span class="nx">expect</span><span class="p">(</span><span class="nx">end</span><span class="p">).</span><span class="nx">toBe</span><span class="p">(</span><span class="s1">'B'</span><span class="p">);</span>
<span class="nx">expect</span><span class="p">(</span><span class="nx">options</span><span class="p">.</span><span class="nx">arrowhead</span><span class="p">).</span><span class="nx">toBe</span><span class="p">(</span><span class="s1">'none'</span><span class="p">);</span>
<span class="nx">expect</span><span class="p">(</span><span class="nx">options</span><span class="p">.</span><span class="nx">style</span><span class="p">).</span><span class="nx">toBe</span><span class="p">(</span><span class="s1">'stroke:val1;stroke-width:val2;'</span><span class="p">);</span>
<span class="p">}</span>
<span class="p">};</span>
<span class="nx">flowRend</span><span class="p">.</span><span class="nx">addEdges</span><span class="p">(</span><span class="nx">edges</span><span class="p">,</span><span class="nx">mockG</span><span class="p">);</span>
<span class="p">});</span>
<span class="nx">it</span><span class="p">(</span><span class="s1">'should handle edges with text and styles defined'</span><span class="p">,</span> <span class="kd">function</span> <span class="p">()</span> <span class="p">{</span>
<span class="kd">var</span> <span class="nx">res</span> <span class="o">=</span> <span class="nx">flow</span><span class="p">.</span><span class="nx">parser</span><span class="p">.</span><span class="nx">parse</span><span class="p">(</span><span class="s1">'graph TD;A---|the text|B; linkStyle 0 stroke:val1,stroke-width:val2;'</span><span class="p">);</span>
<span class="kd">var</span> <span class="nx">vert</span> <span class="o">=</span> <span class="nx">flow</span><span class="p">.</span><span class="nx">parser</span><span class="p">.</span><span class="nx">yy</span><span class="p">.</span><span class="nx">getVertices</span><span class="p">();</span>
<span class="kd">var</span> <span class="nx">edges</span> <span class="o">=</span> <span class="nx">flow</span><span class="p">.</span><span class="nx">parser</span><span class="p">.</span><span class="nx">yy</span><span class="p">.</span><span class="nx">getEdges</span><span class="p">();</span>
<span class="kd">var</span> <span class="nx">mockG</span> <span class="o">=</span> <span class="p">{</span>
<span class="nx">setEdge</span><span class="o">:</span><span class="kd">function</span><span class="p">(</span><span class="nx">start</span><span class="p">,</span> <span class="nx">end</span><span class="p">,</span><span class="nx">options</span><span class="p">,</span><span class="nx">name</span><span class="p">){</span>
<span class="nx">expect</span><span class="p">(</span><span class="nx">start</span><span class="p">).</span><span class="nx">toBe</span><span class="p">(</span><span class="s1">'A'</span><span class="p">);</span>
<span class="nx">expect</span><span class="p">(</span><span class="nx">end</span><span class="p">).</span><span class="nx">toBe</span><span class="p">(</span><span class="s1">'B'</span><span class="p">);</span>
<span class="nx">expect</span><span class="p">(</span><span class="nx">options</span><span class="p">.</span><span class="nx">arrowhead</span><span class="p">).</span><span class="nx">toBe</span><span class="p">(</span><span class="s1">'none'</span><span class="p">);</span>
<span class="nx">expect</span><span class="p">(</span><span class="nx">options</span><span class="p">.</span><span class="nx">label</span><span class="p">.</span><span class="nx">match</span><span class="p">(</span><span class="s1">'the text'</span><span class="p">)).</span><span class="nx">toBeTruthy</span><span class="p">();</span>
<span class="nx">expect</span><span class="p">(</span><span class="nx">options</span><span class="p">.</span><span class="nx">style</span><span class="p">).</span><span class="nx">toBe</span><span class="p">(</span><span class="s1">'stroke:val1;stroke-width:val2;'</span><span class="p">);</span>
<span class="p">}</span>
<span class="p">};</span>
<span class="nx">flowRend</span><span class="p">.</span><span class="nx">addEdges</span><span class="p">(</span><span class="nx">edges</span><span class="p">,</span><span class="nx">mockG</span><span class="p">);</span>
<span class="p">});</span>
<span class="p">});</span>
<span class="nx">describe</span><span class="p">(</span><span class="s1">'checking validity of input '</span><span class="p">,</span> <span class="kd">function</span><span class="p">(){</span>
<span class="nx">it</span><span class="p">(</span><span class="s1">'it should return false for an invalid definiton'</span><span class="p">,</span><span class="kd">function</span><span class="p">(){</span>
<span class="nx">spyOn</span><span class="p">(</span><span class="nx">global</span><span class="p">.</span><span class="nx">mermaid</span><span class="p">,</span><span class="s1">'parseError'</span><span class="p">);</span>
<span class="kd">var</span> <span class="nx">res</span> <span class="o">=</span> <span class="nx">mermaid</span><span class="p">.</span><span class="nx">parse</span><span class="p">(</span><span class="s1">'this is not a mermaid diagram definition'</span><span class="p">);</span>
<span class="nx">expect</span><span class="p">(</span><span class="nx">res</span><span class="p">).</span><span class="nx">toBe</span><span class="p">(</span><span class="kc">false</span><span class="p">);</span>
<span class="nx">expect</span><span class="p">(</span><span class="nx">global</span><span class="p">.</span><span class="nx">mermaid</span><span class="p">.</span><span class="nx">parseError</span><span class="p">).</span><span class="nx">toHaveBeenCalled</span><span class="p">();</span>
<span class="p">});</span>
<span class="nx">it</span><span class="p">(</span><span class="s1">'it should return true for a valid flow definition'</span><span class="p">,</span><span class="kd">function</span><span class="p">(){</span>
<span class="nx">spyOn</span><span class="p">(</span><span class="nx">global</span><span class="p">.</span><span class="nx">mermaid</span><span class="p">,</span><span class="s1">'parseError'</span><span class="p">);</span>
<span class="kd">var</span> <span class="nx">res</span> <span class="o">=</span> <span class="nx">mermaid</span><span class="p">.</span><span class="nx">parse</span><span class="p">(</span><span class="s1">'graph TD;A--x|text including URL space|B;'</span><span class="p">);</span>
<span class="nx">expect</span><span class="p">(</span><span class="nx">res</span><span class="p">).</span><span class="nx">toBe</span><span class="p">(</span><span class="kc">true</span><span class="p">);</span>
<span class="nx">expect</span><span class="p">(</span><span class="nx">global</span><span class="p">.</span><span class="nx">mermaid</span><span class="p">.</span><span class="nx">parseError</span><span class="p">).</span><span class="nx">not</span><span class="p">.</span><span class="nx">toHaveBeenCalled</span><span class="p">();</span>
<span class="p">});</span>
<span class="nx">it</span><span class="p">(</span><span class="s1">'it should return false for an invalid flow definition'</span><span class="p">,</span><span class="kd">function</span><span class="p">(){</span>
<span class="nx">spyOn</span><span class="p">(</span><span class="nx">global</span><span class="p">.</span><span class="nx">mermaid</span><span class="p">,</span><span class="s1">'parseError'</span><span class="p">);</span>
<span class="kd">var</span> <span class="nx">res</span> <span class="o">=</span> <span class="nx">mermaid</span><span class="p">.</span><span class="nx">parse</span><span class="p">(</span><span class="s1">'graph TQ;A--x|text including URL space|B;'</span><span class="p">);</span>
<span class="nx">expect</span><span class="p">(</span><span class="nx">res</span><span class="p">).</span><span class="nx">toBe</span><span class="p">(</span><span class="kc">false</span><span class="p">);</span>
<span class="nx">expect</span><span class="p">(</span><span class="nx">global</span><span class="p">.</span><span class="nx">mermaid</span><span class="p">.</span><span class="nx">parseError</span><span class="p">).</span><span class="nx">toHaveBeenCalled</span><span class="p">();</span>
<span class="p">});</span>
<span class="nx">it</span><span class="p">(</span><span class="s1">'it should return true for a valid sequenceDiagram definition'</span><span class="p">,</span><span class="kd">function</span><span class="p">(){</span>
<span class="nx">spyOn</span><span class="p">(</span><span class="nx">global</span><span class="p">.</span><span class="nx">mermaid</span><span class="p">,</span><span class="s1">'parseError'</span><span class="p">);</span>
<span class="kd">var</span> <span class="nx">str</span> <span class="o">=</span> <span class="s1">'sequenceDiagram\n'</span> <span class="o">+</span>
<span class="s1">'Alice->Bob: Hello Bob, how are you?\n\n'</span> <span class="o">+</span>
<span class="s1">'%% Comment\n'</span> <span class="o">+</span>
<span class="s1">'Note right of Bob: Bob thinks\n'</span> <span class="o">+</span>
<span class="s1">'alt isWell\n\n'</span> <span class="o">+</span>
<span class="s1">'Bob-->Alice: I am good thanks!\n'</span> <span class="o">+</span>
<span class="s1">'else isSick\n'</span> <span class="o">+</span>
<span class="s1">'Bob-->Alice: Feel sick...\n'</span> <span class="o">+</span>
<span class="s1">'end'</span><span class="p">;</span>
<span class="kd">var</span> <span class="nx">res</span> <span class="o">=</span> <span class="nx">mermaid</span><span class="p">.</span><span class="nx">parse</span><span class="p">(</span><span class="nx">str</span><span class="p">);</span>
<span class="nx">expect</span><span class="p">(</span><span class="nx">res</span><span class="p">).</span><span class="nx">toBe</span><span class="p">(</span><span class="kc">true</span><span class="p">);</span>
<span class="nx">expect</span><span class="p">(</span><span class="nx">global</span><span class="p">.</span><span class="nx">mermaid</span><span class="p">.</span><span class="nx">parseError</span><span class="p">).</span><span class="nx">not</span><span class="p">.</span><span class="nx">toHaveBeenCalled</span><span class="p">();</span>
<span class="p">});</span>
<span class="nx">it</span><span class="p">(</span><span class="s1">'it should return false for an invalid sequenceDiagram definition'</span><span class="p">,</span><span class="kd">function</span><span class="p">(){</span>
<span class="nx">spyOn</span><span class="p">(</span><span class="nx">global</span><span class="p">.</span><span class="nx">mermaid</span><span class="p">,</span><span class="s1">'parseError'</span><span class="p">);</span>
<span class="kd">var</span> <span class="nx">str</span> <span class="o">=</span> <span class="s1">'sequenceDiagram\n'</span> <span class="o">+</span>
<span class="s1">'Alice:->Bob: Hello Bob, how are you?\n\n'</span> <span class="o">+</span>
<span class="s1">'%% Comment\n'</span> <span class="o">+</span>
<span class="s1">'Note right of Bob: Bob thinks\n'</span> <span class="o">+</span>
<span class="s1">'alt isWell\n\n'</span> <span class="o">+</span>
<span class="s1">'Bob-->Alice: I am good thanks!\n'</span> <span class="o">+</span>
<span class="s1">'else isSick\n'</span> <span class="o">+</span>
<span class="s1">'Bob-->Alice: Feel sick...\n'</span> <span class="o">+</span>
<span class="s1">'end'</span><span class="p">;</span>
<span class="kd">var</span> <span class="nx">res</span> <span class="o">=</span> <span class="nx">mermaid</span><span class="p">.</span><span class="nx">parse</span><span class="p">(</span><span class="nx">str</span><span class="p">);</span>
<span class="nx">expect</span><span class="p">(</span><span class="nx">res</span><span class="p">).</span><span class="nx">toBe</span><span class="p">(</span><span class="kc">false</span><span class="p">);</span>
<span class="nx">expect</span><span class="p">(</span><span class="nx">global</span><span class="p">.</span><span class="nx">mermaid</span><span class="p">.</span><span class="nx">parseError</span><span class="p">).</span><span class="nx">toHaveBeenCalled</span><span class="p">();</span>
<span class="p">});</span>
<span class="nx">it</span><span class="p">(</span><span class="s1">'it should return true for a valid dot definition'</span><span class="p">,</span><span class="kd">function</span><span class="p">(){</span>
<span class="nx">spyOn</span><span class="p">(</span><span class="nx">global</span><span class="p">.</span><span class="nx">mermaid</span><span class="p">,</span><span class="s1">'parseError'</span><span class="p">);</span>
<span class="kd">var</span> <span class="nx">res</span> <span class="o">=</span> <span class="nx">mermaid</span><span class="p">.</span><span class="nx">parse</span><span class="p">(</span><span class="s1">'digraph\n'</span> <span class="o">+</span>
<span class="s1">'{\n'</span> <span class="o">+</span>
<span class="s1">' a -> b -> c -- d -> e;\n'</span> <span class="o">+</span>
<span class="s1">' a -- e;\n'</span> <span class="o">+</span>
<span class="s1">'}'</span><span class="p">);</span>
<span class="nx">expect</span><span class="p">(</span><span class="nx">res</span><span class="p">).</span><span class="nx">toBe</span><span class="p">(</span><span class="kc">true</span><span class="p">);</span>
<span class="nx">expect</span><span class="p">(</span><span class="nx">global</span><span class="p">.</span><span class="nx">mermaid</span><span class="p">.</span><span class="nx">parseError</span><span class="p">).</span><span class="nx">not</span><span class="p">.</span><span class="nx">toHaveBeenCalled</span><span class="p">();</span>
<span class="p">});</span>
<span class="nx">it</span><span class="p">(</span><span class="s1">'it should return false for an invalid dot definition'</span><span class="p">,</span><span class="kd">function</span><span class="p">(){</span>
<span class="nx">spyOn</span><span class="p">(</span><span class="nx">global</span><span class="p">.</span><span class="nx">mermaid</span><span class="p">,</span><span class="s1">'parseError'</span><span class="p">);</span>
<span class="kd">var</span> <span class="nx">res</span> <span class="o">=</span> <span class="nx">mermaid</span><span class="p">.</span><span class="nx">parse</span><span class="p">(</span><span class="s1">'digraph\n'</span> <span class="o">+</span>
<span class="s1">'{\n'</span> <span class="o">+</span>
<span class="s1">'a -:> b -> c -- d -> e;\n'</span> <span class="o">+</span>
<span class="s1">'a -- e;\n'</span> <span class="o">+</span>
<span class="s1">'}'</span><span class="p">);</span>
<span class="nx">expect</span><span class="p">(</span><span class="nx">res</span><span class="p">).</span><span class="nx">toBe</span><span class="p">(</span><span class="kc">false</span><span class="p">);</span>
<span class="nx">expect</span><span class="p">(</span><span class="nx">global</span><span class="p">.</span><span class="nx">mermaid</span><span class="p">.</span><span class="nx">parseError</span><span class="p">).</span><span class="nx">toHaveBeenCalled</span><span class="p">();</span>
<span class="p">});</span>
<span class="p">});</span>
<span class="p">});</span>
</pre></div>
</td>
</tr>
</tbody>
</table>
</div>
</body>
</html>