mermaid
Version:
Markdownish syntax for generating flowcharts, sequence diagrams and gantt charts.
344 lines (294 loc) • 35.4 kB
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">¶</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">¶</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">'./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 detecting chart type '</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">'./utils'</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">'should handle a sequence defintion'</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">'sequence TB\nbfs1:queue'</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">'sequence'</span><span class="p">);</span>
<span class="p">});</span>
<span class="nx">it</span><span class="p">(</span><span class="s1">'should handle a sequence defintion with leading spaces'</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">' sequence TB\nbfs1:queue'</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">'sequence'</span><span class="p">);</span>
<span class="p">});</span>
<span class="nx">it</span><span class="p">(</span><span class="s1">'should handle a graph defintion'</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">'graph TB\nbfs1:queue'</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">'graph'</span><span class="p">);</span>
<span class="p">});</span>
<span class="nx">it</span><span class="p">(</span><span class="s1">'should handle a graph defintion with leading spaces'</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">' graph TB\nbfs1:queue'</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">'graph'</span><span class="p">);</span>
<span class="p">});</span>
<span class="nx">it</span><span class="p">(</span><span class="s1">'should handle a graph defintion with leading spaces and newline'</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">' \n graph TB\nbfs1:queue'</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">'graph'</span><span class="p">);</span>
<span class="p">});</span>
<span class="nx">it</span><span class="p">(</span><span class="s1">'should handle a sequence defintion with leading spaces and newline'</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">' \n sequence TB\nbfs1:queue'</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">'sequence'</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 cloning CSS '</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">'./utils'</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">'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>
</pre></div>
</td>
</tr>
<tr>
<td class="docs">
<div class="pilwrap">
<a class="pilcrow" href="#section-2" id="section-2">¶</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">¶</a>
</div>
<p>document.body.innerHTML = '';
document.body.innerHTML = '';</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">"style"</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">"\n"</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>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">¶</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"><</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">''</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">'style'</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">'.node { stroke:#eee; }\n.node-square { stroke:#bbb; }\n'</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">'style'</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">'.node2 { stroke:#eee; }\n.node-square { stroke:#beb; }\n'</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">'svg'</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">'id'</span><span class="p">,</span> <span class="s1">'mermaid-01'</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">'g'</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">'class'</span><span class="p">,</span> <span class="s1">'node'</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">'g'</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">'class'</span><span class="p">,</span> <span class="s1">'node-square'</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">'svg'</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">'id'</span><span class="p">,</span> <span class="s1">'mermaid-03'</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">'style'</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">'type'</span><span class="p">,</span> <span class="s1">'text/css'</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">'title'</span><span class="p">,</span> <span class="s1">'mermaid-svg-internal-css'</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">'#mermaid-05 .node2 { stroke:#eee; }\n.node-square { stroke:#bfe; }\n'</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">'mermaid-svg-internal-css'</span><span class="p">;</span>
<span class="p">}</span>
<span class="nx">it</span><span class="p">(</span><span class="s1">'should handle an empty set of classes'</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">'svg'</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">'id'</span><span class="p">,</span> <span class="s1">'mermaid-01'</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">¶</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">''</span><span class="p">);</span>
<span class="p">});</span>
<span class="nx">it</span><span class="p">(</span><span class="s1">'should handle a default class'</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">'svg'</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">'id'</span><span class="p">,</span> <span class="s1">'mermaid-01'</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">"default"</span><span class="o">:</span> <span class="p">{</span> <span class="s2">"styles"</span><span class="o">:</span> <span class="p">[</span><span class="s2">"stroke:#fff"</span><span class="p">,</span><span class="s2">"stroke-width:1.5px"</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">'#mermaid-01 .node { stroke:#fff; stroke-width:1.5px; }'</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">¶</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">'<style type="text/css" title="mermaid-svg-internal-css">/* <![CDATA[ */\n#mermaid-01 .node { stroke:#fff; stroke-width:1.5px; }\n/* ]]> */\n</style>'</span><span class="p">);</span>
<span class="p">});</span>
<span class="nx">it</span><span class="p">(</span><span class="s1">'should handle stylesheet in document with no classes in SVG'</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">'svg'</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">'id'</span><span class="p">,</span> <span class="s1">'mermaid-01'</span><span class="p">);</span>
<span class="nx">addStyleToDocument</span><span class="p">(</span><span class="s1">'mermaid'</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">¶</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">''</span><span class="p">);</span>
<span class="p">});</span>
<span class="nx">it</span><span class="p">(</span><span class="s1">'should handle stylesheet in document with classes in SVG'</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">'.node { stroke: #eee; }'</span><span class="p">,</span> <span class="s1">'.node-square { stroke: #bbb; }'</span><span class="p">]);</span>
<span class="p">});</span>
<span class="nx">it</span><span class="p">(</span><span class="s1">'should handle multiple stylesheets in document with classes in SVG'</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">'.node { stroke: #eee; }'</span><span class="p">,</span> <span class="s1">'.node-square { stroke: #bbb; }'</span><span class="p">,</span> <span class="s1">'.node-square { stroke: #beb; }'</span><span class="p">]);</span>
<span class="p">});</span>
<span class="nx">it</span><span class="p">(</span><span class="s1">'should handle multiple stylesheets + ignore styles in other mermaid SVG'</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">'.node { stroke: #eee; }'</span><span class="p">,</span> <span class="s1">'.node-square { stroke: #bbb; }'</span><span class="p">,</span> <span class="s1">'.node-square { stroke: #beb; }'</span><span class="p">]);</span>
<span class="p">});</span>
<span class="nx">it</span><span class="p">(</span><span class="s1">'should handle a default class together with stylesheet in document with classes in SVG'</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">"default"</span><span class="o">:</span> <span class="p">{</span> <span class="s2">"styles"</span><span class="o">:</span> <span class="p">[</span><span class="s2">"stroke:#fff"</span><span class="p">,</span><span class="s2">"stroke-width:1.5px"</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">'#mermaid-01 .node { stroke:#fff; stroke-width:1.5px; }'</span><span class="p">,</span> <span class="s1">'.node { stroke: #eee; }'</span><span class="p">,</span> <span class="s1">'.node-square { stroke: #bbb; }'</span><span class="p">]);</span>
<span class="p">});</span>
<span class="nx">it</span><span class="p">(</span><span class="s1">'should handle a default class together with stylesheet in document and classDefs'</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">"default"</span><span class="o">:</span> <span class="p">{</span> <span class="s2">"styles"</span><span class="o">:</span> <span class="p">[</span><span class="s2">"stroke:#fff"</span><span class="p">,</span><span class="s2">"stroke-width:1.5px"</span><span class="p">]</span><span class="err"> </span><span class="p">},</span>
<span class="s2">"node-square"</span><span class="o">:</span> <span class="p">{</span> <span class="s2">"styles"</span><span class="o">:</span> <span class="p">[</span><span class="s2">"fill:#eee"</span><span class="p">,</span> <span class="s2">"stroke:#aaa"</span><span class="p">]</span> <span class="p">},</span>
<span class="s2">"node-circle"</span><span class="o">:</span> <span class="p">{</span> <span class="s2">"styles"</span><span class="o">:</span> <span class="p">[</span><span class="s2">"fill:#444"</span><span class="p">,</span> <span class="s2">"stroke:#111"</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">'#mermaid-01 .node { stroke:#fff; stroke-width:1.5px; }'</span><span class="p">,</span>
<span class="s1">'.node { stroke: #eee; }'</span><span class="p">,</span>
<span class="s1">'.node-square { stroke: #bbb; }'</span><span class="p">,</span>
<span class="s1">'#mermaid-01 .node-square { fill:#eee; stroke:#aaa; }'</span><span class="p">,</span>
<span class="s1">'#mermaid-01 .node-circle { fill:#444; stroke:#111; }'</span>
<span class="p">]);</span>
<span class="p">});</span>
<span class="p">});</span>
</pre></div>
</td>
</tr>
</tbody>
</table>
</div>
</body>
</html>