UNPKG

mermaid

Version:

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

344 lines (294 loc) 35.4 kB
<!DOCTYPE html> <html> <head> <title>utils.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/utils.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="#utils.spec.js">utils.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="utils.spec.js"> <h1> <a href="#utils.spec.js" name="utils.spec.js" class="pilcrow">&#182;</a>utils.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-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">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 detecting chart type &#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">utils</span> <span class="o">=</span> <span class="nx">require</span><span class="p">(</span><span class="s1">&#39;./utils&#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="p">});</span> <span class="nx">it</span><span class="p">(</span><span class="s1">&#39;should handle a sequence defintion&#39;</span><span class="p">,</span> <span class="kd">function</span> <span class="p">()</span> <span class="p">{</span> <span class="nx">str</span> <span class="o">=</span> <span class="s1">&#39;sequence TB\nbfs1:queue&#39;</span><span class="p">;</span> <span class="kd">var</span> <span class="nx">type</span> <span class="o">=</span> <span class="nx">utils</span><span class="p">.</span><span class="nx">detectType</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">type</span><span class="p">).</span><span class="nx">toBe</span><span class="p">(</span><span class="s1">&#39;sequence&#39;</span><span class="p">);</span> <span class="p">});</span> <span class="nx">it</span><span class="p">(</span><span class="s1">&#39;should handle a sequence defintion with leading spaces&#39;</span><span class="p">,</span> <span class="kd">function</span> <span class="p">()</span> <span class="p">{</span> <span class="nx">str</span> <span class="o">=</span> <span class="s1">&#39; sequence TB\nbfs1:queue&#39;</span><span class="p">;</span> <span class="kd">var</span> <span class="nx">type</span> <span class="o">=</span> <span class="nx">utils</span><span class="p">.</span><span class="nx">detectType</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">type</span><span class="p">).</span><span class="nx">toBe</span><span class="p">(</span><span class="s1">&#39;sequence&#39;</span><span class="p">);</span> <span class="p">});</span> <span class="nx">it</span><span class="p">(</span><span class="s1">&#39;should handle a graph defintion&#39;</span><span class="p">,</span> <span class="kd">function</span> <span class="p">()</span> <span class="p">{</span> <span class="nx">str</span> <span class="o">=</span> <span class="s1">&#39;graph TB\nbfs1:queue&#39;</span><span class="p">;</span> <span class="kd">var</span> <span class="nx">type</span> <span class="o">=</span> <span class="nx">utils</span><span class="p">.</span><span class="nx">detectType</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">type</span><span class="p">).</span><span class="nx">toBe</span><span class="p">(</span><span class="s1">&#39;graph&#39;</span><span class="p">);</span> <span class="p">});</span> <span class="nx">it</span><span class="p">(</span><span class="s1">&#39;should handle a graph defintion with leading spaces&#39;</span><span class="p">,</span> <span class="kd">function</span> <span class="p">()</span> <span class="p">{</span> <span class="nx">str</span> <span class="o">=</span> <span class="s1">&#39; graph TB\nbfs1:queue&#39;</span><span class="p">;</span> <span class="kd">var</span> <span class="nx">type</span> <span class="o">=</span> <span class="nx">utils</span><span class="p">.</span><span class="nx">detectType</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">type</span><span class="p">).</span><span class="nx">toBe</span><span class="p">(</span><span class="s1">&#39;graph&#39;</span><span class="p">);</span> <span class="p">});</span> <span class="nx">it</span><span class="p">(</span><span class="s1">&#39;should handle a graph defintion with leading spaces and newline&#39;</span><span class="p">,</span> <span class="kd">function</span> <span class="p">()</span> <span class="p">{</span> <span class="nx">str</span> <span class="o">=</span> <span class="s1">&#39; \n graph TB\nbfs1:queue&#39;</span><span class="p">;</span> <span class="kd">var</span> <span class="nx">type</span> <span class="o">=</span> <span class="nx">utils</span><span class="p">.</span><span class="nx">detectType</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">type</span><span class="p">).</span><span class="nx">toBe</span><span class="p">(</span><span class="s1">&#39;graph&#39;</span><span class="p">);</span> <span class="p">});</span> <span class="nx">it</span><span class="p">(</span><span class="s1">&#39;should handle a sequence defintion with leading spaces and newline&#39;</span><span class="p">,</span> <span class="kd">function</span> <span class="p">()</span> <span class="p">{</span> <span class="nx">str</span> <span class="o">=</span> <span class="s1">&#39; \n sequence TB\nbfs1:queue&#39;</span><span class="p">;</span> <span class="kd">var</span> <span class="nx">type</span> <span class="o">=</span> <span class="nx">utils</span><span class="p">.</span><span class="nx">detectType</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">type</span><span class="p">).</span><span class="nx">toBe</span><span class="p">(</span><span class="s1">&#39;sequence&#39;</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 cloning CSS &#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">utils</span> <span class="o">=</span> <span class="nx">require</span><span class="p">(</span><span class="s1">&#39;./utils&#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="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> </pre></div> </td> </tr> <tr> <td class="docs"> <div class="pilwrap"> <a class="pilcrow" href="#section-2" id="section-2">&#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> </pre></div> </td> </tr> <tr> <td class="docs"> <div class="pilwrap"> <a class="pilcrow" href="#section-3" id="section-3">&#182;</a> </div> <p>document.body.innerHTML = &#39;&#39;; document.body.innerHTML = &#39;&#39;;</p> </td> <td class="code highlight"><div class="highlight"><pre> <span class="p">});</span> <span class="kd">function</span> <span class="nx">stylesToArray</span><span class="p">(</span><span class="nx">svg</span><span class="p">)</span> <span class="p">{</span> <span class="kd">var</span> <span class="nx">styleSheets</span> <span class="o">=</span> <span class="nx">svg</span><span class="p">.</span><span class="nx">getElementsByTagName</span><span class="p">(</span><span class="s2">&quot;style&quot;</span><span class="p">);</span> <span class="nx">expect</span><span class="p">(</span><span class="nx">styleSheets</span><span class="p">.</span><span class="nx">length</span><span class="p">).</span><span class="nx">toBe</span><span class="p">(</span><span class="mi">1</span><span class="p">);</span> <span class="kd">var</span> <span class="nx">styleSheet</span> <span class="o">=</span> <span class="nx">styleSheets</span><span class="p">[</span><span class="mi">0</span><span class="p">];</span> <span class="kd">var</span> <span class="nx">innerStyle</span> <span class="o">=</span> <span class="nx">styleSheet</span><span class="p">.</span><span class="nx">innerHTML</span><span class="p">;</span> <span class="kd">var</span> <span class="nx">styleArr</span> <span class="o">=</span> <span class="nx">innerStyle</span><span class="p">.</span><span class="nx">split</span><span class="p">(</span><span class="s2">&quot;\n&quot;</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>Remove first and last two lines to remove the CDATA</p> </td> <td class="code highlight"><div class="highlight"><pre> <span class="nx">expect</span><span class="p">(</span><span class="nx">styleArr</span><span class="p">.</span><span class="nx">length</span><span class="p">).</span><span class="nx">toBeGreaterThan</span><span class="p">(</span><span class="mi">2</span><span class="p">);</span> <span class="kd">var</span> <span class="nx">styleArrTrim</span> <span class="o">=</span> <span class="nx">styleArr</span><span class="p">.</span><span class="nx">slice</span><span class="p">(</span><span class="mi">1</span><span class="p">,</span><span class="o">-</span><span class="mi">2</span><span class="p">);</span> </pre></div> </td> </tr> <tr> <td class="docs"> <div class="pilwrap"> <a class="pilcrow" href="#section-5" id="section-5">&#182;</a> </div> <p>Remove all empty lines</p> </td> <td class="code highlight"><div class="highlight"><pre> <span class="k">for</span> <span class="p">(</span><span class="kd">var</span> <span class="nx">i</span> <span class="o">=</span> <span class="mi">0</span><span class="p">;</span> <span class="nx">i</span> <span class="o">&lt;</span> <span class="nx">styleArrTrim</span><span class="p">.</span><span class="nx">length</span><span class="p">;</span> <span class="nx">i</span><span class="o">++</span><span class="p">)</span> <span class="p">{</span> <span class="k">if</span> <span class="p">(</span><span class="nx">styleArrTrim</span><span class="p">[</span><span class="nx">i</span><span class="p">].</span><span class="nx">trim</span><span class="p">()</span> <span class="o">===</span> <span class="s1">&#39;&#39;</span><span class="p">)</span> <span class="p">{</span> <span class="nx">styleArrTrim</span><span class="p">.</span><span class="nx">splice</span><span class="p">(</span><span class="nx">i</span><span class="p">,</span><span class="mi">1</span><span class="p">);</span> <span class="nx">i</span><span class="o">--</span><span class="p">;</span> <span class="p">}</span> <span class="p">}</span> <span class="k">return</span> <span class="nx">styleArrTrim</span><span class="p">;</span> <span class="p">}</span> <span class="kd">function</span> <span class="nx">addStyleToDocument</span><span class="p">()</span> <span class="p">{</span> <span class="kd">var</span> <span class="nx">styleSheetCount</span> <span class="o">=</span> <span class="nb">document</span><span class="p">.</span><span class="nx">styleSheets</span><span class="p">.</span><span class="nx">length</span><span class="p">;</span> <span class="kd">var</span> <span class="nx">s</span> <span class="o">=</span> <span class="nb">document</span><span class="p">.</span><span class="nx">createElement</span><span class="p">(</span><span class="s1">&#39;style&#39;</span><span class="p">);</span> <span class="nx">s</span><span class="p">.</span><span class="nx">innerHTML</span> <span class="o">=</span> <span class="s1">&#39;.node { stroke:#eee; }\n.node-square { stroke:#bbb; }\n&#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">appendChild</span><span class="p">(</span><span class="nx">s</span><span class="p">);</span> <span class="p">}</span> <span class="kd">function</span> <span class="nx">addSecondStyleToDocument</span><span class="p">()</span> <span class="p">{</span> <span class="kd">var</span> <span class="nx">styleSheetCount</span> <span class="o">=</span> <span class="nb">document</span><span class="p">.</span><span class="nx">styleSheets</span><span class="p">.</span><span class="nx">length</span><span class="p">;</span> <span class="kd">var</span> <span class="nx">s</span> <span class="o">=</span> <span class="nb">document</span><span class="p">.</span><span class="nx">createElement</span><span class="p">(</span><span class="s1">&#39;style&#39;</span><span class="p">);</span> <span class="nx">s</span><span class="p">.</span><span class="nx">innerHTML</span> <span class="o">=</span> <span class="s1">&#39;.node2 { stroke:#eee; }\n.node-square { stroke:#beb; }\n&#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">appendChild</span><span class="p">(</span><span class="nx">s</span><span class="p">);</span> <span class="p">}</span> <span class="kd">function</span> <span class="nx">generateSVG</span><span class="p">()</span> <span class="p">{</span> <span class="kd">var</span> <span class="nx">svg</span> <span class="o">=</span> <span class="nb">document</span><span class="p">.</span><span class="nx">createElement</span><span class="p">(</span><span class="s1">&#39;svg&#39;</span><span class="p">);</span> <span class="nx">svg</span><span class="p">.</span><span class="nx">setAttribute</span><span class="p">(</span><span class="s1">&#39;id&#39;</span><span class="p">,</span> <span class="s1">&#39;mermaid-01&#39;</span><span class="p">);</span> <span class="kd">var</span> <span class="nx">g1</span> <span class="o">=</span> <span class="nb">document</span><span class="p">.</span><span class="nx">createElement</span><span class="p">(</span><span class="s1">&#39;g&#39;</span><span class="p">);</span> <span class="nx">g1</span><span class="p">.</span><span class="nx">setAttribute</span><span class="p">(</span><span class="s1">&#39;class&#39;</span><span class="p">,</span> <span class="s1">&#39;node&#39;</span><span class="p">);</span> <span class="nx">svg</span><span class="p">.</span><span class="nx">appendChild</span><span class="p">(</span><span class="nx">g1</span><span class="p">);</span> <span class="kd">var</span> <span class="nx">g2</span> <span class="o">=</span> <span class="nb">document</span><span class="p">.</span><span class="nx">createElement</span><span class="p">(</span><span class="s1">&#39;g&#39;</span><span class="p">);</span> <span class="nx">g2</span><span class="p">.</span><span class="nx">setAttribute</span><span class="p">(</span><span class="s1">&#39;class&#39;</span><span class="p">,</span> <span class="s1">&#39;node-square&#39;</span><span class="p">);</span> <span class="nx">svg</span><span class="p">.</span><span class="nx">appendChild</span><span class="p">(</span><span class="nx">g2</span><span class="p">);</span> <span class="k">return</span> <span class="nx">svg</span><span class="p">;</span> <span class="p">}</span> <span class="kd">function</span> <span class="nx">addMermaidSVGwithStyleToDocument</span><span class="p">()</span> <span class="p">{</span> <span class="kd">var</span> <span class="nx">styleSheetCount</span> <span class="o">=</span> <span class="nb">document</span><span class="p">.</span><span class="nx">styleSheets</span><span class="p">.</span><span class="nx">length</span><span class="p">;</span> <span class="kd">var</span> <span class="nx">svg</span> <span class="o">=</span> <span class="nb">document</span><span class="p">.</span><span class="nx">createElement</span><span class="p">(</span><span class="s1">&#39;svg&#39;</span><span class="p">);</span> <span class="nx">svg</span><span class="p">.</span><span class="nx">setAttribute</span><span class="p">(</span><span class="s1">&#39;id&#39;</span><span class="p">,</span> <span class="s1">&#39;mermaid-03&#39;</span><span class="p">);</span> <span class="kd">var</span> <span class="nx">s</span> <span class="o">=</span> <span class="nb">document</span><span class="p">.</span><span class="nx">createElement</span><span class="p">(</span><span class="s1">&#39;style&#39;</span><span class="p">);</span> <span class="nx">s</span><span class="p">.</span><span class="nx">setAttribute</span><span class="p">(</span><span class="s1">&#39;type&#39;</span><span class="p">,</span> <span class="s1">&#39;text/css&#39;</span><span class="p">);</span> <span class="nx">s</span><span class="p">.</span><span class="nx">setAttribute</span><span class="p">(</span><span class="s1">&#39;title&#39;</span><span class="p">,</span> <span class="s1">&#39;mermaid-svg-internal-css&#39;</span><span class="p">);</span> <span class="nx">s</span><span class="p">.</span><span class="nx">innerHTML</span> <span class="o">=</span> <span class="s1">&#39;#mermaid-05 .node2 { stroke:#eee; }\n.node-square { stroke:#bfe; }\n&#39;</span><span class="p">;</span> <span class="nx">svg</span><span class="p">.</span><span class="nx">appendChild</span><span class="p">(</span><span class="nx">s</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">appendChild</span><span class="p">(</span><span class="nx">svg</span><span class="p">);</span> <span class="nb">document</span><span class="p">.</span><span class="nx">styleSheets</span><span class="p">[</span><span class="nx">styleSheetCount</span><span class="p">].</span><span class="nx">title</span> <span class="o">=</span> <span class="s1">&#39;mermaid-svg-internal-css&#39;</span><span class="p">;</span> <span class="p">}</span> <span class="nx">it</span><span class="p">(</span><span class="s1">&#39;should handle an empty set of classes&#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">svg</span> <span class="o">=</span> <span class="nb">document</span><span class="p">.</span><span class="nx">createElement</span><span class="p">(</span><span class="s1">&#39;svg&#39;</span><span class="p">);</span> <span class="nx">svg</span><span class="p">.</span><span class="nx">setAttribute</span><span class="p">(</span><span class="s1">&#39;id&#39;</span><span class="p">,</span> <span class="s1">&#39;mermaid-01&#39;</span><span class="p">);</span> <span class="nx">utils</span><span class="p">.</span><span class="nx">cloneCssStyles</span><span class="p">(</span><span class="nx">svg</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-6" id="section-6">&#182;</a> </div> <p>Should not create style element if not needed</p> </td> <td class="code highlight"><div class="highlight"><pre> <span class="nx">expect</span><span class="p">(</span><span class="nx">svg</span><span class="p">.</span><span class="nx">innerHTML</span><span class="p">).</span><span class="nx">toBe</span><span class="p">(</span><span class="s1">&#39;&#39;</span><span class="p">);</span> <span class="p">});</span> <span class="nx">it</span><span class="p">(</span><span class="s1">&#39;should handle a default class&#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">svg</span> <span class="o">=</span> <span class="nb">document</span><span class="p">.</span><span class="nx">createElement</span><span class="p">(</span><span class="s1">&#39;svg&#39;</span><span class="p">);</span> <span class="nx">svg</span><span class="p">.</span><span class="nx">setAttribute</span><span class="p">(</span><span class="s1">&#39;id&#39;</span><span class="p">,</span> <span class="s1">&#39;mermaid-01&#39;</span><span class="p">);</span> <span class="nx">utils</span><span class="p">.</span><span class="nx">cloneCssStyles</span><span class="p">(</span><span class="nx">svg</span><span class="p">,</span> <span class="p">{</span> <span class="s2">&quot;default&quot;</span><span class="o">:</span> <span class="p">{</span> <span class="s2">&quot;styles&quot;</span><span class="o">:</span> <span class="p">[</span><span class="s2">&quot;stroke:#fff&quot;</span><span class="p">,</span><span class="s2">&quot;stroke-width:1.5px&quot;</span><span class="p">]</span><span class="err"> </span><span class="p">}</span> <span class="p">});</span> <span class="nx">expect</span><span class="p">(</span><span class="nx">stylesToArray</span><span class="p">(</span><span class="nx">svg</span><span class="p">)).</span><span class="nx">toEqual</span><span class="p">([</span> <span class="s1">&#39;#mermaid-01 .node { stroke:#fff; stroke-width:1.5px; }&#39;</span> <span class="p">]);</span> </pre></div> </td> </tr> <tr> <td class="docs"> <div class="pilwrap"> <a class="pilcrow" href="#section-7" id="section-7">&#182;</a> </div> <p>Also verify the elements around the styling</p> </td> <td class="code highlight"><div class="highlight"><pre> <span class="nx">expect</span><span class="p">(</span><span class="nx">svg</span><span class="p">.</span><span class="nx">innerHTML</span><span class="p">).</span><span class="nx">toBe</span><span class="p">(</span><span class="s1">&#39;&lt;style type=&quot;text/css&quot; title=&quot;mermaid-svg-internal-css&quot;&gt;/* &lt;![CDATA[ */\n#mermaid-01 .node { stroke:#fff; stroke-width:1.5px; }\n/* ]]&gt; */\n&lt;/style&gt;&#39;</span><span class="p">);</span> <span class="p">});</span> <span class="nx">it</span><span class="p">(</span><span class="s1">&#39;should handle stylesheet in document with no classes in SVG&#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">svg</span> <span class="o">=</span> <span class="nb">document</span><span class="p">.</span><span class="nx">createElement</span><span class="p">(</span><span class="s1">&#39;svg&#39;</span><span class="p">);</span> <span class="nx">svg</span><span class="p">.</span><span class="nx">setAttribute</span><span class="p">(</span><span class="s1">&#39;id&#39;</span><span class="p">,</span> <span class="s1">&#39;mermaid-01&#39;</span><span class="p">);</span> <span class="nx">addStyleToDocument</span><span class="p">(</span><span class="s1">&#39;mermaid&#39;</span><span class="p">);</span> <span class="nx">utils</span><span class="p">.</span><span class="nx">cloneCssStyles</span><span class="p">(</span><span class="nx">svg</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-8" id="section-8">&#182;</a> </div> <p>Should not create style element if not needed</p> </td> <td class="code highlight"><div class="highlight"><pre> <span class="nx">expect</span><span class="p">(</span><span class="nx">svg</span><span class="p">.</span><span class="nx">innerHTML</span><span class="p">).</span><span class="nx">toBe</span><span class="p">(</span><span class="s1">&#39;&#39;</span><span class="p">);</span> <span class="p">});</span> <span class="nx">it</span><span class="p">(</span><span class="s1">&#39;should handle stylesheet in document with classes in SVG&#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">svg</span> <span class="o">=</span> <span class="nx">generateSVG</span><span class="p">();</span> <span class="nx">addStyleToDocument</span><span class="p">();</span> <span class="nx">utils</span><span class="p">.</span><span class="nx">cloneCssStyles</span><span class="p">(</span><span class="nx">svg</span><span class="p">,</span> <span class="p">{});</span> <span class="nx">expect</span><span class="p">(</span><span class="nx">stylesToArray</span><span class="p">(</span><span class="nx">svg</span><span class="p">)).</span><span class="nx">toEqual</span><span class="p">([</span> <span class="s1">&#39;.node { stroke: #eee; }&#39;</span><span class="p">,</span> <span class="s1">&#39;.node-square { stroke: #bbb; }&#39;</span><span class="p">]);</span> <span class="p">});</span> <span class="nx">it</span><span class="p">(</span><span class="s1">&#39;should handle multiple stylesheets in document with classes in SVG&#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">svg</span> <span class="o">=</span> <span class="nx">generateSVG</span><span class="p">();</span> <span class="nx">addStyleToDocument</span><span class="p">();</span> <span class="nx">addSecondStyleToDocument</span><span class="p">();</span> <span class="nx">utils</span><span class="p">.</span><span class="nx">cloneCssStyles</span><span class="p">(</span><span class="nx">svg</span><span class="p">,</span> <span class="p">{});</span> <span class="nx">expect</span><span class="p">(</span><span class="nx">stylesToArray</span><span class="p">(</span><span class="nx">svg</span><span class="p">)).</span><span class="nx">toEqual</span><span class="p">([</span> <span class="s1">&#39;.node { stroke: #eee; }&#39;</span><span class="p">,</span> <span class="s1">&#39;.node-square { stroke: #bbb; }&#39;</span><span class="p">,</span> <span class="s1">&#39;.node-square { stroke: #beb; }&#39;</span><span class="p">]);</span> <span class="p">});</span> <span class="nx">it</span><span class="p">(</span><span class="s1">&#39;should handle multiple stylesheets + ignore styles in other mermaid SVG&#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">svg</span> <span class="o">=</span> <span class="nx">generateSVG</span><span class="p">();</span> <span class="nx">addStyleToDocument</span><span class="p">();</span> <span class="nx">addSecondStyleToDocument</span><span class="p">();</span> <span class="nx">addMermaidSVGwithStyleToDocument</span><span class="p">();</span> <span class="nx">utils</span><span class="p">.</span><span class="nx">cloneCssStyles</span><span class="p">(</span><span class="nx">svg</span><span class="p">,</span> <span class="p">{});</span> <span class="nx">expect</span><span class="p">(</span><span class="nx">stylesToArray</span><span class="p">(</span><span class="nx">svg</span><span class="p">)).</span><span class="nx">toEqual</span><span class="p">([</span> <span class="s1">&#39;.node { stroke: #eee; }&#39;</span><span class="p">,</span> <span class="s1">&#39;.node-square { stroke: #bbb; }&#39;</span><span class="p">,</span> <span class="s1">&#39;.node-square { stroke: #beb; }&#39;</span><span class="p">]);</span> <span class="p">});</span> <span class="nx">it</span><span class="p">(</span><span class="s1">&#39;should handle a default class together with stylesheet in document with classes in SVG&#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">svg</span> <span class="o">=</span> <span class="nx">generateSVG</span><span class="p">();</span> <span class="nx">addStyleToDocument</span><span class="p">();</span> <span class="nx">utils</span><span class="p">.</span><span class="nx">cloneCssStyles</span><span class="p">(</span><span class="nx">svg</span><span class="p">,</span> <span class="p">{</span> <span class="s2">&quot;default&quot;</span><span class="o">:</span> <span class="p">{</span> <span class="s2">&quot;styles&quot;</span><span class="o">:</span> <span class="p">[</span><span class="s2">&quot;stroke:#fff&quot;</span><span class="p">,</span><span class="s2">&quot;stroke-width:1.5px&quot;</span><span class="p">]</span><span class="err"> </span><span class="p">}</span> <span class="p">});</span> <span class="nx">expect</span><span class="p">(</span><span class="nx">stylesToArray</span><span class="p">(</span><span class="nx">svg</span><span class="p">)).</span><span class="nx">toEqual</span><span class="p">([</span> <span class="s1">&#39;#mermaid-01 .node { stroke:#fff; stroke-width:1.5px; }&#39;</span><span class="p">,</span> <span class="s1">&#39;.node { stroke: #eee; }&#39;</span><span class="p">,</span> <span class="s1">&#39;.node-square { stroke: #bbb; }&#39;</span><span class="p">]);</span> <span class="p">});</span> <span class="nx">it</span><span class="p">(</span><span class="s1">&#39;should handle a default class together with stylesheet in document and classDefs&#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">svg</span> <span class="o">=</span> <span class="nx">generateSVG</span><span class="p">();</span> <span class="nx">addStyleToDocument</span><span class="p">();</span> <span class="nx">utils</span><span class="p">.</span><span class="nx">cloneCssStyles</span><span class="p">(</span><span class="nx">svg</span><span class="p">,</span> <span class="p">{</span> <span class="s2">&quot;default&quot;</span><span class="o">:</span> <span class="p">{</span> <span class="s2">&quot;styles&quot;</span><span class="o">:</span> <span class="p">[</span><span class="s2">&quot;stroke:#fff&quot;</span><span class="p">,</span><span class="s2">&quot;stroke-width:1.5px&quot;</span><span class="p">]</span><span class="err"> </span><span class="p">},</span> <span class="s2">&quot;node-square&quot;</span><span class="o">:</span> <span class="p">{</span> <span class="s2">&quot;styles&quot;</span><span class="o">:</span> <span class="p">[</span><span class="s2">&quot;fill:#eee&quot;</span><span class="p">,</span> <span class="s2">&quot;stroke:#aaa&quot;</span><span class="p">]</span> <span class="p">},</span> <span class="s2">&quot;node-circle&quot;</span><span class="o">:</span> <span class="p">{</span> <span class="s2">&quot;styles&quot;</span><span class="o">:</span> <span class="p">[</span><span class="s2">&quot;fill:#444&quot;</span><span class="p">,</span> <span class="s2">&quot;stroke:#111&quot;</span><span class="p">]</span> <span class="p">}</span> <span class="p">});</span> <span class="nx">expect</span><span class="p">(</span><span class="nx">stylesToArray</span><span class="p">(</span><span class="nx">svg</span><span class="p">)).</span><span class="nx">toEqual</span><span class="p">([</span> <span class="s1">&#39;#mermaid-01 .node { stroke:#fff; stroke-width:1.5px; }&#39;</span><span class="p">,</span> <span class="s1">&#39;.node { stroke: #eee; }&#39;</span><span class="p">,</span> <span class="s1">&#39;.node-square { stroke: #bbb; }&#39;</span><span class="p">,</span> <span class="s1">&#39;#mermaid-01 .node-square { fill:#eee; stroke:#aaa; }&#39;</span><span class="p">,</span> <span class="s1">&#39;#mermaid-01 .node-circle { fill:#444; stroke:#111; }&#39;</span> <span class="p">]);</span> <span class="p">});</span> <span class="p">});</span> </pre></div> </td> </tr> </tbody> </table> </div> </body> </html>