X-Git-Url: https://adrianiainlam.tk/git/?a=blobdiff_plain;ds=sidebyside;f=auto_tests%2Ftests%2Fdygraph-options-tests.js;h=094ebd6d5a69df46dea9710e50aa0a11e072b316;hb=b3cb0794c0513e0a4c9b31d11fbe8b65778fc02e;hp=792dcdbe3a6f0b6502cb8ab36c97d86729e4c1f2;hpb=335011fd4473f55aaaceb69726d15e0063373149;p=dygraphs.git diff --git a/auto_tests/tests/dygraph-options-tests.js b/auto_tests/tests/dygraph-options-tests.js index 792dcdb..094ebd6 100644 --- a/auto_tests/tests/dygraph-options-tests.js +++ b/auto_tests/tests/dygraph-options-tests.js @@ -35,7 +35,7 @@ DygraphOptionsTestCase.prototype.testGetSeriesNames = function() { * Ensures that even if logscale is set globally, it doesn't impact the * x axis. */ -DygraphOptionsTestCase.prototype.getLogscaleForX = function() { +DygraphOptionsTestCase.prototype.testGetLogscaleForX = function() { var opts = { width: 480, height: 320 @@ -47,10 +47,69 @@ DygraphOptionsTestCase.prototype.getLogscaleForX = function() { var graph = document.getElementById("graph"); var g = new Dygraph(graph, data, opts); - assertFalse(g.getOptionForAxis('logscale', 'x')); - assertFalse(g.getOptionForAxis('logscale', 'y')); + assertFalse(!!g.getOptionForAxis('logscale', 'x')); + assertFalse(!!g.getOptionForAxis('logscale', 'y')); g.updateOptions({ logscale : true }); - assertFalse(g.getOptionForAxis('logscale', 'x')); - assertTrue(g.getOptionForAxis('logscale', 'y')); + assertFalse(!!g.getOptionForAxis('logscale', 'x')); + assertTrue(!!g.getOptionForAxis('logscale', 'y')); +}; + +// Helper to gather all warnings emitted by Dygraph constructor. +// Removes everything after the first open parenthesis in each warning. +// Returns them in a (possibly empty) list. +var getWarnings = function(div, data, opts) { + var warnings = []; + var oldWarn = console.warn; + console.warn = function(message) { + warnings.push(message.replace(/ \(.*/, '')); + }; + new Dygraph(graph, data, opts); + console.warn = oldWarn; + return warnings; +}; + +DygraphOptionsTestCase.prototype.testLogWarningForNonexistentOption = function() { + if (typeof(Dygraph.OPTIONS_REFERENCE) === 'undefined') { + return; // this test won't pass in non-debug mode. + } + + var graph = document.getElementById("graph"); + var data = "X,Y,Y2,Y3\n" + + "1,-1,2,3"; + + var expectWarning = function(opts, badOptionName) { + DygraphOptions.resetWarnings_(); + var warnings = getWarnings(graph, data, opts); + assertEquals(['Unknown option ' + badOptionName], warnings); + }; + var expectNoWarning = function(opts) { + DygraphOptions.resetWarnings_(); + var warnings = getWarnings(graph, data, opts); + assertEquals([], warnings); + }; + + expectNoWarning({}); + expectWarning({nonExistentOption: true}, 'nonExistentOption'); + expectWarning({series: {Y: {nonExistentOption: true}}}, 'nonExistentOption'); + // expectWarning({Y: {nonExistentOption: true}}); + expectWarning({axes: {y: {anotherNonExistentOption: true}}}, 'anotherNonExistentOption'); + expectWarning({highlightSeriesOpts: {anotherNonExistentOption: true}}, 'anotherNonExistentOption'); + expectNoWarning({highlightSeriesOpts: {strokeWidth: 20}}); + expectNoWarning({strokeWidth: 20}); +}; + +DygraphOptionsTestCase.prototype.testOnlyLogsEachWarningOnce = function() { + if (typeof(Dygraph.OPTIONS_REFERENCE) === 'undefined') { + return; // this test won't pass in non-debug mode. + } + + var graph = document.getElementById("graph"); + var data = "X,Y,Y2,Y3\n" + + "1,-1,2,3"; + + var warnings1 = getWarnings(graph, data, {nonExistent: true}); + var warnings2 = getWarnings(graph, data, {nonExistent: true}); + assertEquals(['Unknown option nonExistent'], warnings1); + assertEquals([], warnings2); };