Commit | Line | Data |
---|---|---|
7165f97b | 1 | <!-- A local source file that allows dygraph developers to test locally. --> |
644eff8b RK |
2 | <html> |
3 | <head> | |
7165f97b RK |
4 | <!-- Standard Dygraph scripts --> |
5 | <meta http-equiv="X-UA-Compatible" content="IE=EmulateIE7; IE=EmulateIE9"> | |
6 | <!--[if IE]> | |
7 | <script type="text/javascript" src="../../excanvas.js"></script> | |
8 | <![endif]--> | |
8d3d15af | 9 | <script type="text/javascript" src="../../dygraph-dev.js"></script> |
7165f97b RK |
10 | |
11 | <!-- Scripts for automated tests --> | |
12 | <script type="text/javascript" src="../lib/jquery-1.4.2.js"></script> | |
13 | <script type="text/javascript" src="../lib/Asserts.js"></script> | |
14 | <script type="text/javascript" src="fake-jstestdriver.js"></script> | |
15 | <script type="text/javascript" src="../tests/Proxy.js"></script> | |
16 | <script type="text/javascript" src="../tests/CanvasAssertions.js"></script> | |
72a74f04 | 17 | <script type="text/javascript" src="../tests/DygraphOps.js"></script> |
6a4587ac | 18 | <script type="text/javascript" src="../tests/annotations.js"></script> |
f3cbe61e | 19 | <script type="text/javascript" src="../tests/axis_labels.js"></script> |
6a4587ac RK |
20 | <script type="text/javascript" src="../tests/callback.js"></script> |
21 | <script type="text/javascript" src="../tests/css.js"></script> | |
22 | <script type="text/javascript" src="../tests/custom_bars.js"></script> | |
23 | <script type="text/javascript" src="../tests/date_formats.js"></script> | |
24 | <script type="text/javascript" src="../tests/error_bars.js"></script> | |
25 | <script type="text/javascript" src="../tests/formats.js"></script> | |
9c831431 | 26 | <script type="text/javascript" src="../tests/interaction_model.js"></script> |
cea0fb70 | 27 | <script type="text/javascript" src="../tests/missing_points.js"></script> |
6a4587ac RK |
28 | <script type="text/javascript" src="../tests/multiple_axes.js"></script> |
29 | <script type="text/javascript" src="../tests/multi_csv.js"></script> | |
30 | <script type="text/javascript" src="../tests/no_hours.js"></script> | |
31 | <script type="text/javascript" src="../tests/pathological_cases.js"></script> | |
32 | ||
33 | <script type="text/javascript" src="../tests/range_tests.js"></script> | |
34 | <script type="text/javascript" src="../tests/rolling_average.js"></script> | |
35 | <script type="text/javascript" src="../tests/sanity.js"></script> | |
36 | <script type="text/javascript" src="../tests/selection.js"></script> | |
37 | <script type="text/javascript" src="../tests/scientific_notation.js"></script> | |
38 | <script type="text/javascript" src="../tests/scrolling_div.js"></script> | |
39 | <script type="text/javascript" src="../tests/simple_drawing.js"></script> | |
0842b24b | 40 | <!-- |
48e614ac | 41 | <script type="text/javascript" src="../tests/tickers.js"></script> |
0842b24b | 42 | --> |
6a4587ac | 43 | <script type="text/javascript" src="../tests/to_dom_coords.js"></script> |
97583b90 | 44 | <script type="text/javascript" src="../tests/update_while_panning.js"></script> |
890e2a37 | 45 | <script type="text/javascript" src="../tests/stacked.js"></script> |
e2d8db3a | 46 | <script type="text/javascript" src="../tests/per_series.js"></script> |
9ca829f2 | 47 | <script type="text/javascript" src="../tests/update_options.js"></script> |
48e614ac | 48 | <script type="text/javascript" src="../tests/utils_test.js"></script> |
87bbdb4d | 49 | |
5cfed8c5 RK |
50 | <style type="text/css"> |
51 | .pass .outcome { | |
52 | color: green; | |
53 | } | |
54 | ||
55 | .fail .outcome { | |
56 | color: red; | |
57 | } | |
87bbdb4d | 58 | |
5cfed8c5 RK |
59 | .activeAnchor { |
60 | color: black; | |
61 | text-decoration: none; | |
62 | } | |
63 | </style> | |
6788e30b | 64 | <script type="text/javascript"> |
b43b50fe RK |
65 | var tc = null; // Selected test case |
66 | var name = null; | |
5cfed8c5 RK |
67 | |
68 | var resultDiv = null; | |
69 | ||
6788e30b RK |
70 | function processVariables() { |
71 | var splitVariables = function() { // http://www.idealog.us/2006/06/javascript_to_p.html | |
72 | var query = window.location.search.substring(1); | |
73 | var args = {}; | |
74 | var vars = query.split("&"); | |
3d8093fa RK |
75 | for (var i = 0; i < vars.length; i++) { |
76 | if (vars[i].length > 0) { | |
77 | var pair = vars[i].split("="); | |
78 | args[pair[0]] = pair[1]; | |
79 | } | |
6788e30b RK |
80 | } |
81 | return args; | |
82 | } | |
83 | ||
84 | var args = splitVariables(); | |
85 | var test = args.test; | |
86 | var command = args.command; | |
87 | ||
ef13835b | 88 | // args.testCaseName uses the string name of the test. |
357f7a8a RK |
89 | if (args.testCaseName) { |
90 | var testCases = getAllTestCases(); | |
0c393397 | 91 | name = args.testCaseName; |
357f7a8a RK |
92 | for (var idx in testCases) { |
93 | var entry = testCases[idx]; | |
94 | if (entry.name == args.testCaseName) { | |
95 | var prototype = entry.testCase; | |
96 | tc = new entry.testCase(); | |
97 | break; | |
98 | } | |
99 | } | |
ef13835b | 100 | } else if (args.testCase) { // The class name of the test. |
0c393397 | 101 | name = args.testCase; |
6788e30b | 102 | eval("tc = new " + args.testCase + "()"); |
357f7a8a | 103 | } |
ef13835b | 104 | |
5cfed8c5 | 105 | var results = null; |
ef13835b | 106 | // If the test class is defined. |
357f7a8a | 107 | if (tc != null) { |
ef13835b RK |
108 | if (args.command == "runAllTests") { |
109 | console.log("Running all tests for " + args.testCase); | |
5cfed8c5 RK |
110 | results = tc.runAllTests(); |
111 | } else if (args.command == "runTest") { | |
ef13835b | 112 | console.log("Running test " + args.testCase + "." + args.test); |
5cfed8c5 | 113 | results = tc.runTest(args.test); |
ef13835b RK |
114 | } |
115 | } else { | |
116 | if (args.command == "runAllTests") { | |
117 | console.log("Running all tests for all test cases"); | |
118 | var testCases = getAllTestCases(); | |
5cfed8c5 | 119 | results = {}; |
ef13835b RK |
120 | for (var idx in testCases) { |
121 | var entry = testCases[idx]; | |
122 | var prototype = entry.testCase; | |
123 | tc = new entry.testCase(); | |
124 | results[entry.name] = tc.runAllTests(); | |
6788e30b RK |
125 | } |
126 | } | |
127 | } | |
5cfed8c5 | 128 | resultsDiv = createResultsDiv(); |
b43b50fe RK |
129 | var summary = { failed: 0, passed: 0 }; |
130 | postResults(results, summary); | |
5cfed8c5 | 131 | resultsDiv.appendChild(document.createElement("hr")); |
0bdbfaf3 | 132 | document.getElementById('summary').innerHTML = "(" + summary.failed + " failed, " + summary.passed + " passed)"; |
6788e30b | 133 | } |
da11a9a7 | 134 | |
5cfed8c5 RK |
135 | function createResultsDiv() { |
136 | var body = document.getElementsByTagName("body")[0]; | |
137 | div = document.createElement("div"); | |
138 | div.id='results'; | |
825a47fc | 139 | div.innerHTML = "Test results: <span id='summary'></span> <a href='#' id='passed'>passed</a> <a href='#' id='failed'>failed</a> <a href='#' id='all'>all</a><br/>"; |
5cfed8c5 RK |
140 | body.insertBefore(div, body.firstChild); |
141 | ||
142 | var setByClassName = function(name, displayStyle) { | |
143 | var elements = div.getElementsByClassName(name); | |
144 | for (var i = 0; i < elements.length; i++) { | |
145 | elements[i].style.display = displayStyle; | |
ef13835b | 146 | } |
ef13835b | 147 | } |
da11a9a7 | 148 | |
5cfed8c5 RK |
149 | var passedAnchor = document.getElementById('passed'); |
150 | var failedAnchor = document.getElementById('failed'); | |
151 | var allAnchor = document.getElementById('all'); | |
152 | passedAnchor.onclick = function() { | |
153 | setByClassName('fail', 'none'); | |
154 | setByClassName('pass', 'block'); | |
155 | ||
156 | passedAnchor.setAttribute("class", 'activeAnchor'); | |
157 | failedAnchor.setAttribute("class", ''); | |
158 | }; | |
159 | failedAnchor.onclick = function() { | |
160 | setByClassName('fail', 'block'); | |
161 | setByClassName('pass', 'none'); | |
162 | passedAnchor.setAttribute("class", ''); | |
163 | failedAnchor.setAttribute("class", 'activeAnchor'); | |
164 | }; | |
165 | allAnchor.onclick = function() { | |
166 | setByClassName('fail', 'block'); | |
167 | setByClassName('pass', 'block'); | |
168 | passedAnchor.setAttribute("class", ''); | |
169 | failedAnchor.setAttribute("class", ''); | |
170 | }; | |
171 | return div; | |
172 | } | |
da11a9a7 | 173 | |
b43b50fe | 174 | function postResults(results, summary, title) { |
da11a9a7 | 175 | if (typeof(results) == "boolean") { |
ef13835b | 176 | var elem = document.createElement("div"); |
5cfed8c5 RK |
177 | elem.setAttribute("class", results ? 'pass' : 'fail'); |
178 | ||
179 | var prefix = title ? (title + ": ") : ""; | |
180 | elem.innerHTML = prefix + '<span class=\'outcome\'>' + (results ? 'pass' : 'fail') + '</span>'; | |
181 | resultsDiv.appendChild(elem); | |
b43b50fe RK |
182 | if (results) { |
183 | summary.passed++; | |
184 | } else { | |
185 | summary.failed++; | |
186 | } | |
da11a9a7 | 187 | } else { // hash |
825a47fc | 188 | var failed = 0; |
da11a9a7 RK |
189 | var html = ""; |
190 | for (var key in results) { | |
191 | if (results.hasOwnProperty(key)) { | |
ef13835b RK |
192 | var elem = results[key]; |
193 | if (typeof(elem) == "boolean" && title) { | |
b43b50fe | 194 | postResults(results[key], summary, title + "." + key); |
ef13835b | 195 | } else { |
b43b50fe | 196 | postResults(results[key], summary, key); |
ef13835b | 197 | } |
da11a9a7 RK |
198 | } |
199 | } | |
da11a9a7 | 200 | } |
da11a9a7 | 201 | } |
5cfed8c5 | 202 | |
6788e30b | 203 | </script> |
644eff8b RK |
204 | </head> |
205 | <body> | |
206 | <div id='graph'></div> | |
33933283 | 207 | <div id="selector"></div> |
3914c8e1 | 208 | <p>This file is really nothing more than all the tests coalesced into a single |
33933283 RK |
209 | HTML file. To run a test, use the selector above, or |
210 | open a Javascript console and execute, for instance,</p> | |
3914c8e1 | 211 | <code>testDrawSimpleRangePlusOne()</code> |
6788e30b RK |
212 | |
213 | <p>Alternatively you can use query args: <ul> | |
33933283 RK |
214 | <li>testCase - for the name of the test case prototype |
215 | <li>testCaseName - for the name of the test case | |
6788e30b RK |
216 | <li>test - for the name of the test (use command=runTest) |
217 | <li>command - either runTest or runAllTests. | |
218 | </ul> | |
219 | Example: <code>local.html?testCase=ScrollingDivTestCase&test=testNestedDiv_Scrolled&command=runTest</code> | |
357f7a8a | 220 | <p/> |
644eff8b | 221 | </body> |
6788e30b RK |
222 | <script> |
223 | processVariables(); | |
3914c8e1 | 224 | addGlobalTestSymbols(); |
357f7a8a | 225 | |
357f7a8a | 226 | var selector = document.getElementById("selector"); |
0c393397 | 227 | |
357f7a8a | 228 | if (selector != null) { // running a test |
da11a9a7 RK |
229 | var createAttached = function(name, parent) { |
230 | var elem = document.createElement(name); | |
231 | parent.appendChild(elem); | |
232 | return elem; | |
233 | } | |
234 | ||
357f7a8a RK |
235 | var description = createAttached("div", selector); |
236 | var list = createAttached("ul", selector); | |
237 | var parent = list.parentElement; | |
da11a9a7 | 238 | var createLink = function(parent, text, url) { |
5cfed8c5 RK |
239 | var li = createAttached("li", parent); |
240 | var a = createAttached("a", li); | |
0bdbfaf3 | 241 | a.innerHTML = text; |
5cfed8c5 | 242 | a.href = url; |
da11a9a7 | 243 | } |
357f7a8a RK |
244 | if (tc == null) { |
245 | description.innerHTML = "Test cases:"; | |
246 | var testCases = getAllTestCases(); | |
ef13835b | 247 | createLink(list, "(run all tests)", document.URL + "?command=runAllTests"); |
357f7a8a | 248 | for (var idx in testCases) { |
da11a9a7 RK |
249 | var entryName = testCases[idx].name; |
250 | createLink(list, entryName, document.URL + "?testCaseName=" + entryName); | |
357f7a8a RK |
251 | } |
252 | } else { | |
253 | description.innerHTML = "Tests for " + name; | |
254 | var names = tc.getTestNames(); | |
da11a9a7 | 255 | createLink(list, "Run All Tests", document.URL + "&command=runAllTests"); |
357f7a8a RK |
256 | for (var idx in names) { |
257 | var name = names[idx]; | |
da11a9a7 | 258 | createLink(list, name, document.URL + "&test=" + name + "&command=runTest"); |
357f7a8a RK |
259 | } |
260 | } | |
261 | } | |
6788e30b | 262 | </script> |
644eff8b | 263 | </html> |