Support function() returning other data types.
[dygraphs.git] / auto_tests / misc / local.html
1 <!-- A local source file that allows dygraph developers to test locally. -->
2 <html>
3 <head>
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]-->
9 <script type="text/javascript" src="../../dygraph-dev.js"></script>
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>
17 <script type="text/javascript" src="../tests/DygraphOps.js"></script>
18 <script type="text/javascript" src="../tests/sanity.js"></script>
19 <script type="text/javascript" src="../tests/simple_drawing.js"></script>
20 <script type="text/javascript" src="../tests/range_tests.js"></script>
21 <script type="text/javascript" src="../tests/axis_labels.js"></script>
22 <script type="text/javascript" src="../tests/multi_csv.js"></script>
23 <script type="text/javascript" src="../tests/to_dom_coords.js"></script>
24 <script type="text/javascript" src="../tests/interaction_model.js"></script>
25 <!--
26 <script type="text/javascript" src="../tests/tickers.js"></script>
27 -->
28 <script type="text/javascript" src="../tests/scrolling_div.js"></script>
29 <script type="text/javascript" src="../tests/custom_bars.js"></script>
30 <script type="text/javascript" src="../tests/css.js"></script>
31 <script type="text/javascript" src="../tests/selection.js"></script>
32 <script type="text/javascript" src="../tests/rolling_average.js"></script>
33 <script type="text/javascript" src="../tests/error_bars.js"></script>
34 <script type="text/javascript" src="../tests/annotations.js"></script>
35 <script type="text/javascript" src="../tests/scientific_notation.js"></script>
36 <script type="text/javascript" src="../tests/pathological_cases.js"></script>
37 <script type="text/javascript" src="../tests/date_formats.js"></script>
38 <script type="text/javascript" src="../tests/formats.js"></script>
39 <script type="text/javascript" src="../tests/update_options.js"></script>
40 <script type="text/javascript" src="../tests/utils_test.js"></script>
41 <script type="text/javascript" src="../tests/multiple_axes.js"></script>
42
43
44 <script type="text/javascript">
45 var tc = null;
46 var name = null;
47 function processVariables() {
48 var splitVariables = function() { // http://www.idealog.us/2006/06/javascript_to_p.html
49 var query = window.location.search.substring(1);
50 var args = {};
51 var vars = query.split("&");
52 for (var i = 0;i < vars.length; i++) {
53 var pair = vars[i].split("=");
54 args[pair[0]] = pair[1];
55 }
56 return args;
57 }
58
59 var args = splitVariables();
60 var test = args.test;
61 var command = args.command;
62
63 if (args.testCaseName) {
64 var testCases = getAllTestCases();
65 name = args.testCaseName;
66 for (var idx in testCases) {
67 var entry = testCases[idx];
68 if (entry.name == args.testCaseName) {
69 var prototype = entry.testCase;
70 tc = new entry.testCase();
71 break;
72 }
73 }
74 } else if (args.testCase) {
75 name = args.testCase;
76 eval("tc = new " + args.testCase + "()");
77 }
78 if (tc != null) {
79 if (args.command) {
80 if (args.command == "runAllTests") {
81 console.log("Running all tests for " + args.testCase);
82 postResults(tc.runAllTests());
83 }
84 if (args.command == "runTest") {
85 console.log("Running test " + args.testCase + "." + args.test);
86 postResults(tc.runTest(args.test));
87 }
88 }
89 }
90 }
91
92 function postResults(results) {
93 var body = document.getElementsByTagName("body")[0];
94 var div = document.createElement("div");
95 body.insertBefore(div, body.firstChild);
96
97 var resultToHtml = function(result) {
98 return result ?
99 "<span style='color:green;'>pass</span>" :
100 "<span style='color:red;'>fail</span>";
101 }
102
103 if (typeof(results) == "boolean") {
104 div.innerHTML = "Test results: " + resultToHtml(results);
105 } else { // hash
106 var html = "";
107 for (var key in results) {
108 if (results.hasOwnProperty(key)) {
109 html = html + key + ": " + resultToHtml(results[key]) + "<br/>";
110 }
111 }
112 div.innerHTML = "Test results:<br/>" + html;
113 }
114 div.appendChild(document.createElement("hr"));
115 }
116 </script>
117 </head>
118 <body>
119 <div id='graph'></div>
120 <div id="selector"></div>
121 <p>This file is really nothing more than all the tests coalesced into a single
122 HTML file. To run a test, use the selector above, or
123 open a Javascript console and execute, for instance,</p>
124 <code>testDrawSimpleRangePlusOne()</code>
125
126 <p>Alternatively you can use query args: <ul>
127 <li>testCase - for the name of the test case prototype
128 <li>testCaseName - for the name of the test case
129 <li>test - for the name of the test (use command=runTest)
130 <li>command - either runTest or runAllTests.
131 </ul>
132 Example: <code>local.html?testCase=ScrollingDivTestCase&test=testNestedDiv_Scrolled&command=runTest</code>
133 <p/>
134 </body>
135 <script>
136 processVariables();
137 addGlobalTestSymbols();
138
139 var selector = document.getElementById("selector");
140
141 if (selector != null) { // running a test
142 var createAttached = function(name, parent) {
143 var elem = document.createElement(name);
144 parent.appendChild(elem);
145 return elem;
146 }
147
148 var description = createAttached("div", selector);
149 var list = createAttached("ul", selector);
150 var parent = list.parentElement;
151 var createLink = function(parent, text, url) {
152 var li = createAttached("li", parent);
153 var a = createAttached("a", li);
154 a.innerText = text;
155 a.href = url;
156 }
157 if (tc == null) {
158 description.innerHTML = "Test cases:";
159 var testCases = getAllTestCases();
160 for (var idx in testCases) {
161 var entryName = testCases[idx].name;
162 createLink(list, entryName, document.URL + "?testCaseName=" + entryName);
163 }
164 } else {
165 description.innerHTML = "Tests for " + name;
166 var names = tc.getTestNames();
167 createLink(list, "Run All Tests", document.URL + "&command=runAllTests");
168 for (var idx in names) {
169 var name = names[idx];
170 createLink(list, name, document.URL + "&test=" + name + "&command=runTest");
171 }
172 }
173 }
174 </script>
175 </html>