//
// Test display isolation
// An object whose metadata contains an "isolated" tag must be isolated
// from the rest of the document. In the case of inline SVGs, this means
// that multiple SVGs have different scopes. This test checks that there
// are no CSS leaks between two isolated SVGs.
//

casper.notebook_test(function () {
    this.evaluate(function () {
        var cell = IPython.notebook.get_cell(0);
        cell.set_text( "from IPython.core.display import SVG, display_svg\n" +
                       "s1 = '''<svg width='1cm' height='1cm' viewBox='0 0 1000 500'>" +
                       "<defs><style>rect {fill:red;}; </style></defs>" +
                       "<rect id='r1' x='200' y='100' width='600' height='300' /></svg>" +
                       "'''\n" +
                       "s2 = '''<svg width='1cm' height='1cm' viewBox='0 0 1000 500'>" +
                       "<rect id='r2' x='200' y='100' width='600' height='300' /></svg>" +
                       "'''\n" +
                       "display_svg(SVG(s1), metadata=dict(isolated=True))\n" +
                       "display_svg(SVG(s2), metadata=dict(isolated=True))\n"
            );
        cell.execute();
    });

    this.then(function() {
        var fname=this.test.currentTestFile.split('/').pop().toLowerCase();
        this.echo(fname);
        this.echo(this.currentUrl);
        this.evaluate(function (n) {
            IPython.notebook.rename(n);
            IPython.notebook.save_notebook();
        }, {n : fname});
        this.echo(this.currentUrl);
    });

    this.then(function() {
    
        url = this.evaluate(function() {
            IPython.notebook.rename("foo");
            return document.location.href;
        });
        this.echo("renamed" + url);
        this.echo(this.currentUrl);
    });

    this.wait_for_output(0);

    this.then(function () {
        var colors = this.evaluate(function () {
            var colors = [];
            var ifr = __utils__.findAll("iframe");
            var svg1 = ifr[0].contentWindow.document.getElementById('r1');
            colors[0] = window.getComputedStyle(svg1).fill;
            var svg2 = ifr[1].contentWindow.document.getElementById('r2');
            colors[1] = window.getComputedStyle(svg2).fill;
            return colors;
        });
        this.assert_colors_equal('#ff0000', colors && colors[0], 'display_svg() First svg should be red');
        this.assert_colors_equal('#000000', colors && colors[1], 'display_svg() Second svg should be black');
    });

    // now ensure that we can pass the same metadata dict to plain old display()
    this.thenEvaluate(function () {
        var cell = IPython.notebook.get_cell(0);
        cell.clear_output();
        cell.set_text( "from IPython.display import display\n" +
                       "display(SVG(s1), metadata=dict(isolated=True))\n" +
                       "display(SVG(s2), metadata=dict(isolated=True))\n"
            );
        cell.execute();
    });

    this.wait_for_output(0);

    // same test as original
    this.then(function () {
        var colors = this.evaluate(function () {
            var colors = [];
            var ifr = __utils__.findAll("iframe");
            var svg1 = ifr[0].contentWindow.document.getElementById('r1');
            colors[0] = window.getComputedStyle(svg1).fill;
            var svg2 = ifr[1].contentWindow.document.getElementById('r2');
            colors[1] = window.getComputedStyle(svg2).fill;
            return colors;
        });
        this.assert_colors_equal('#ff0000', colors && colors[0], 'display() First svg should be red');
        this.assert_colors_equal('#000000', colors && colors[1], 'display() Second svg should be black');
    });
});