reverse_multi_bundle.js 1.52 KB
/**
 * To be able to lazy load bundles with script loaders the loaded bundles
 * must have access to modules exposed by previous bundles.
 *
 * In effect this is the same as adding the bundles in reverse order
 **/

var browserify = require('../');
var vm = require('vm');
var test = require('tap').test;

test('reverse multi bundle', function (t) {
    t.plan(5);

    // Main app bundle has the main app code and the shared library code
    var app = browserify([__dirname + '/reverse_multi_bundle/app.js'])
        .external(__dirname + '/reverse_multi_bundle/lazy.js')
        .require(__dirname + '/reverse_multi_bundle/shared.js', { expose: true })
        .require(__dirname + '/reverse_multi_bundle/arbitrary.js', {expose: 'not/real'});

    // Lazily loaded bundle has only its own code even it uses code from the
    // shared library.
    var lazy = browserify({
            filter: function (id) {
                return id !== 'not/real';
            }
        })
        .require(__dirname + '/reverse_multi_bundle/lazy.js', { expose: true })
        .external(__dirname + '/reverse_multi_bundle/shared.js')
        .external('not/real');


    app.bundle(function (err, appSrc) {
        if (err) throw err;
        lazy.bundle(function(err, lazySrc) {
            if (err) throw err;

            var src = appSrc + ';' + lazySrc;
            var c = {
                setTimeout: setTimeout,
                clearTimeout: clearTimeout,
                t: t
            };
            vm.runInNewContext(src, c);
        });
    });
});