Newer
Older
pixi.js / packages / app / test / index.js
@Matt Karl Matt Karl on 10 Jun 2018 3 KB Application plugin structure (#4933)
const { Application } = require('../');
const { autoDetectRenderer } = require('@pixi/canvas-renderer');
const { Container } = require('@pixi/display');
const { skipHello } = require('@pixi/utils');

skipHello();

// Use fallback if no webgl
Application.prototype.createRenderer = autoDetectRenderer;

describe('PIXI.Application', function ()
{
    it('should generate application', function ()
    {
        expect(Application).to.be.a.function;
        const app = new Application();

        expect(app.stage).to.be.instanceof(Container);
        expect(app.renderer).to.be.ok;

        app.destroy();

        expect(app.stage).to.be.null;
        expect(app.renderer).to.be.null;
    });

    it('register a new plugin, then destroy it', function ()
    {
        const plugin = {
            init: sinon.spy(),
            destroy: sinon.spy(),
        };

        Application.registerPlugin(plugin);

        const app = new Application();

        app.destroy();

        expect(plugin.init).to.be.calledOnce;
        expect(plugin.destroy).to.be.calledOnce;

        Application._plugins.pop();
    });

    it('should remove canvas when destroyed', function ()
    {
        const app = new Application();
        const view = app.view;

        expect(view).to.be.instanceof(HTMLCanvasElement);
        document.body.appendChild(view);

        expect(document.body.contains(view)).to.be.true;
        app.destroy(true);
        expect(document.body.contains(view)).to.be.false;
    });

    describe('resizeTo', function ()
    {
        before(function ()
        {
            const div = document.createElement('div');

            div.style.width = '100px';
            div.style.height = '200px';
            document.body.appendChild(div);
            this.div = div;
        });

        after(function ()
        {
            this.div.parentNode.removeChild(this.div);
            this.div = null;
        });

        it('should assign resizeTo', function ()
        {
            const app = new Application({
                resizeTo: this.div,
            });

            expect(app.resizeTo).to.equal(this.div);
            expect(app.view.width).to.equal(100);
            expect(app.view.height).to.equal(200);
            app.destroy();
        });

        it('should resizeTo with resolution', function ()
        {
            const app = new Application({
                resolution: 2,
                resizeTo: this.div,
            });

            expect(app.view.width).to.equal(200);
            expect(app.view.height).to.equal(400);
            app.destroy();
        });

        it('should resizeTo with resolution and autoDensity', function ()
        {
            const app = new Application({
                resolution: 2,
                resizeTo: this.div,
                autoDensity: true,
            });

            expect(app.view.width).to.equal(200);
            expect(app.view.height).to.equal(400);
            expect(app.view.style.width).to.equal(this.div.style.width);
            expect(app.view.style.height).to.equal(this.div.style.height);
            app.destroy();
        });
    });
});