casper.notebook_test(function () { // Note, \033 is the octal notation of \u001b var input = [ "\033[0m[\033[0minfo\033[0m] \033[0mtext\033[0m", "\033[0m[\033[33mwarn\033[0m] \033[0m\tmore text\033[0m", "\033[0m[\033[33mwarn\033[0m] \033[0m https://some/url/to/a/file.ext\033[0m", "\033[0m[\033[31merror\033[0m] \033[0m\033[0m", "\033[0m[\033[31merror\033[0m] \033[0m\teven more text\033[0m", "\u001b[?25hBuilding wheels for collected packages: scipy", "\x1b[38;5;28;01mtry\x1b[39;00m", "\033[0m[\033[31merror\033[0m] \033[0m\t\tand more more text\033[0m", "normal\x1b[43myellowbg\x1b[35mmagentafg\x1b[1mbold\x1b[49mdefaultbg\x1b[39mdefaultfg\x1b[22mnormal", ].join("\n"); var output = [ "[info] text", '[warn] \tmore text', '[warn] https://some/url/to/a/file.ext', '[error] ', '[error] \teven more text', "Building wheels for collected packages: scipy", 'try', '[error] \t\tand more more text', 'normalyellowbgmagentafgbolddefaultbgdefaultfgnormal', ].join("\n"); var result = this.evaluate(function (input) { return IPython.utils.fixConsole(input); }, input); this.test.assertEquals(result, output, "IPython.utils.fixConsole() handles [0m correctly"); this.thenEvaluate(function() { define('nbextensions/a', [], function() { window.a = true; }); define('nbextensions/c', [], function() { window.c = true; }); require(['base/js/utils'], function(utils) { utils.load_extensions('a', 'b', 'c'); }); }).then(function() { this.waitFor(function() { return this.evaluate(function() { return window.a; }); }); this.waitFor(function() { return this.evaluate(function() { return window.a; }); }); }); });