forked from loadfocus/pageloadtime
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathload.sh
106 lines (87 loc) · 4.48 KB
/
load.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
#!/bin/bash
# Builds the RESULT_HTML chart file
RESULT_HTML=results.html
rm -f $RESULT_HTML
rm -rf results*
rm -rf reports*
echo $1
echo $3
phantomprocess=$3" --local-to-remote-url-access=true --load-images=true --ignore-ssl-errors=true --web-security=false loadreport.js $1 performance json wip &"
for ((i = 0; i<$2; i++))
do
echo "Start test"
$phantomprocess & echo $!
for ((j=0; j< 60;j++ ))
do
if ps -p $!;then
sleep 1
echo "sleep 1 second"
fi
done
if ps -p $!;then
kill $!
fi
done
# Add cols
echo "<html>
<head>
<script src=\"http://code.jquery.com/jquery-1.10.0.min.js\"></script>
<script type=\"text/javascript\" src=\"https://www.google.com/jsapi\"></script>
<script type=\"text/javascript\">
google.load(\"visualization\", \"1\", {packages:[\"corechart\"]});
google.setOnLoadCallback(drawChart);
function drawChart() {
var rows = new Array();
var columns = new Array();
$.getJSON(\"reports/loadreport-wip.json\", function(data) {
console.log(data);
for (var i = 0; i < data.length; i++){
var singleRow = {\"c\":[ {\"v\": i },
{ \"node\" : \"Elapsed Load Time\", \"v\" : data[i].elapsedLoadTime },
{ \"nodeid\" : \"Total resources time\", \"v\" : data[i].totalResourcesTime },
{ \"nodeid1\" : \"Number of resources\", \"v\" : data[i].numberOfResources },
{ \"nodeid1\" : \"Total resources size\", \"v\" : data[i].totalResourcesSize },
{ \"nodeid1\" : \"DOM ready state interactive\", \"v\" : data[i].domReadystateInteractive },
{ \"nodeid1\" : \"DOM ready state loading\", \"v\" : data[i].domReadystateLoading },
{ \"nodeid1\" : \"Non reporting resources\", \"v\" : data[i].nonReportingResources }
]};
rows.push(singleRow);
\$('#slowest').append('<li>Run'+i + \" URL: \" +data[i].slowestResource+'</li>');
\$('#largest').append('<li>Run'+i + \" URL: \" +data[i].largestResource+'</li>');
for (var j = 0; j < data[i].resource.length; j++){
\$('#resource').append('<li>Run '+i + \" URL: \" +data[i].resource[j].url+' Size: '+data[i].resource[j].size+' bytes</li>');
}
\$('#resource').append('<li>**********************************************************************************************************</li>');
}
var jsonData = {\"cols\": [
{\"id\":\"\",\"label\":\"commitNumber\",\"type\":\"string\"},
{\"id\":\"\",\"label\":\"Elapsed Load Time\",\"type\":\"number\"},
{\"id\":\"\",\"label\":\"Total resources time\",\"type\":\"number\"},
{\"id\":\"\",\"label\":\"Number of resources\",\"type\":\"number\"},
{\"id\":\"\",\"label\":\"Total resources size\",\"type\":\"number\"},
{\"id\":\"\",\"label\":\"DOM ready state interactive\",\"type\":\"number\"},
{\"id\":\"\",\"label\":\"DOM ready state loading\",\"type\":\"number\"},
{\"id\":\"\",\"label\":\"Non reporting resources\",\"type\":\"number\"}
], \"rows\": rows};
var newData = new google.visualization.DataTable(jsonData);
var options = {
title: 'Load test results ' + data[0].url,
curveType: \"function\"
};
var chart = new google.visualization.LineChart(document.getElementById('chart_div'));
chart.draw(newData, options);
});
}
</script>
</head>
<body>
<div id=\"chart_div\" style=\"width: 1600px; height: 800px;\"></div>
Slowest resource
<ul id=\"slowest\"></ul>
Largest resource
<ul id=\"largest\"></ul>
Resource
<ul id=\"resource\"></ul>
</body>
</html>
" >> $RESULT_HTML