viewport.js 2.18 KB
/*eslint strict:0*/
var utils = require('utils');

casper.test.begin('viewport() tests', 3, function(test) {
    casper.start();
    casper.viewport(1337, 999);
    test.assertEquals(casper.page.viewportSize.width, 1337,
        'Casper.viewport() can change the width of page viewport');
    test.assertEquals(casper.page.viewportSize.height, 999,
        'Casper.viewport() can change the height of page viewport');
    test.assertRaises(casper.viewport, ['a', 'b'],
        'Casper.viewport() validates viewport size data');
    test.done();
});

casper.test.begin('viewport() asynchronous tests', 4, function(test) {
    var screenshotData;

    casper.start('tests/site/index.html').viewport(800, 600, function() {
        this.setContent(utils.format('<img src="data:image/png;base64,%s">',
                                     this.captureBase64('png',{
                                        top: 0,
                                        left: 0,
                                        width: 800,
                                        height: 600
                            })));
    });

    casper.then(function() {
        var imgInfo = this.getElementInfo('img');
        // sometimes, setting viewport could take more time in slimerjs/gecko
        // and the image is not still ready: :-/
        
        if (!test.skipIfEngine(2, {
          name: 'slimerjs',
          version : { max: '1.9.0'},
          message: 'Casper.viewport() change test'
        })) {
            test.assertEquals(imgInfo.width, 800, 'Casper.viewport() changes width asynchronously');
            test.assertEquals(imgInfo.height, 600, 'Casper.viewport() changes height asynchronously');
        }
    });

    casper.thenOpen('tests/site/popup.html',function() {
        casper.waitForPopup("index.html", function() {
            casper.withPopup('index.html', function() {
                test.assertEquals(casper.page.viewportSize.width, 800, 'Casper.viewport() popup changes width asynchronously');
                test.assertEquals(casper.page.viewportSize.height, 600, 'Casper.viewport() popup changes height asynchronously');
            });
        });
    });
    
    casper.run(function() {
        test.done();
    });
});