2021-06-13 14:35:07 +01:00
<!DOCTYPE html>
< html lang = "en" >
< head >
< meta charset = "UTF-8" >
2021-06-14 22:53:15 +01:00
< title > Dashboard for /Users/barnabywalters/Documents/Programming/taproot/indieauth/src/Storage< / title >
2021-06-13 14:35:07 +01:00
< meta name = "viewport" content = "width=device-width, initial-scale=1.0" >
2021-06-13 14:47:54 +01:00
< link href = "../phpunit_css/bootstrap.min.css" rel = "stylesheet" type = "text/css" >
< link href = "../phpunit_css/nv.d3.min.css" rel = "stylesheet" type = "text/css" >
< link href = "../phpunit_css/style.css" rel = "stylesheet" type = "text/css" >
< link href = "../phpunit_css/custom.css" rel = "stylesheet" type = "text/css" >
2021-06-13 14:35:07 +01:00
< / head >
< body >
< header >
< div class = "container-fluid" >
< div class = "row" >
< div class = "col-md-12" >
< nav aria-label = "breadcrumb" >
< ol class = "breadcrumb" >
2021-06-14 22:53:15 +01:00
< li class = "breadcrumb-item" > < a href = "../index.html" > /Users/barnabywalters/Documents/Programming/taproot/indieauth/src< / a > < / li >
2021-06-13 14:35:07 +01:00
< li class = "breadcrumb-item" > < a href = "index.html" > Storage< / a > < / li >
< li class = "breadcrumb-item active" > (Dashboard)< / li >
< / ol >
< / nav >
< / div >
< / div >
< / div >
< / header >
< div class = "container-fluid" >
< div class = "row" >
< div class = "col-md-12" >
< h2 > Classes< / h2 >
< / div >
< / div >
< div class = "row" >
< div class = "col-md-6" >
< h3 > Coverage Distribution< / h3 >
< div id = "classCoverageDistribution" style = "height: 300px;" >
< svg > < / svg >
< / div >
< / div >
< div class = "col-md-6" >
< h3 > Complexity< / h3 >
< div id = "classComplexity" style = "height: 300px;" >
< svg > < / svg >
< / div >
< / div >
< / div >
< div class = "row" >
< div class = "col-md-6" >
< h3 > Insufficient Coverage< / h3 >
< div class = "scrollbox" >
< table class = "table" >
< thead >
< tr >
< th > Class< / th >
< th class = "text-right" > Coverage< / th >
< / tr >
< / thead >
< tbody >
< / tbody >
< / table >
< / div >
< / div >
< div class = "col-md-6" >
< h3 > Project Risks< / h3 >
< div class = "scrollbox" >
< table class = "table" >
< thead >
< tr >
< th > Class< / th >
< th class = "text-right" > < abbr title = "Change Risk Anti-Patterns (CRAP) Index" > CRAP< / abbr > < / th >
< / tr >
< / thead >
< tbody >
< / tbody >
< / table >
< / div >
< / div >
< / div >
< div class = "row" >
< div class = "col-md-12" >
< h2 > Methods< / h2 >
< / div >
< / div >
< div class = "row" >
< div class = "col-md-6" >
< h3 > Coverage Distribution< / h3 >
< div id = "methodCoverageDistribution" style = "height: 300px;" >
< svg > < / svg >
< / div >
< / div >
< div class = "col-md-6" >
< h3 > Complexity< / h3 >
< div id = "methodComplexity" style = "height: 300px;" >
< svg > < / svg >
< / div >
< / div >
< / div >
< div class = "row" >
< div class = "col-md-6" >
< h3 > Insufficient Coverage< / h3 >
< div class = "scrollbox" >
< table class = "table" >
< thead >
< tr >
< th > Method< / th >
< th class = "text-right" > Coverage< / th >
< / tr >
< / thead >
< tbody >
< tr > < td > < a href = "FilesystemJsonStorage.php.html#40" > < abbr title = "Taproot\IndieAuth\Storage\FilesystemJsonStorage::__construct" > __construct< / abbr > < / a > < / td > < td class = "text-right" > 81%< / td > < / tr >
< tr > < td > < a href = "FilesystemJsonStorage.php.html#68" > < abbr title = "Taproot\IndieAuth\Storage\FilesystemJsonStorage::createAuthCode" > createAuthCode< / abbr > < / a > < / td > < td class = "text-right" > 85%< / td > < / tr >
< tr > < td > < a href = "FilesystemJsonStorage.php.html#228" > < abbr title = "Taproot\IndieAuth\Storage\FilesystemJsonStorage::delete" > delete< / abbr > < / a > < / td > < td class = "text-right" > 87%< / td > < / tr >
< / tbody >
< / table >
< / div >
< / div >
< div class = "col-md-6" >
< h3 > Project Risks< / h3 >
< div class = "scrollbox" >
< table class = "table" >
< thead >
< tr >
< th > Method< / th >
< th class = "text-right" > < abbr title = "Change Risk Anti-Patterns (CRAP) Index" > CRAP< / abbr > < / th >
< / tr >
< / thead >
< tbody >
2021-06-15 00:14:27 +01:00
< tr > < td > < a href = "FilesystemJsonStorage.php.html#40" > < abbr title = "Taproot\IndieAuth\Storage\FilesystemJsonStorage::__construct" > __construct< / abbr > < / a > < / td > < td class = "text-right" > 3< / td > < / tr >
2021-06-13 14:35:07 +01:00
< tr > < td > < a href = "FilesystemJsonStorage.php.html#68" > < abbr title = "Taproot\IndieAuth\Storage\FilesystemJsonStorage::createAuthCode" > createAuthCode< / abbr > < / a > < / td > < td class = "text-right" > 3< / td > < / tr >
< tr > < td > < a href = "FilesystemJsonStorage.php.html#228" > < abbr title = "Taproot\IndieAuth\Storage\FilesystemJsonStorage::delete" > delete< / abbr > < / a > < / td > < td class = "text-right" > 3< / td > < / tr >
< / tbody >
< / table >
< / div >
< / div >
< / div >
< footer >
< hr / >
< p >
2021-06-15 00:14:27 +01:00
< small > Generated by < a href = "https://github.com/sebastianbergmann/php-code-coverage" target = "_top" > php-code-coverage 9.2.6< / a > using < a href = "https://secure.php.net/" target = "_top" > PHP 7.4.19< / a > with < a href = "https://xdebug.org/" > Xdebug 3.0.4< / a > and < a href = "https://phpunit.de/" > PHPUnit 9.5.5< / a > at Mon Jun 14 23:14:13 UTC 2021.< / small >
2021-06-13 14:35:07 +01:00
< / p >
< / footer >
< / div >
2021-06-13 14:47:54 +01:00
< script src = "../phpunit_js/jquery.min.js" type = "text/javascript" > < / script >
< script src = "../phpunit_js/d3.min.js" type = "text/javascript" > < / script >
< script src = "../phpunit_js/nv.d3.min.js" type = "text/javascript" > < / script >
2021-06-13 14:35:07 +01:00
< script type = "text/javascript" >
$(document).ready(function() {
nv.addGraph(function() {
var chart = nv.models.multiBarChart();
chart.tooltips(false)
.showControls(false)
.showLegend(false)
.reduceXTicks(false)
.staggerLabels(true)
.yAxis.tickFormat(d3.format('d'));
d3.select('#classCoverageDistribution svg')
2021-06-15 00:14:27 +01:00
.datum(getCoverageDistributionData([0,0,0,0,0,0,0,0,0,0,1,0], "Class Coverage"))
2021-06-13 14:35:07 +01:00
.transition().duration(500).call(chart);
nv.utils.windowResize(chart.update);
return chart;
});
nv.addGraph(function() {
var chart = nv.models.multiBarChart();
chart.tooltips(false)
.showControls(false)
.showLegend(false)
.reduceXTicks(false)
.staggerLabels(true)
.yAxis.tickFormat(d3.format('d'));
d3.select('#methodCoverageDistribution svg')
.datum(getCoverageDistributionData([0,0,0,0,0,0,0,0,0,3,3,7], "Method Coverage"))
.transition().duration(500).call(chart);
nv.utils.windowResize(chart.update);
return chart;
});
function getCoverageDistributionData(data, label) {
var labels = [
'0%',
'0-10%',
'10-20%',
'20-30%',
'30-40%',
'40-50%',
'50-60%',
'60-70%',
'70-80%',
'80-90%',
'90-100%',
'100%'
];
var values = [];
$.each(labels, function(key) {
values.push({x: labels[key], y: data[key]});
});
return [
{
key: label,
values: values,
color: "#4572A7"
}
];
}
nv.addGraph(function() {
var chart = nv.models.scatterChart()
.showDistX(true)
.showDistY(true)
.showLegend(false)
.forceX([0, 100]);
chart.tooltipContent(function(graph) {
return '< p > ' + graph.point.class + '< / p > ';
});
chart.xAxis.axisLabel('Code Coverage (in percent)');
chart.yAxis.axisLabel('Cyclomatic Complexity');
d3.select('#classComplexity svg')
2021-06-15 00:14:27 +01:00
.datum(getComplexityData([[92.3076923076923,46,"< a href = \"FilesystemJsonStorage.php.html#26\" > Taproot\\IndieAuth\\Storage\\FilesystemJsonStorage< \/a>"]], 'Class Complexity'))
2021-06-13 14:35:07 +01:00
.transition()
.duration(500)
.call(chart);
nv.utils.windowResize(chart.update);
return chart;
});
nv.addGraph(function() {
var chart = nv.models.scatterChart()
.showDistX(true)
.showDistY(true)
.showLegend(false)
.forceX([0, 100]);
chart.tooltipContent(function(graph) {
return '< p > ' + graph.point.class + '< / p > ';
});
chart.xAxis.axisLabel('Code Coverage (in percent)');
chart.yAxis.axisLabel('Method Complexity');
d3.select('#methodComplexity svg')
2021-06-15 00:14:27 +01:00
.datum(getComplexityData([[81.81818181818183,3,"< a href = \"FilesystemJsonStorage.php.html#40\" > Taproot\\IndieAuth\\Storage\\FilesystemJsonStorage::__construct< \/a>"],[100,1,"< a href = \"FilesystemJsonStorage.php.html#62\" > Taproot\\IndieAuth\\Storage\\FilesystemJsonStorage::setLogger< \/a>"],[85.71428571428571,3,"< a href = \"FilesystemJsonStorage.php.html#68\" > Taproot\\IndieAuth\\Storage\\FilesystemJsonStorage::createAuthCode< \/a>"],[92.85714285714286,11,"< a href = \"FilesystemJsonStorage.php.html#82\" > Taproot\\IndieAuth\\Storage\\FilesystemJsonStorage::exchangeAuthCodeForAccessToken< \/a>"],[100,5,"< a href = \"FilesystemJsonStorage.php.html#147\" > Taproot\\IndieAuth\\Storage\\FilesystemJsonStorage::getAccessToken< \/a>"],[100,1,"< a href = \"FilesystemJsonStorage.php.html#163\" > Taproot\\IndieAuth\\Storage\\FilesystemJsonStorage::revokeAccessToken< \/a>"],[100,9,"< a href = \"FilesystemJsonStorage.php.html#169\" > Taproot\\IndieAuth\\Storage\\FilesystemJsonStorage::deleteExpiredTokens< \/a>"],[91.66666666666666,4,"< a href = \"FilesystemJsonStorage.php.html#197\" > Taproot\\IndieAuth\\Storage\\FilesystemJsonStorage::get< \/a>"],[100,1,"< a href = \"FilesystemJsonStorage.php.html#219\" > Taproot\\IndieAuth\\Storage\\FilesystemJsonStorage::put< \/a>"],[87.5,3,"< a href = \"FilesystemJsonStorage.php.html#228\" > Taproot\\IndieAuth\\Storage\\FilesystemJsonStorage::delete< \/a>"],[100,1,"< a href = \"FilesystemJsonStorage.php.html#242\" > Taproot\\IndieAuth\\Storage\\FilesystemJsonStorage::getPath< \/a>"],[90.9090909090909,3,"< a href = \"FilesystemJsonStorage.php.html#247\" > Taproot\\IndieAuth\\Storage\\FilesystemJsonStorage::withLock< \/a>"],[100,1,"< a href = \"FilesystemJsonStorage.php.html#271\" > Taproot\\IndieAuth\\Storage\\FilesystemJsonStorage::hash< \/a>"]], 'Method Complexity'))
2021-06-13 14:35:07 +01:00
.transition()
.duration(500)
.call(chart);
nv.utils.windowResize(chart.update);
return chart;
});
function getComplexityData(data, label) {
var values = [];
$.each(data, function(key) {
var value = Math.round(data[key][0]*100) / 100;
values.push({
x: value,
y: data[key][1],
class: data[key][2],
size: 0.05,
shape: 'diamond'
});
});
return [
{
key: label,
values: values,
color: "#4572A7"
}
];
}
});
< / script >
< / body >
< / html >