UNPKG

mermaid

Version:

Markdownish syntax for generating flowcharts, sequence diagrams and gantt charts.

363 lines (312 loc) 44.4 kB
<!DOCTYPE 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">&#182;</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">&#182;</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">&quot;rewire&quot;</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">&quot;./utils&quot;</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">&quot;./mermaid&quot;</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">&#39;./logger&#39;</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">&#39;when using mermaid and &#39;</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">&#39;when detecting chart type &#39;</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">&#182;</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">&#39;mock-browser&#39;</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">&#182;</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">&#39;should not start rendering with mermaid_config.startOnLoad set to false&#39;</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">&#39;./mermaid&#39;</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">&#39;&lt;div class=&quot;mermaid&quot;&gt;graph TD;\na;&lt;/div&gt;&#39;</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">&#39;init&#39;</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">&#182;</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">&#39;should not start rendering with mermaid.startOnLoad set to false&#39;</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">&#39;./mermaid&#39;</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">&#39;&lt;div class=&quot;mermaid&quot;&gt;graph TD;\na;&lt;/div&gt;&#39;</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">&#39;init&#39;</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">&#39;should start rendering with both startOnLoad set&#39;</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">&#39;./mermaid&#39;</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">&#39;&lt;div class=&quot;mermaid&quot;&gt;graph TD;\na;&lt;/div&gt;&#39;</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">&#39;init&#39;</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">&#39;should start rendering with mermaid.startOnLoad set and no mermaid_config defined&#39;</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">&#39;./mermaid&#39;</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">&#39;&lt;div class=&quot;mermaid&quot;&gt;graph TD;\na;&lt;/div&gt;&#39;</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">&#39;init&#39;</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">&#39;should start rendering as a default with no changes performed&#39;</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">&#39;./mermaid&#39;</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">&#39;&lt;div class=&quot;mermaid&quot;&gt;graph TD;\na;&lt;/div&gt;&#39;</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">&#39;init&#39;</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">&#39;when calling addEdges &#39;</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">&#39;./diagrams/flowchart/graphDb&#39;</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">&#39;./diagrams/flowchart/parser/flow&#39;</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">&#39;./diagrams/flowchart/flowRenderer&#39;</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">&#39;mock-browser&#39;</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">&#39;./mermaid&#39;</span><span class="p">);</span> <span class="p">});</span> <span class="nx">it</span><span class="p">(</span><span class="s1">&#39;it should handle edges with text&#39;</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">&#39;graph TD;A--&gt;|text ex|B;&#39;</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">&#39;A&#39;</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">&#39;B&#39;</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">&#39;normal&#39;</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">&#39;text ex&#39;</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">&#39;should handle edges without text&#39;</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">&#39;graph TD;A--&gt;B;&#39;</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">&#39;A&#39;</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">&#39;B&#39;</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">&#39;normal&#39;</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">&#39;should handle open-ended edges&#39;</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">&#39;graph TD;A---B;&#39;</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">&#39;A&#39;</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">&#39;B&#39;</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">&#39;none&#39;</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">&#39;should handle edges with styles defined&#39;</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">&#39;graph TD;A---B; linkStyle 0 stroke:val1,stroke-width:val2;&#39;</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">&#39;A&#39;</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">&#39;B&#39;</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">&#39;none&#39;</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">&#39;stroke:val1;stroke-width:val2;&#39;</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">&#39;should handle edges with text and styles defined&#39;</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">&#39;graph TD;A---|the text|B; linkStyle 0 stroke:val1,stroke-width:val2;&#39;</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">&#39;A&#39;</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">&#39;B&#39;</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">&#39;none&#39;</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">&#39;the text&#39;</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">&#39;stroke:val1;stroke-width:val2;&#39;</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">&#39;checking validity of input &#39;</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">&#39;it should return false for an invalid definiton&#39;</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">&#39;parseError&#39;</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">&#39;this is not a mermaid diagram definition&#39;</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">&#39;it should return true for a valid flow definition&#39;</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">&#39;parseError&#39;</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">&#39;graph TD;A--x|text including URL space|B;&#39;</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">&#39;it should return false for an invalid flow definition&#39;</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">&#39;parseError&#39;</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">&#39;graph TQ;A--x|text including URL space|B;&#39;</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">&#39;it should return true for a valid sequenceDiagram definition&#39;</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">&#39;parseError&#39;</span><span class="p">);</span> <span class="kd">var</span> <span class="nx">str</span> <span class="o">=</span> <span class="s1">&#39;sequenceDiagram\n&#39;</span> <span class="o">+</span> <span class="s1">&#39;Alice-&gt;Bob: Hello Bob, how are you?\n\n&#39;</span> <span class="o">+</span> <span class="s1">&#39;%% Comment\n&#39;</span> <span class="o">+</span> <span class="s1">&#39;Note right of Bob: Bob thinks\n&#39;</span> <span class="o">+</span> <span class="s1">&#39;alt isWell\n\n&#39;</span> <span class="o">+</span> <span class="s1">&#39;Bob--&gt;Alice: I am good thanks!\n&#39;</span> <span class="o">+</span> <span class="s1">&#39;else isSick\n&#39;</span> <span class="o">+</span> <span class="s1">&#39;Bob--&gt;Alice: Feel sick...\n&#39;</span> <span class="o">+</span> <span class="s1">&#39;end&#39;</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">&#39;it should return false for an invalid sequenceDiagram definition&#39;</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">&#39;parseError&#39;</span><span class="p">);</span> <span class="kd">var</span> <span class="nx">str</span> <span class="o">=</span> <span class="s1">&#39;sequenceDiagram\n&#39;</span> <span class="o">+</span> <span class="s1">&#39;Alice:-&gt;Bob: Hello Bob, how are you?\n\n&#39;</span> <span class="o">+</span> <span class="s1">&#39;%% Comment\n&#39;</span> <span class="o">+</span> <span class="s1">&#39;Note right of Bob: Bob thinks\n&#39;</span> <span class="o">+</span> <span class="s1">&#39;alt isWell\n\n&#39;</span> <span class="o">+</span> <span class="s1">&#39;Bob--&gt;Alice: I am good thanks!\n&#39;</span> <span class="o">+</span> <span class="s1">&#39;else isSick\n&#39;</span> <span class="o">+</span> <span class="s1">&#39;Bob--&gt;Alice: Feel sick...\n&#39;</span> <span class="o">+</span> <span class="s1">&#39;end&#39;</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">&#39;it should return true for a valid dot definition&#39;</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">&#39;parseError&#39;</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">&#39;digraph\n&#39;</span> <span class="o">+</span> <span class="s1">&#39;{\n&#39;</span> <span class="o">+</span> <span class="s1">&#39; a -&gt; b -&gt; c -- d -&gt; e;\n&#39;</span> <span class="o">+</span> <span class="s1">&#39; a -- e;\n&#39;</span> <span class="o">+</span> <span class="s1">&#39;}&#39;</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">&#39;it should return false for an invalid dot definition&#39;</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">&#39;parseError&#39;</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">&#39;digraph\n&#39;</span> <span class="o">+</span> <span class="s1">&#39;{\n&#39;</span> <span class="o">+</span> <span class="s1">&#39;a -:&gt; b -&gt; c -- d -&gt; e;\n&#39;</span> <span class="o">+</span> <span class="s1">&#39;a -- e;\n&#39;</span> <span class="o">+</span> <span class="s1">&#39;}&#39;</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>