2014-12-11 14:27:41 +00:00
<!DOCTYPE html>
< html lang = "en" >
< head >
< meta charset = "UTF-8" >
< title > Dashboard for /home/travis/build/thephpleague/oauth2-server/src/Util< / title >
< meta name = "viewport" content = "width=device-width, initial-scale=1.0" >
< link href = "../css/bootstrap.min.css" rel = "stylesheet" >
2015-07-13 20:56:40 +00:00
< link href = "../css/nv.d3.min.css" rel = "stylesheet" >
2014-12-11 14:27:41 +00:00
< link href = "../css/style.css" rel = "stylesheet" >
<!-- [if lt IE 9]>
< script src = "../js/html5shiv.min.js" > < / script >
< script src = "../js/respond.min.js" > < / script >
<![endif]-->
< / head >
< body >
< header >
< div class = "container" >
< div class = "row" >
< div class = "col-md-12" >
< ol class = "breadcrumb" >
< li > < a href = "../index.html" > /home/travis/build/thephpleague/oauth2-server/src< / a > < / li >
< li > < a href = "index.html" > Util< / a > < / li >
< li class = "active" > (Dashboard)< / li >
< / ol >
< / div >
< / div >
< / div >
< / header >
< div class = "container" >
< 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 >
< / 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 >
< / tbody >
< / table >
< / div >
< / div >
< / div >
< footer >
< hr / >
< p >
2015-09-26 15:06:01 +00:00
< small > Generated by < a href = "http://github.com/sebastianbergmann/php-code-coverage" target = "_top" > PHP_CodeCoverage 2.2.3< / a > using < a href = "http://php.net/" target = "_top" > PHP 5.6.5< / a > and < a href = "http://phpunit.de/" > PHPUnit 4.3.5< / a > at Sat Sep 26 15:05:45 UTC 2015.< / small >
2014-12-11 14:27:41 +00:00
< / p >
< / footer >
< / div >
< script src = "../js/jquery.min.js" type = "text/javascript" > < / script >
< script src = "../js/bootstrap.min.js" type = "text/javascript" > < / script >
2015-07-13 20:56:40 +00:00
< script src = "../js/holder.min.js" type = "text/javascript" > < / script >
2014-12-11 14:27:41 +00:00
< script src = "../js/d3.min.js" type = "text/javascript" > < / script >
< script src = "../js/nv.d3.min.js" type = "text/javascript" > < / script >
< 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')
2015-08-21 08:00:38 +00:00
.datum(getCoverageDistributionData([0,0,0,0,0,0,0,0,0,0,0,3], "Class Coverage"))
2014-12-11 14:27:41 +00: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')
2015-08-21 08:00:38 +00:00
.datum(getCoverageDistributionData([0,0,0,0,0,0,0,0,0,0,0,5], "Method Coverage"))
2014-12-11 14:27:41 +00:00
.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(key, y, e, graph) {
return '< p > ' + graph.point.class + '< / p > ';
});
chart.xAxis.axisLabel('Code Coverage (in percent)');
chart.yAxis.axisLabel('Cyclomatic Complexity');
d3.select('#classComplexity svg')
2015-08-21 08:00:38 +00:00
.datum(getComplexityData([[100,4,"< a href = \"KeyAlgorithm\/DefaultAlgorithm.php.html#14\" > DefaultAlgorithm< \/a>"],[100,2,"< a href = \"RedirectUri.php.html#17\" > RedirectUri< \/a>"],[100,4,"< a href = \"SecureKey.php.html#20\" > SecureKey< \/a>"]], 'Class Complexity'))
2014-12-11 14:27:41 +00: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(key, y, e, graph) {
return '< p > ' + graph.point.class + '< / p > ';
});
chart.xAxis.axisLabel('Code Coverage (in percent)');
chart.yAxis.axisLabel('Method Complexity');
d3.select('#methodComplexity svg')
2015-08-21 08:00:38 +00:00
.datum(getComplexityData([[100,4,"< a href = \"KeyAlgorithm\/DefaultAlgorithm.php.html#19\" > DefaultAlgorithm::generate< \/a>"],[100,2,"< a href = \"RedirectUri.php.html#28\" > RedirectUri::make< \/a>"],[100,1,"< a href = \"SecureKey.php.html#31\" > SecureKey::generate< \/a>"],[100,1,"< a href = \"SecureKey.php.html#39\" > SecureKey::setAlgorithm< \/a>"],[100,2,"< a href = \"SecureKey.php.html#47\" > SecureKey::getAlgorithm< \/a>"]], 'Method Complexity'))
2014-12-11 14:27:41 +00: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 >