mermaid
Version:
Markdownish syntax for generating flowcharts, sequence diagrams and gantt charts.
335 lines (290 loc) • 110 kB
HTML
<!DOCTYPE html>
<html>
<head>
<title>HtmlReporterSpec.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/bower_components/jasmine/spec/html/HtmlReporterSpec.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="#HtmlReporterSpec.js">HtmlReporterSpec.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="HtmlReporterSpec.js">
<h1>
<a href="#HtmlReporterSpec.js" name="HtmlReporterSpec.js" class="pilcrow">¶</a>HtmlReporterSpec.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>
</td>
<td class="code highlight"><div class="highlight"><pre><span class="nx">describe</span><span class="p">(</span><span class="s2">"New HtmlReporter"</span><span class="p">,</span> <span class="kd">function</span><span class="p">()</span> <span class="p">{</span>
</pre></div>
</td>
</tr>
<tr>
<td class="docs">
<div class="pilwrap">
<a class="pilcrow" href="#section-2" id="section-2">¶</a>
</div>
<p>TODO: Figure out why this isn't rendering...</p>
</td>
<td class="code highlight"><div class="highlight"><pre>
<span class="nx">it</span><span class="p">(</span><span class="s2">"builds the initial DOM elements, including the title banner"</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">env</span> <span class="o">=</span> <span class="k">new</span> <span class="nx">j$</span><span class="p">.</span><span class="nx">Env</span><span class="p">(),</span>
<span class="nx">container</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="s2">"div"</span><span class="p">),</span>
<span class="nx">getContainer</span> <span class="o">=</span> <span class="kd">function</span><span class="p">()</span> <span class="p">{</span> <span class="k">return</span> <span class="nx">container</span><span class="p">;</span> <span class="p">},</span>
<span class="nx">reporter</span> <span class="o">=</span> <span class="k">new</span> <span class="nx">j$</span><span class="p">.</span><span class="nx">HtmlReporter</span><span class="p">({</span>
<span class="nx">env</span><span class="o">:</span> <span class="nx">env</span><span class="p">,</span>
<span class="nx">getContainer</span><span class="o">:</span> <span class="nx">getContainer</span><span class="p">,</span>
<span class="nx">createElement</span><span class="o">:</span> <span class="kd">function</span><span class="p">()</span> <span class="p">{</span> <span class="k">return</span> <span class="nb">document</span><span class="p">.</span><span class="nx">createElement</span><span class="p">.</span><span class="nx">apply</span><span class="p">(</span><span class="nb">document</span><span class="p">,</span> <span class="nx">arguments</span><span class="p">);</span> <span class="p">},</span>
<span class="nx">createTextNode</span><span class="o">:</span> <span class="kd">function</span><span class="p">()</span> <span class="p">{</span> <span class="k">return</span> <span class="nb">document</span><span class="p">.</span><span class="nx">createTextNode</span><span class="p">.</span><span class="nx">apply</span><span class="p">(</span><span class="nb">document</span><span class="p">,</span> <span class="nx">arguments</span><span class="p">);</span> <span class="p">}</span>
<span class="p">});</span>
<span class="nx">reporter</span><span class="p">.</span><span class="nx">initialize</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>Main top-level elements</p>
</td>
<td class="code highlight"><div class="highlight"><pre>
<span class="nx">expect</span><span class="p">(</span><span class="nx">container</span><span class="p">.</span><span class="nx">querySelector</span><span class="p">(</span><span class="s2">"div.jasmine_html-reporter"</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">container</span><span class="p">.</span><span class="nx">querySelector</span><span class="p">(</span><span class="s2">"div.banner"</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">container</span><span class="p">.</span><span class="nx">querySelector</span><span class="p">(</span><span class="s2">"div.alert"</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">container</span><span class="p">.</span><span class="nx">querySelector</span><span class="p">(</span><span class="s2">"div.results"</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">container</span><span class="p">.</span><span class="nx">querySelector</span><span class="p">(</span><span class="s2">"ul.symbol-summary"</span><span class="p">)).</span><span class="nx">toBeTruthy</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>title banner</p>
</td>
<td class="code highlight"><div class="highlight"><pre>
<span class="kd">var</span> <span class="nx">banner</span> <span class="o">=</span> <span class="nx">container</span><span class="p">.</span><span class="nx">querySelector</span><span class="p">(</span><span class="s2">".banner"</span><span class="p">);</span>
<span class="kd">var</span> <span class="nx">title</span> <span class="o">=</span> <span class="nx">banner</span><span class="p">.</span><span class="nx">querySelector</span><span class="p">(</span><span class="s2">"a.title"</span><span class="p">);</span>
<span class="nx">expect</span><span class="p">(</span><span class="nx">title</span><span class="p">.</span><span class="nx">getAttribute</span><span class="p">(</span><span class="s1">'href'</span><span class="p">)).</span><span class="nx">toEqual</span><span class="p">(</span><span class="s1">'http://jasmine.github.io/'</span><span class="p">);</span>
<span class="nx">expect</span><span class="p">(</span><span class="nx">title</span><span class="p">.</span><span class="nx">getAttribute</span><span class="p">(</span><span class="s1">'target'</span><span class="p">)).</span><span class="nx">toEqual</span><span class="p">(</span><span class="s1">'_blank'</span><span class="p">);</span>
<span class="kd">var</span> <span class="nx">version</span> <span class="o">=</span> <span class="nx">banner</span><span class="p">.</span><span class="nx">querySelector</span><span class="p">(</span><span class="s2">".version"</span><span class="p">),</span>
<span class="nx">versionText</span> <span class="o">=</span> <span class="s1">'textContent'</span> <span class="k">in</span> <span class="nx">version</span> <span class="o">?</span> <span class="nx">version</span><span class="p">.</span><span class="nx">textContent</span> <span class="o">:</span> <span class="nx">version</span><span class="p">.</span><span class="nx">innerText</span><span class="p">;</span>
<span class="nx">expect</span><span class="p">(</span><span class="nx">versionText</span><span class="p">).</span><span class="nx">toEqual</span><span class="p">(</span><span class="nx">j$</span><span class="p">.</span><span class="nx">version</span><span class="p">);</span>
<span class="p">});</span>
<span class="nx">it</span><span class="p">(</span><span class="s2">"builds a single reporter even if initialized multiple times"</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">env</span> <span class="o">=</span> <span class="k">new</span> <span class="nx">j$</span><span class="p">.</span><span class="nx">Env</span><span class="p">(),</span>
<span class="nx">container</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="s2">"div"</span><span class="p">),</span>
<span class="nx">getContainer</span> <span class="o">=</span> <span class="kd">function</span><span class="p">()</span> <span class="p">{</span> <span class="k">return</span> <span class="nx">container</span><span class="p">;</span> <span class="p">},</span>
<span class="nx">reporter</span> <span class="o">=</span> <span class="k">new</span> <span class="nx">j$</span><span class="p">.</span><span class="nx">HtmlReporter</span><span class="p">({</span>
<span class="nx">env</span><span class="o">:</span> <span class="nx">env</span><span class="p">,</span>
<span class="nx">getContainer</span><span class="o">:</span> <span class="nx">getContainer</span><span class="p">,</span>
<span class="nx">createElement</span><span class="o">:</span> <span class="kd">function</span><span class="p">()</span> <span class="p">{</span> <span class="k">return</span> <span class="nb">document</span><span class="p">.</span><span class="nx">createElement</span><span class="p">.</span><span class="nx">apply</span><span class="p">(</span><span class="nb">document</span><span class="p">,</span> <span class="nx">arguments</span><span class="p">);</span> <span class="p">},</span>
<span class="nx">createTextNode</span><span class="o">:</span> <span class="kd">function</span><span class="p">()</span> <span class="p">{</span> <span class="k">return</span> <span class="nb">document</span><span class="p">.</span><span class="nx">createTextNode</span><span class="p">.</span><span class="nx">apply</span><span class="p">(</span><span class="nb">document</span><span class="p">,</span> <span class="nx">arguments</span><span class="p">);</span> <span class="p">}</span>
<span class="p">});</span>
<span class="nx">reporter</span><span class="p">.</span><span class="nx">initialize</span><span class="p">();</span>
<span class="nx">reporter</span><span class="p">.</span><span class="nx">initialize</span><span class="p">();</span>
<span class="nx">reporter</span><span class="p">.</span><span class="nx">initialize</span><span class="p">();</span>
<span class="nx">expect</span><span class="p">(</span><span class="nx">container</span><span class="p">.</span><span class="nx">querySelectorAll</span><span class="p">(</span><span class="s2">"div.jasmine_html-reporter"</span><span class="p">).</span><span class="nx">length</span><span class="p">).</span><span class="nx">toEqual</span><span class="p">(</span><span class="mi">1</span><span class="p">);</span>
<span class="p">});</span>
<span class="nx">it</span><span class="p">(</span><span class="s2">"starts the timer when jasmine begins"</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">env</span> <span class="o">=</span> <span class="k">new</span> <span class="nx">jasmine</span><span class="p">.</span><span class="nx">Env</span><span class="p">(),</span>
<span class="nx">startTimerSpy</span> <span class="o">=</span> <span class="nx">jasmine</span><span class="p">.</span><span class="nx">createSpy</span><span class="p">(</span><span class="s2">"start-timer-spy"</span><span class="p">),</span>
<span class="nx">reporter</span> <span class="o">=</span> <span class="k">new</span> <span class="nx">j$</span><span class="p">.</span><span class="nx">HtmlReporter</span><span class="p">({</span>
<span class="nx">env</span><span class="o">:</span> <span class="nx">env</span><span class="p">,</span>
<span class="nx">createElement</span><span class="o">:</span> <span class="kd">function</span><span class="p">()</span> <span class="p">{</span> <span class="k">return</span> <span class="nb">document</span><span class="p">.</span><span class="nx">createElement</span><span class="p">.</span><span class="nx">apply</span><span class="p">(</span><span class="nb">document</span><span class="p">,</span> <span class="nx">arguments</span><span class="p">);</span> <span class="p">},</span>
<span class="nx">timer</span><span class="o">:</span> <span class="p">{</span> <span class="nx">start</span><span class="o">:</span> <span class="nx">startTimerSpy</span> <span class="p">}</span>
<span class="p">});</span>
<span class="nx">reporter</span><span class="p">.</span><span class="nx">jasmineStarted</span><span class="p">({});</span>
<span class="nx">expect</span><span class="p">(</span><span class="nx">startTimerSpy</span><span class="p">).</span><span class="nx">toHaveBeenCalled</span><span class="p">();</span>
<span class="p">});</span>
<span class="nx">describe</span><span class="p">(</span><span class="s2">"when a spec is done"</span><span class="p">,</span> <span class="kd">function</span><span class="p">()</span> <span class="p">{</span>
<span class="nx">it</span><span class="p">(</span><span class="s2">"logs errors to the console and prints a special symbol if it is an empty spec"</span><span class="p">,</span> <span class="kd">function</span><span class="p">()</span> <span class="p">{</span>
<span class="k">if</span> <span class="p">(</span><span class="o">!</span><span class="nb">window</span><span class="p">.</span><span class="nx">console</span><span class="p">)</span> <span class="p">{</span>
<span class="nb">window</span><span class="p">.</span><span class="nx">console</span> <span class="o">=</span> <span class="p">{</span> <span class="nx">error</span><span class="o">:</span> <span class="kd">function</span><span class="p">(){}</span> <span class="p">};</span>
<span class="p">}</span>
<span class="kd">var</span> <span class="nx">env</span> <span class="o">=</span> <span class="k">new</span> <span class="nx">j$</span><span class="p">.</span><span class="nx">Env</span><span class="p">(),</span>
<span class="nx">container</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">'div'</span><span class="p">),</span>
<span class="nx">getContainer</span> <span class="o">=</span> <span class="kd">function</span><span class="p">()</span> <span class="p">{</span><span class="k">return</span> <span class="nx">container</span><span class="p">;},</span>
<span class="nx">reporter</span> <span class="o">=</span> <span class="k">new</span> <span class="nx">j$</span><span class="p">.</span><span class="nx">HtmlReporter</span><span class="p">({</span>
<span class="nx">env</span><span class="o">:</span> <span class="nx">env</span><span class="p">,</span>
<span class="nx">getContainer</span><span class="o">:</span> <span class="nx">getContainer</span><span class="p">,</span>
<span class="nx">createElement</span><span class="o">:</span> <span class="kd">function</span><span class="p">()</span> <span class="p">{</span> <span class="k">return</span> <span class="nb">document</span><span class="p">.</span><span class="nx">createElement</span><span class="p">.</span><span class="nx">apply</span><span class="p">(</span><span class="nb">document</span><span class="p">,</span> <span class="nx">arguments</span><span class="p">);</span> <span class="p">},</span>
<span class="nx">createTextNode</span><span class="o">:</span> <span class="kd">function</span><span class="p">()</span> <span class="p">{</span> <span class="k">return</span> <span class="nb">document</span><span class="p">.</span><span class="nx">createTextNode</span><span class="p">.</span><span class="nx">apply</span><span class="p">(</span><span class="nb">document</span><span class="p">,</span> <span class="nx">arguments</span><span class="p">);</span> <span class="p">}</span>
<span class="p">});</span>
<span class="nx">spyOn</span><span class="p">(</span><span class="nx">console</span><span class="p">,</span> <span class="s1">'error'</span><span class="p">);</span>
<span class="nx">reporter</span><span class="p">.</span><span class="nx">initialize</span><span class="p">();</span>
<span class="nx">reporter</span><span class="p">.</span><span class="nx">specDone</span><span class="p">({</span>
<span class="nx">status</span><span class="o">:</span> <span class="s2">"passed"</span><span class="p">,</span>
<span class="nx">fullName</span><span class="o">:</span> <span class="s1">'Some Name'</span><span class="p">,</span>
<span class="nx">passedExpectations</span><span class="o">:</span> <span class="p">[],</span>
<span class="nx">failedExpectations</span><span class="o">:</span> <span class="p">[]</span>
<span class="p">});</span>
<span class="nx">expect</span><span class="p">(</span><span class="nx">console</span><span class="p">.</span><span class="nx">error</span><span class="p">).</span><span class="nx">toHaveBeenCalledWith</span><span class="p">(</span><span class="s2">"Spec \'Some Name\' has no expectations."</span><span class="p">);</span>
<span class="kd">var</span> <span class="nx">specEl</span> <span class="o">=</span> <span class="nx">container</span><span class="p">.</span><span class="nx">querySelector</span><span class="p">(</span><span class="s1">'.symbol-summary li'</span><span class="p">);</span>
<span class="nx">expect</span><span class="p">(</span><span class="nx">specEl</span><span class="p">.</span><span class="nx">getAttribute</span><span class="p">(</span><span class="s2">"class"</span><span class="p">)).</span><span class="nx">toEqual</span><span class="p">(</span><span class="s2">"empty"</span><span class="p">);</span>
<span class="p">});</span>
<span class="nx">it</span><span class="p">(</span><span class="s2">"reports the status symbol of a disabled spec"</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">env</span> <span class="o">=</span> <span class="k">new</span> <span class="nx">j$</span><span class="p">.</span><span class="nx">Env</span><span class="p">(),</span>
<span class="nx">container</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="s2">"div"</span><span class="p">),</span>
<span class="nx">getContainer</span> <span class="o">=</span> <span class="kd">function</span><span class="p">()</span> <span class="p">{</span> <span class="k">return</span> <span class="nx">container</span><span class="p">;</span> <span class="p">},</span>
<span class="nx">reporter</span> <span class="o">=</span> <span class="k">new</span> <span class="nx">j$</span><span class="p">.</span><span class="nx">HtmlReporter</span><span class="p">({</span>
<span class="nx">env</span><span class="o">:</span> <span class="nx">env</span><span class="p">,</span>
<span class="nx">getContainer</span><span class="o">:</span> <span class="nx">getContainer</span><span class="p">,</span>
<span class="nx">createElement</span><span class="o">:</span> <span class="kd">function</span><span class="p">()</span> <span class="p">{</span> <span class="k">return</span> <span class="nb">document</span><span class="p">.</span><span class="nx">createElement</span><span class="p">.</span><span class="nx">apply</span><span class="p">(</span><span class="nb">document</span><span class="p">,</span> <span class="nx">arguments</span><span class="p">);</span> <span class="p">},</span>
<span class="nx">createTextNode</span><span class="o">:</span> <span class="kd">function</span><span class="p">()</span> <span class="p">{</span> <span class="k">return</span> <span class="nb">document</span><span class="p">.</span><span class="nx">createTextNode</span><span class="p">.</span><span class="nx">apply</span><span class="p">(</span><span class="nb">document</span><span class="p">,</span> <span class="nx">arguments</span><span class="p">);</span> <span class="p">}</span>
<span class="p">});</span>
<span class="nx">reporter</span><span class="p">.</span><span class="nx">initialize</span><span class="p">();</span>
<span class="nx">reporter</span><span class="p">.</span><span class="nx">specDone</span><span class="p">({</span><span class="nx">id</span><span class="o">:</span> <span class="mi">789</span><span class="p">,</span> <span class="nx">status</span><span class="o">:</span> <span class="s2">"disabled"</span><span class="p">,</span> <span class="nx">fullName</span><span class="o">:</span> <span class="s2">"symbols should have titles"</span><span class="p">,</span> <span class="nx">passedExpectations</span><span class="o">:</span> <span class="p">[],</span> <span class="nx">failedExpectations</span><span class="o">:</span> <span class="p">[]});</span>
<span class="kd">var</span> <span class="nx">specEl</span> <span class="o">=</span> <span class="nx">container</span><span class="p">.</span><span class="nx">querySelector</span><span class="p">(</span><span class="s1">'.symbol-summary li'</span><span class="p">);</span>
<span class="nx">expect</span><span class="p">(</span><span class="nx">specEl</span><span class="p">.</span><span class="nx">getAttribute</span><span class="p">(</span><span class="s2">"class"</span><span class="p">)).</span><span class="nx">toEqual</span><span class="p">(</span><span class="s2">"disabled"</span><span class="p">);</span>
<span class="nx">expect</span><span class="p">(</span><span class="nx">specEl</span><span class="p">.</span><span class="nx">getAttribute</span><span class="p">(</span><span class="s2">"id"</span><span class="p">)).</span><span class="nx">toEqual</span><span class="p">(</span><span class="s2">"spec_789"</span><span class="p">);</span>
<span class="nx">expect</span><span class="p">(</span><span class="nx">specEl</span><span class="p">.</span><span class="nx">getAttribute</span><span class="p">(</span><span class="s2">"title"</span><span class="p">)).</span><span class="nx">toEqual</span><span class="p">(</span><span class="s2">"symbols should have titles"</span><span class="p">);</span>
<span class="p">});</span>
<span class="nx">it</span><span class="p">(</span><span class="s2">"reports the status symbol of a pending spec"</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">env</span> <span class="o">=</span> <span class="k">new</span> <span class="nx">j$</span><span class="p">.</span><span class="nx">Env</span><span class="p">(),</span>
<span class="nx">container</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="s2">"div"</span><span class="p">),</span>
<span class="nx">getContainer</span> <span class="o">=</span> <span class="kd">function</span><span class="p">()</span> <span class="p">{</span> <span class="k">return</span> <span class="nx">container</span><span class="p">;</span> <span class="p">},</span>
<span class="nx">reporter</span> <span class="o">=</span> <span class="k">new</span> <span class="nx">j$</span><span class="p">.</span><span class="nx">HtmlReporter</span><span class="p">({</span>
<span class="nx">env</span><span class="o">:</span> <span class="nx">env</span><span class="p">,</span>
<span class="nx">getContainer</span><span class="o">:</span> <span class="nx">getContainer</span><span class="p">,</span>
<span class="nx">createElement</span><span class="o">:</span> <span class="kd">function</span><span class="p">()</span> <span class="p">{</span> <span class="k">return</span> <span class="nb">document</span><span class="p">.</span><span class="nx">createElement</span><span class="p">.</span><span class="nx">apply</span><span class="p">(</span><span class="nb">document</span><span class="p">,</span> <span class="nx">arguments</span><span class="p">);</span> <span class="p">},</span>
<span class="nx">createTextNode</span><span class="o">:</span> <span class="kd">function</span><span class="p">()</span> <span class="p">{</span> <span class="k">return</span> <span class="nb">document</span><span class="p">.</span><span class="nx">createTextNode</span><span class="p">.</span><span class="nx">apply</span><span class="p">(</span><span class="nb">document</span><span class="p">,</span> <span class="nx">arguments</span><span class="p">);</span> <span class="p">}</span>
<span class="p">});</span>
<span class="nx">reporter</span><span class="p">.</span><span class="nx">initialize</span><span class="p">();</span>
<span class="nx">reporter</span><span class="p">.</span><span class="nx">specDone</span><span class="p">({</span><span class="nx">id</span><span class="o">:</span> <span class="mi">789</span><span class="p">,</span> <span class="nx">status</span><span class="o">:</span> <span class="s2">"pending"</span><span class="p">,</span> <span class="nx">passedExpectations</span><span class="o">:</span> <span class="p">[],</span> <span class="nx">failedExpectations</span><span class="o">:</span> <span class="p">[]});</span>
<span class="kd">var</span> <span class="nx">specEl</span> <span class="o">=</span> <span class="nx">container</span><span class="p">.</span><span class="nx">querySelector</span><span class="p">(</span><span class="s1">'.symbol-summary li'</span><span class="p">);</span>
<span class="nx">expect</span><span class="p">(</span><span class="nx">specEl</span><span class="p">.</span><span class="nx">getAttribute</span><span class="p">(</span><span class="s2">"class"</span><span class="p">)).</span><span class="nx">toEqual</span><span class="p">(</span><span class="s2">"pending"</span><span class="p">);</span>
<span class="nx">expect</span><span class="p">(</span><span class="nx">specEl</span><span class="p">.</span><span class="nx">getAttribute</span><span class="p">(</span><span class="s2">"id"</span><span class="p">)).</span><span class="nx">toEqual</span><span class="p">(</span><span class="s2">"spec_789"</span><span class="p">);</span>
<span class="p">});</span>
<span class="nx">it</span><span class="p">(</span><span class="s2">"reports the status symbol of a passing spec"</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">env</span> <span class="o">=</span> <span class="k">new</span> <span class="nx">j$</span><span class="p">.</span><span class="nx">Env</span><span class="p">(),</span>
<span class="nx">container</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="s2">"div"</span><span class="p">),</span>
<span class="nx">getContainer</span> <span class="o">=</span> <span class="kd">function</span><span class="p">()</span> <span class="p">{</span> <span class="k">return</span> <span class="nx">container</span><span class="p">;</span> <span class="p">},</span>
<span class="nx">reporter</span> <span class="o">=</span> <span class="k">new</span> <span class="nx">j$</span><span class="p">.</span><span class="nx">HtmlReporter</span><span class="p">({</span>
<span class="nx">env</span><span class="o">:</span> <span class="nx">env</span><span class="p">,</span>
<span class="nx">getContainer</span><span class="o">:</span> <span class="nx">getContainer</span><span class="p">,</span>
<span class="nx">createElement</span><span class="o">:</span> <span class="kd">function</span><span class="p">()</span> <span class="p">{</span> <span class="k">return</span> <span class="nb">document</span><span class="p">.</span><span class="nx">createElement</span><span class="p">.</span><span class="nx">apply</span><span class="p">(</span><span class="nb">document</span><span class="p">,</span> <span class="nx">arguments</span><span class="p">);</span> <span class="p">},</span>
<span class="nx">createTextNode</span><span class="o">:</span> <span class="kd">function</span><span class="p">()</span> <span class="p">{</span> <span class="k">return</span> <span class="nb">document</span><span class="p">.</span><span class="nx">createTextNode</span><span class="p">.</span><span class="nx">apply</span><span class="p">(</span><span class="nb">document</span><span class="p">,</span> <span class="nx">arguments</span><span class="p">);</span> <span class="p">}</span>
<span class="p">});</span>
<span class="nx">reporter</span><span class="p">.</span><span class="nx">initialize</span><span class="p">();</span>
<span class="nx">reporter</span><span class="p">.</span><span class="nx">specDone</span><span class="p">({</span><span class="nx">id</span><span class="o">:</span> <span class="mi">123</span><span class="p">,</span> <span class="nx">status</span><span class="o">:</span> <span class="s2">"passed"</span><span class="p">,</span> <span class="nx">passedExpectations</span><span class="o">:</span> <span class="p">[{</span><span class="nx">passed</span><span class="o">:</span> <span class="kc">true</span><span class="p">}],</span> <span class="nx">failedExpectations</span><span class="o">:</span> <span class="p">[]});</span>
<span class="kd">var</span> <span class="nx">statuses</span> <span class="o">=</span> <span class="nx">container</span><span class="p">.</span><span class="nx">querySelector</span><span class="p">(</span><span class="s2">".symbol-summary"</span><span class="p">);</span>
<span class="kd">var</span> <span class="nx">specEl</span> <span class="o">=</span> <span class="nx">statuses</span><span class="p">.</span><span class="nx">querySelector</span><span class="p">(</span><span class="s2">"li"</span><span class="p">);</span>
<span class="nx">expect</span><span class="p">(</span><span class="nx">specEl</span><span class="p">.</span><span class="nx">getAttribute</span><span class="p">(</span><span class="s2">"class"</span><span class="p">)).</span><span class="nx">toEqual</span><span class="p">(</span><span class="s2">"passed"</span><span class="p">);</span>
<span class="nx">expect</span><span class="p">(</span><span class="nx">specEl</span><span class="p">.</span><span class="nx">getAttribute</span><span class="p">(</span><span class="s2">"id"</span><span class="p">)).</span><span class="nx">toEqual</span><span class="p">(</span><span class="s2">"spec_123"</span><span class="p">);</span>
<span class="p">});</span>
<span class="nx">it</span><span class="p">(</span><span class="s2">"reports the status symbol of a failing spec"</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">env</span> <span class="o">=</span> <span class="k">new</span> <span class="nx">j$</span><span class="p">.</span><span class="nx">Env</span><span class="p">(),</span>
<span class="nx">container</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="s2">"div"</span><span class="p">),</span>
<span class="nx">getContainer</span> <span class="o">=</span> <span class="kd">function</span><span class="p">()</span> <span class="p">{</span> <span class="k">return</span> <span class="nx">container</span><span class="p">;</span> <span class="p">},</span>
<span class="nx">reporter</span> <span class="o">=</span> <span class="k">new</span> <span class="nx">j$</span><span class="p">.</span><span class="nx">HtmlReporter</span><span class="p">({</span>
<span class="nx">env</span><span class="o">:</span> <span class="nx">env</span><span class="p">,</span>
<span class="nx">getContainer</span><span class="o">:</span> <span class="nx">getContainer</span><span class="p">,</span>
<span class="nx">createElement</span><span class="o">:</span> <span class="kd">function</span><span class="p">()</span> <span class="p">{</span> <span class="k">return</span> <span class="nb">document</span><span class="p">.</span><span class="nx">createElement</span><span class="p">.</span><span class="nx">apply</span><span class="p">(</span><span class="nb">document</span><span class="p">,</span> <span class="nx">arguments</span><span class="p">);</span> <span class="p">},</span>
<span class="nx">createTextNode</span><span class="o">:</span> <span class="kd">function</span><span class="p">()</span> <span class="p">{</span> <span class="k">return</span> <span class="nb">document</span><span class="p">.</span><span class="nx">createTextNode</span><span class="p">.</span><span class="nx">apply</span><span class="p">(</span><span class="nb">document</span><span class="p">,</span> <span class="nx">arguments</span><span class="p">);</span> <span class="p">}</span>
<span class="p">});</span>
<span class="nx">reporter</span><span class="p">.</span><span class="nx">initialize</span><span class="p">();</span>
<span class="nx">reporter</span><span class="p">.</span><span class="nx">specDone</span><span class="p">({</span>
<span class="nx">id</span><span class="o">:</span> <span class="mi">345</span><span class="p">,</span>
<span class="nx">status</span><span class="o">:</span> <span class="s2">"failed"</span><span class="p">,</span>
<span class="nx">failedExpectations</span><span class="o">:</span> <span class="p">[],</span>
<span class="nx">passedExpectations</span><span class="o">:</span> <span class="p">[]</span>
<span class="p">});</span>
<span class="kd">var</span> <span class="nx">specEl</span> <span class="o">=</span> <span class="nx">container</span><span class="p">.</span><span class="nx">querySelector</span><span class="p">(</span><span class="s2">".symbol-summary li"</span><span class="p">);</span>
<span class="nx">expect</span><span class="p">(</span><span class="nx">specEl</span><span class="p">.</span><span class="nx">getAttribute</span><span class="p">(</span><span class="s2">"class"</span><span class="p">)).</span><span class="nx">toEqual</span><span class="p">(</span><span class="s2">"failed"</span><span class="p">);</span>
<span class="nx">expect</span><span class="p">(</span><span class="nx">specEl</span><span class="p">.</span><span class="nx">getAttribute</span><span class="p">(</span><span class="s2">"id"</span><span class="p">)).</span><span class="nx">toEqual</span><span class="p">(</span><span class="s2">"spec_345"</span><span class="p">);</span>
<span class="p">});</span>
<span class="p">});</span>
<span class="nx">describe</span><span class="p">(</span><span class="s2">"when Jasmine is done"</span><span class="p">,</span> <span class="kd">function</span><span class="p">()</span> <span class="p">{</span>
<span class="nx">it</span><span class="p">(</span><span class="s2">"adds EMPTY to the link title of specs that have no expectations"</span><span class="p">,</span> <span class="kd">function</span><span class="p">()</span> <span class="p">{</span>
<span class="k">if</span> <span class="p">(</span><span class="o">!</span><span class="nb">window</span><span class="p">.</span><span class="nx">console</span><span class="p">)</span> <span class="p">{</span>
<span class="nb">window</span><span class="p">.</span><span class="nx">console</span> <span class="o">=</span> <span class="p">{</span> <span class="nx">error</span><span class="o">:</span> <span class="kd">function</span><span class="p">(){}</span> <span class="p">};</span>
<span class="p">}</span>
<span class="kd">var</span> <span class="nx">env</span> <span class="o">=</span> <span class="k">new</span> <span class="nx">j$</span><span class="p">.</span><span class="nx">Env</span><span class="p">(),</span>
<span class="nx">container</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">'div'</span><span class="p">),</span>
<span class="nx">getContainer</span> <span class="o">=</span> <span class="kd">function</span><span class="p">()</span> <span class="p">{</span><span class="k">return</span> <span class="nx">container</span><span class="p">;},</span>
<span class="nx">reporter</span> <span class="o">=</span> <span class="k">new</span> <span class="nx">j$</span><span class="p">.</span><span class="nx">HtmlReporter</span><span class="p">({</span>
<span class="nx">env</span><span class="o">:</span> <span class="nx">env</span><span class="p">,</span>
<span class="nx">getContainer</span><span class="o">:</span> <span class="nx">getContainer</span><span class="p">,</span>
<span class="nx">createElement</span><span class="o">:</span> <span class="kd">function</span><span class="p">()</span> <span class="p">{</span> <span class="k">return</span> <span class="nb">document</span><span class="p">.</span><span class="nx">createElement</span><span class="p">.</span><span class="nx">apply</span><span class="p">(</span><span class="nb">document</span><span class="p">,</span> <span class="nx">arguments</span><span class="p">);</span> <span class="p">},</span>
<span class="nx">createTextNode</span><span class="o">:</span> <span class="kd">function</span><span class="p">()</span> <span class="p">{</span> <span class="k">return</span> <span class="nb">document</span><span class="p">.</span><span class="nx">createTextNode</span><span class="p">.</span><span class="nx">apply</span><span class="p">(</span><span class="nb">document</span><span class="p">,</span> <span class="nx">arguments</span><span class="p">);</span> <span class="p">}</span>
<span class="p">});</span>
<span class="nx">spyOn</span><span class="p">(</span><span class="nx">console</span><span class="p">,</span> <span class="s1">'error'</span><span class="p">);</span>
<span class="nx">reporter</span><span class="p">.</span><span class="nx">initialize</span><span class="p">();</span>
<span class="nx">reporter</span><span class="p">.</span><span class="nx">jasmineStarted</span><span class="p">({});</span>
<span class="nx">reporter</span><span class="p">.</span><span class="nx">suiteStarted</span><span class="p">({</span><span class="nx">id</span><span class="o">:</span> <span class="mi">1</span><span class="p">});</span>
<span class="nx">reporter</span><span class="p">.</span><span class="nx">specStarted</span><span class="p">({</span><span class="nx">id</span><span class="o">:</span> <span class="mi">1</span><span class="p">,</span> <span class="nx">status</span><span class="o">:</span> <span class="s1">'passed'</span><span class="p">,</span> <span class="nx">passedExpectations</span><span class="o">:</span> <span class="p">[],</span> <span class="nx">failedExpectations</span><span class="o">:</span> <span class="p">[]});</span>
<span class="nx">reporter</span><span class="p">.</span><span class="nx">specDone</span><span class="p">({</span>
<span class="nx">id</span><span class="o">:</span> <span class="mi">1</span><span class="p">,</span>
<span class="nx">status</span><span class="o">:</span> <span class="s1">'passed'</span><span class="p">,</span>
<span class="nx">description</span><span class="o">:</span> <span class="s1">'Spec Description'</span><span class="p">,</span>
<span class="nx">passedExpectations</span><span class="o">:</span> <span class="p">[],</span>
<span class="nx">failedExpectations</span><span class="o">:</span> <span class="p">[]</span>
<span class="p">});</span>
<span class="nx">reporter</span><span class="p">.</span><span class="nx">suiteDone</span><span class="p">({</span><span class="nx">id</span><span class="o">:</span> <span class="mi">1</span><span class="p">});</span>
<span class="nx">reporter</span><span class="p">.</span><span class="nx">jasmineDone</span><span class="p">({});</span>
<span class="kd">var</span> <span class="nx">summary</span> <span class="o">=</span> <span class="nx">container</span><span class="p">.</span><span class="nx">querySelector</span><span class="p">(</span><span class="s1">'.summary'</span><span class="p">);</span>
<span class="kd">var</span> <span class="nx">suite</span> <span class="o">=</span> <span class="nx">summary</span><span class="p">.</span><span class="nx">childNodes</span><span class="p">[</span><span class="mi">0</span><span class="p">];</span>
<span class="kd">var</span> <span class="nx">specs</span> <span class="o">=</span> <span class="nx">suite</span><span class="p">.</span><span class="nx">childNodes</span><span class="p">[</span><span class="mi">1</span><span class="p">];</span>
<span class="kd">var</span> <span class="nx">spec</span> <span class="o">=</span> <span class="nx">specs</span><span class="p">.</span><span class="nx">childNodes</span><span class="p">[</span><span class="mi">0</span><span class="p">];</span>
<span class="kd">var</span> <span class="nx">specLink</span> <span class="o">=</span> <span class="nx">spec</span><span class="p">.</span><span class="nx">childNodes</span><span class="p">[</span><span class="mi">0</span><span class="p">];</span>
<span class="nx">expect</span><span class="p">(</span><span class="nx">specLink</span><span class="p">.</span><span class="nx">innerHTML</span><span class="p">).</span><span class="nx">toMatch</span><span class="p">(</span><span class="sr">/SPEC HAS NO EXPECTATIONS/</span><span class="p">);</span>
<span class="p">});</span>
<span class="nx">it</span><span class="p">(</span><span class="s2">"reports the run time"</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">env</span> <span class="o">=</span> <span class="k">new</span> <span class="nx">j$</span><span class="p">.</span><span class="nx">Env</span><span class="p">(),</span>
<span class="nx">container</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="s2">"div"</span><span class="p">),</span>
<span class="nx">timer</span> <span class="o">=</span> <span class="nx">jasmine</span><span class="p">.</span><span class="nx">createSpyObj</span><span class="p">(</span><span class="s1">'timer'</span><span class="p">,</span> <span class="p">[</span><span class="s1">'start'</span><span class="p">,</span> <span class="s1">'elapsed'</span><span class="p">]),</span>
<span class="nx">getContainer</span> <span class="o">=</span> <span class="kd">function</span><span class="p">()</span> <span class="p">{</span> <span class="k">return</span> <span class="nx">container</span><span class="p">;</span> <span class="p">},</span>
<span class="nx">reporter</span> <span class="o">=</span> <span class="k">new</span> <span class="nx">j$</span><span class="p">.</span><span class="nx">HtmlReporter</span><span class="p">({</span>
<span class="nx">env</span><span class="o">:</span> <span class="nx">env</span><span class="p">,</span>
<span class="nx">getContainer</span><span class="o">:</span> <span class="nx">getContainer</span><span class="p">,</span>
<span class="nx">createElement</span><span class="o">:</span> <span class="kd">function</span><span class="p">()</span> <span class="p">{</span> <span class="k">return</span> <span class="nb">document</span><span class="p">.</span><span class="nx">createElement</span><span class="p">.</span><span class="nx">apply</span><span class="p">(</span><span class="nb">document</span><span class="p">,</span> <span class="nx">arguments</span><span class="p">);</span> <span class="p">},</span>
<span class="nx">createTextNode</span><span class="o">:</span> <span class="kd">function</span><span class="p">()</span> <span class="p">{</span> <span class="k">return</span> <span class="nb">document</span><span class="p">.</span><span class="nx">createTextNode</span><span class="p">.</span><span class="nx">apply</span><span class="p">(</span><span class="nb">document</span><span class="p">,</span> <span class="nx">arguments</span><span class="p">);</span> <span class="p">},</span>
<span class="nx">timer</span><span class="o">:</span> <span class="nx">timer</span>
<span class="p">});</span>
<span class="nx">reporter</span><span class="p">.</span><span class="nx">initialize</span><span class="p">();</span>
<span class="nx">reporter</span><span class="p">.</span><span class="nx">jasmineStarted</span><span class="p">({});</span>
<span class="nx">timer</span><span class="p">.</span><span class="nx">elapsed</span><span class="p">.</span><span class="nx">and</span><span class="p">.</span><span class="nx">returnValue</span><span class="p">(</span><span class="mi">100</span><span class="p">);</span>
<span class="nx">reporter</span><span class="p">.</span><span class="nx">jasmineDone</span><span class="p">();</span>
<span class="kd">var</span> <span class="nx">duration</span> <span class="o">=</span> <span class="nx">container</span><span class="p">.</span><span class="nx">querySelector</span><span class="p">(</span><span class="s2">".banner .duration"</span><span class="p">);</span>
<span class="nx">expect</span><span class="p">(</span><span class="nx">duration</span><span class="p">.</span><span class="nx">innerHTML</span><span class="p">).</span><span class="nx">toMatch</span><span class="p">(</span><span class="sr">/finished in 0.1s/</span><span class="p">);</span>
<span class="p">});</span>
<span class="nx">it</span><span class="p">(</span><span class="s2">"reports the suite and spec names with status"</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">env</span> <span class="o">=</span> <span class="k">new</span> <span class="nx">j$</span><span class="p">.</span><span class="nx">Env</span><span class="p">(),</span>
<span class="nx">container</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="s2">"div"</span><span class="p">),</span>
<span class="nx">getContainer</span> <span class="o">=</span> <span class="kd">function</span><span class="p">()</span> <span class="p">{</span> <span class="k">return</span> <span class="nx">container</span><span class="p">;</span> <span class="p">},</span>
<span class="nx">reporter</span> <span class="o">=</span> <span class="k">new</span> <span class="nx">j$</span><span class="p">.</span><span class="nx">HtmlReporter</span><span class="p">({</span>
<span class="nx">env</span><span class="o">:</span> <span class="nx">env</span><span class="p">,</span>
<span class="nx">getContainer</span><span class="o">:</span> <span class="nx"