X-Git-Url: https://adrianiainlam.tk/git/?a=blobdiff_plain;f=auto_tests%2Ftests%2FUtil.js;h=3b8c1b8d64f6b2fa8ad3d0e83faedd605794f9d1;hb=94fff6f2a229e28095253d8a83854c8c44497a14;hp=3436c152ac4998d2168cf2e6c3109f7d2c21be63;hpb=89fdcedbda6906d90e15d84285c4f6c0b8d96d28;p=dygraphs.git diff --git a/auto_tests/tests/Util.js b/auto_tests/tests/Util.js index 3436c15..3b8c1b8 100644 --- a/auto_tests/tests/Util.js +++ b/auto_tests/tests/Util.js @@ -51,11 +51,16 @@ Util.getClassTexts = function(css_class, parent) { return texts; }; +// Convert   to a normal space +Util.nbspToSpace = function(str) { + var re = new RegExp(String.fromCharCode(160), 'g'); + return str.replace(re, ' '); +}; + Util.getLegend = function(parent) { parent = parent || document; var legend = parent.getElementsByClassName("dygraph-legend")[0]; - var re = new RegExp(String.fromCharCode(160), 'g'); - return legend.textContent.replace(re, ' '); + return Util.nbspToSpace(legend.textContent); }; /** @@ -63,9 +68,10 @@ Util.getLegend = function(parent) { */ Util.assertStyleOfChildren = function(selector, property, expectedValue) { assert.isTrue(selector.length > 0); - $.each(selector, function(idx, child) { - assert.isEqual(expectedValue, $(child).css(property)); - }); + for (var idx = 0; idx < selector.length; idx++) { + var child = selector[idx]; + assert.equal(expectedValue, window.getComputedStyle(child)[property]); + } }; @@ -141,3 +147,24 @@ Util.overrideXMLHttpRequest = function(data) { Util.formatDate = function(dateMillis) { return Dygraph.dateString_(dateMillis).slice(0, 10); // 10 == "YYYY/MM/DD".length }; + +/** + * Capture console.{log,warn,error} statements into obj. + * obj will look like {log:[], warn:[], error:[]} + * This returns a function which will restore the original console. + */ +Util.captureConsole = function(obj) { + obj.log = []; + obj.warn = []; + obj.error = []; + var orig = [console.log, console.warn, console.error]; + console.log = function(text) { obj.log.push(text); }; + console.warn = function(text) { obj.warn.push(text); }; + console.error = function(text) { obj.error.push(text); }; + + return function() { + console.log = orig[0]; + console.warn = orig[1]; + console.error = orig[2]; + }; +};