Skip to content

Commit

Permalink
Set up a Testing Framework
Browse files Browse the repository at this point in the history
Write a test for 'htmlGenerator' function

Add more testing functions for htmlGenerator()

Update testing functions

Add test:watch & Code Coverage Analysis
  • Loading branch information
DerekJxy committed Nov 11, 2021
1 parent cdf3b06 commit 025d9a8
Show file tree
Hide file tree
Showing 18 changed files with 3,847 additions and 134 deletions.
2 changes: 1 addition & 1 deletion .prettierrc.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{ "trailingComma": "es5",
"tabWidth": 2,
"semi": false,
"semi": true,
"singleQuote": true
}

29 changes: 29 additions & 0 deletions coverage/clover.xml
Original file line number Diff line number Diff line change
@@ -0,0 +1,29 @@
<?xml version="1.0" encoding="UTF-8"?>
<coverage generated="1636595025511" clover="3.2.0">
<project timestamp="1636595025511" name="All files">
<metrics statements="20" coveredstatements="20" conditionals="26" coveredconditionals="26" methods="1" coveredmethods="1" elements="47" coveredelements="47" complexity="0" loc="20" ncloc="20" packages="1" files="1" classes="1"/>
<file name="htmlGenerator.js" path="E:\11\My-First-SSG\htmlGenerator.js">
<metrics statements="20" coveredstatements="20" conditionals="26" coveredconditionals="26" methods="1" coveredmethods="1"/>
<line num="3" count="11" type="cond" truecount="2" falsecount="0"/>
<line num="4" count="1" type="stmt"/>
<line num="5" count="10" type="cond" truecount="2" falsecount="0"/>
<line num="6" count="1" type="stmt"/>
<line num="9" count="9" type="cond" truecount="2" falsecount="0"/>
<line num="10" count="1" type="stmt"/>
<line num="11" count="8" type="cond" truecount="2" falsecount="0"/>
<line num="12" count="1" type="stmt"/>
<line num="15" count="7" type="cond" truecount="4" falsecount="0"/>
<line num="16" count="1" type="stmt"/>
<line num="17" count="6" type="cond" truecount="4" falsecount="0"/>
<line num="18" count="1" type="stmt"/>
<line num="21" count="5" type="cond" truecount="2" falsecount="0"/>
<line num="22" count="1" type="stmt"/>
<line num="23" count="4" type="cond" truecount="2" falsecount="0"/>
<line num="24" count="1" type="stmt"/>
<line num="27" count="3" type="cond" truecount="4" falsecount="0"/>
<line num="28" count="2" type="cond" truecount="2" falsecount="0"/>
<line num="47" count="1" type="stmt"/>
<line num="51" count="1" type="stmt"/>
</file>
</project>
</coverage>
2 changes: 2 additions & 0 deletions coverage/coverage-final.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
{"E:\\11\\My-First-SSG\\htmlGenerator.js": {"path":"E:\\11\\My-First-SSG\\htmlGenerator.js","statementMap":{"0":{"start":{"line":3,"column":2},"end":{"line":7,"column":3}},"1":{"start":{"line":4,"column":4},"end":{"line":4,"column":39}},"2":{"start":{"line":5,"column":9},"end":{"line":7,"column":3}},"3":{"start":{"line":6,"column":4},"end":{"line":6,"column":41}},"4":{"start":{"line":9,"column":2},"end":{"line":13,"column":3}},"5":{"start":{"line":10,"column":4},"end":{"line":10,"column":40}},"6":{"start":{"line":11,"column":9},"end":{"line":13,"column":3}},"7":{"start":{"line":12,"column":4},"end":{"line":12,"column":42}},"8":{"start":{"line":15,"column":2},"end":{"line":19,"column":3}},"9":{"start":{"line":16,"column":4},"end":{"line":16,"column":39}},"10":{"start":{"line":17,"column":9},"end":{"line":19,"column":3}},"11":{"start":{"line":18,"column":4},"end":{"line":18,"column":48}},"12":{"start":{"line":21,"column":2},"end":{"line":25,"column":3}},"13":{"start":{"line":22,"column":4},"end":{"line":22,"column":41}},"14":{"start":{"line":23,"column":9},"end":{"line":25,"column":3}},"15":{"start":{"line":24,"column":4},"end":{"line":24,"column":43}},"16":{"start":{"line":27,"column":2},"end":{"line":48,"column":3}},"17":{"start":{"line":28,"column":4},"end":{"line":45,"column":54}},"18":{"start":{"line":47,"column":4},"end":{"line":47,"column":48}},"19":{"start":{"line":51,"column":0},"end":{"line":51,"column":45}}},"fnMap":{"0":{"name":"htmlGenerator","decl":{"start":{"line":1,"column":9},"end":{"line":1,"column":22}},"loc":{"start":{"line":1,"column":50},"end":{"line":49,"column":1}},"line":1}},"branchMap":{"0":{"loc":{"start":{"line":3,"column":2},"end":{"line":7,"column":3}},"type":"if","locations":[{"start":{"line":3,"column":2},"end":{"line":7,"column":3}},{"start":{"line":5,"column":9},"end":{"line":7,"column":3}}],"line":3},"1":{"loc":{"start":{"line":5,"column":9},"end":{"line":7,"column":3}},"type":"if","locations":[{"start":{"line":5,"column":9},"end":{"line":7,"column":3}},{"start":{},"end":{}}],"line":5},"2":{"loc":{"start":{"line":9,"column":2},"end":{"line":13,"column":3}},"type":"if","locations":[{"start":{"line":9,"column":2},"end":{"line":13,"column":3}},{"start":{"line":11,"column":9},"end":{"line":13,"column":3}}],"line":9},"3":{"loc":{"start":{"line":11,"column":9},"end":{"line":13,"column":3}},"type":"if","locations":[{"start":{"line":11,"column":9},"end":{"line":13,"column":3}},{"start":{},"end":{}}],"line":11},"4":{"loc":{"start":{"line":15,"column":2},"end":{"line":19,"column":3}},"type":"if","locations":[{"start":{"line":15,"column":2},"end":{"line":19,"column":3}},{"start":{"line":17,"column":9},"end":{"line":19,"column":3}}],"line":15},"5":{"loc":{"start":{"line":15,"column":6},"end":{"line":15,"column":56}},"type":"binary-expr","locations":[{"start":{"line":15,"column":6},"end":{"line":15,"column":29}},{"start":{"line":15,"column":33},"end":{"line":15,"column":56}}],"line":15},"6":{"loc":{"start":{"line":17,"column":9},"end":{"line":19,"column":3}},"type":"if","locations":[{"start":{"line":17,"column":9},"end":{"line":19,"column":3}},{"start":{},"end":{}}],"line":17},"7":{"loc":{"start":{"line":17,"column":13},"end":{"line":17,"column":50}},"type":"binary-expr","locations":[{"start":{"line":17,"column":13},"end":{"line":17,"column":36}},{"start":{"line":17,"column":40},"end":{"line":17,"column":50}}],"line":17},"8":{"loc":{"start":{"line":21,"column":2},"end":{"line":25,"column":3}},"type":"if","locations":[{"start":{"line":21,"column":2},"end":{"line":25,"column":3}},{"start":{"line":23,"column":9},"end":{"line":25,"column":3}}],"line":21},"9":{"loc":{"start":{"line":23,"column":9},"end":{"line":25,"column":3}},"type":"if","locations":[{"start":{"line":23,"column":9},"end":{"line":25,"column":3}},{"start":{},"end":{}}],"line":23},"10":{"loc":{"start":{"line":27,"column":2},"end":{"line":48,"column":3}},"type":"if","locations":[{"start":{"line":27,"column":2},"end":{"line":48,"column":3}},{"start":{"line":46,"column":9},"end":{"line":48,"column":3}}],"line":27},"11":{"loc":{"start":{"line":27,"column":6},"end":{"line":27,"column":30}},"type":"binary-expr","locations":[{"start":{"line":27,"column":6},"end":{"line":27,"column":16}},{"start":{"line":27,"column":20},"end":{"line":27,"column":30}}],"line":27},"12":{"loc":{"start":{"line":28,"column":11},"end":{"line":45,"column":53}},"type":"cond-expr","locations":[{"start":{"line":29,"column":8},"end":{"line":36,"column":53}},{"start":{"line":37,"column":8},"end":{"line":45,"column":53}}],"line":28}},"s":{"0":11,"1":1,"2":10,"3":1,"4":9,"5":1,"6":8,"7":1,"8":7,"9":1,"10":6,"11":1,"12":5,"13":1,"14":4,"15":1,"16":3,"17":2,"18":1,"19":1},"f":{"0":11},"b":{"0":[1,10],"1":[1,9],"2":[1,8],"3":[1,7],"4":[1,6],"5":[7,3],"6":[1,5],"7":[6,4],"8":[1,4],"9":[1,3],"10":[2,1],"11":[3,2],"12":[1,1]},"_coverageSchema":"1a1c01bbd47fc00a2c39e90264f33305004495a9","hash":"078f77afdf970d93831fb2b42416c88b5a29aafd"}
}
224 changes: 224 additions & 0 deletions coverage/lcov-report/base.css
Original file line number Diff line number Diff line change
@@ -0,0 +1,224 @@
body, html {
margin:0; padding: 0;
height: 100%;
}
body {
font-family: Helvetica Neue, Helvetica, Arial;
font-size: 14px;
color:#333;
}
.small { font-size: 12px; }
*, *:after, *:before {
-webkit-box-sizing:border-box;
-moz-box-sizing:border-box;
box-sizing:border-box;
}
h1 { font-size: 20px; margin: 0;}
h2 { font-size: 14px; }
pre {
font: 12px/1.4 Consolas, "Liberation Mono", Menlo, Courier, monospace;
margin: 0;
padding: 0;
-moz-tab-size: 2;
-o-tab-size: 2;
tab-size: 2;
}
a { color:#0074D9; text-decoration:none; }
a:hover { text-decoration:underline; }
.strong { font-weight: bold; }
.space-top1 { padding: 10px 0 0 0; }
.pad2y { padding: 20px 0; }
.pad1y { padding: 10px 0; }
.pad2x { padding: 0 20px; }
.pad2 { padding: 20px; }
.pad1 { padding: 10px; }
.space-left2 { padding-left:55px; }
.space-right2 { padding-right:20px; }
.center { text-align:center; }
.clearfix { display:block; }
.clearfix:after {
content:'';
display:block;
height:0;
clear:both;
visibility:hidden;
}
.fl { float: left; }
@media only screen and (max-width:640px) {
.col3 { width:100%; max-width:100%; }
.hide-mobile { display:none!important; }
}

.quiet {
color: #7f7f7f;
color: rgba(0,0,0,0.5);
}
.quiet a { opacity: 0.7; }

.fraction {
font-family: Consolas, 'Liberation Mono', Menlo, Courier, monospace;
font-size: 10px;
color: #555;
background: #E8E8E8;
padding: 4px 5px;
border-radius: 3px;
vertical-align: middle;
}

div.path a:link, div.path a:visited { color: #333; }
table.coverage {
border-collapse: collapse;
margin: 10px 0 0 0;
padding: 0;
}

table.coverage td {
margin: 0;
padding: 0;
vertical-align: top;
}
table.coverage td.line-count {
text-align: right;
padding: 0 5px 0 20px;
}
table.coverage td.line-coverage {
text-align: right;
padding-right: 10px;
min-width:20px;
}

table.coverage td span.cline-any {
display: inline-block;
padding: 0 5px;
width: 100%;
}
.missing-if-branch {
display: inline-block;
margin-right: 5px;
border-radius: 3px;
position: relative;
padding: 0 4px;
background: #333;
color: yellow;
}

.skip-if-branch {
display: none;
margin-right: 10px;
position: relative;
padding: 0 4px;
background: #ccc;
color: white;
}
.missing-if-branch .typ, .skip-if-branch .typ {
color: inherit !important;
}
.coverage-summary {
border-collapse: collapse;
width: 100%;
}
.coverage-summary tr { border-bottom: 1px solid #bbb; }
.keyline-all { border: 1px solid #ddd; }
.coverage-summary td, .coverage-summary th { padding: 10px; }
.coverage-summary tbody { border: 1px solid #bbb; }
.coverage-summary td { border-right: 1px solid #bbb; }
.coverage-summary td:last-child { border-right: none; }
.coverage-summary th {
text-align: left;
font-weight: normal;
white-space: nowrap;
}
.coverage-summary th.file { border-right: none !important; }
.coverage-summary th.pct { }
.coverage-summary th.pic,
.coverage-summary th.abs,
.coverage-summary td.pct,
.coverage-summary td.abs { text-align: right; }
.coverage-summary td.file { white-space: nowrap; }
.coverage-summary td.pic { min-width: 120px !important; }
.coverage-summary tfoot td { }

.coverage-summary .sorter {
height: 10px;
width: 7px;
display: inline-block;
margin-left: 0.5em;
background: url(sort-arrow-sprite.png) no-repeat scroll 0 0 transparent;
}
.coverage-summary .sorted .sorter {
background-position: 0 -20px;
}
.coverage-summary .sorted-desc .sorter {
background-position: 0 -10px;
}
.status-line { height: 10px; }
/* yellow */
.cbranch-no { background: yellow !important; color: #111; }
/* dark red */
.red.solid, .status-line.low, .low .cover-fill { background:#C21F39 }
.low .chart { border:1px solid #C21F39 }
.highlighted,
.highlighted .cstat-no, .highlighted .fstat-no, .highlighted .cbranch-no{
background: #C21F39 !important;
}
/* medium red */
.cstat-no, .fstat-no, .cbranch-no, .cbranch-no { background:#F6C6CE }
/* light red */
.low, .cline-no { background:#FCE1E5 }
/* light green */
.high, .cline-yes { background:rgb(230,245,208) }
/* medium green */
.cstat-yes { background:rgb(161,215,106) }
/* dark green */
.status-line.high, .high .cover-fill { background:rgb(77,146,33) }
.high .chart { border:1px solid rgb(77,146,33) }
/* dark yellow (gold) */
.status-line.medium, .medium .cover-fill { background: #f9cd0b; }
.medium .chart { border:1px solid #f9cd0b; }
/* light yellow */
.medium { background: #fff4c2; }

.cstat-skip { background: #ddd; color: #111; }
.fstat-skip { background: #ddd; color: #111 !important; }
.cbranch-skip { background: #ddd !important; color: #111; }

span.cline-neutral { background: #eaeaea; }

.coverage-summary td.empty {
opacity: .5;
padding-top: 4px;
padding-bottom: 4px;
line-height: 1;
color: #888;
}

.cover-fill, .cover-empty {
display:inline-block;
height: 12px;
}
.chart {
line-height: 0;
}
.cover-empty {
background: white;
}
.cover-full {
border-right: none !important;
}
pre.prettyprint {
border: none !important;
padding: 0 !important;
margin: 0 !important;
}
.com { color: #999 !important; }
.ignore-none { color: #999; font-weight: normal; }

.wrapper {
min-height: 100%;
height: auto !important;
height: 100%;
margin: 0 auto -48px;
}
.footer, .push {
height: 48px;
}
79 changes: 79 additions & 0 deletions coverage/lcov-report/block-navigation.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,79 @@
/* eslint-disable */
var jumpToCode = (function init() {
// Classes of code we would like to highlight in the file view
var missingCoverageClasses = ['.cbranch-no', '.cstat-no', '.fstat-no'];

// Elements to highlight in the file listing view
var fileListingElements = ['td.pct.low'];

// We don't want to select elements that are direct descendants of another match
var notSelector = ':not(' + missingCoverageClasses.join('):not(') + ') > '; // becomes `:not(a):not(b) > `

// Selecter that finds elements on the page to which we can jump
var selector =
fileListingElements.join(', ') +
', ' +
notSelector +
missingCoverageClasses.join(', ' + notSelector); // becomes `:not(a):not(b) > a, :not(a):not(b) > b`

// The NodeList of matching elements
var missingCoverageElements = document.querySelectorAll(selector);

var currentIndex;

function toggleClass(index) {
missingCoverageElements
.item(currentIndex)
.classList.remove('highlighted');
missingCoverageElements.item(index).classList.add('highlighted');
}

function makeCurrent(index) {
toggleClass(index);
currentIndex = index;
missingCoverageElements.item(index).scrollIntoView({
behavior: 'smooth',
block: 'center',
inline: 'center'
});
}

function goToPrevious() {
var nextIndex = 0;
if (typeof currentIndex !== 'number' || currentIndex === 0) {
nextIndex = missingCoverageElements.length - 1;
} else if (missingCoverageElements.length > 1) {
nextIndex = currentIndex - 1;
}

makeCurrent(nextIndex);
}

function goToNext() {
var nextIndex = 0;

if (
typeof currentIndex === 'number' &&
currentIndex < missingCoverageElements.length - 1
) {
nextIndex = currentIndex + 1;
}

makeCurrent(nextIndex);
}

return function jump(event) {
switch (event.which) {
case 78: // n
case 74: // j
goToNext();
break;
case 66: // b
case 75: // k
case 80: // p
goToPrevious();
break;
}
};
})();
window.addEventListener('keydown', jumpToCode);
Binary file added coverage/lcov-report/favicon.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading

0 comments on commit 025d9a8

Please sign in to comment.