mirror of
https://github.com/status-im/metro.git
synced 2025-01-22 00:50:52 +00:00
[react-packager] Cache in which bundle is each module
Summary: Not that at the moment a module can be present in multiple bundles, so the new API will return only one of them. In the near future we'll impose the invariant that a module can only be present in a single bundle so this API will return the exact bundle in which it is.
This commit is contained in:
parent
c3be08e66b
commit
fec5d8d4d4
@ -146,5 +146,42 @@ describe('BundlesLayout', () => {
|
||||
])
|
||||
);
|
||||
});
|
||||
|
||||
pit('separate cache in which bundle is each dependency', () => {
|
||||
DependencyResolver.prototype.getDependencies.mockImpl((path) => {
|
||||
switch (path) {
|
||||
case '/root/index.js':
|
||||
return Promise.resolve({
|
||||
dependencies: [dep('/root/index.js'), dep('/root/a.js')],
|
||||
asyncDependencies: [['/root/b.js']],
|
||||
});
|
||||
case '/root/a.js':
|
||||
return Promise.resolve({
|
||||
dependencies: [dep('/root/a.js')],
|
||||
asyncDependencies: [],
|
||||
});
|
||||
case '/root/b.js':
|
||||
return Promise.resolve({
|
||||
dependencies: [dep('/root/b.js')],
|
||||
asyncDependencies: [['/root/c.js']],
|
||||
});
|
||||
case '/root/c.js':
|
||||
return Promise.resolve({
|
||||
dependencies: [dep('/root/c.js')],
|
||||
asyncDependencies: [],
|
||||
});
|
||||
default:
|
||||
throw 'Undefined path: ' + path;
|
||||
}
|
||||
});
|
||||
|
||||
var layout = newBundlesLayout();
|
||||
return layout.generateLayout(['/root/index.js']).then(() => {
|
||||
expect(layout.getBundleIDForModule('/root/index.js')).toBe(0);
|
||||
expect(layout.getBundleIDForModule('/root/a.js')).toBe(0);
|
||||
expect(layout.getBundleIDForModule('/root/b.js')).toBe(1);
|
||||
expect(layout.getBundleIDForModule('/root/c.js')).toBe(2);
|
||||
});
|
||||
});
|
||||
});
|
||||
});
|
||||
|
11
react-packager/src/BundlesLayout/index.js
vendored
11
react-packager/src/BundlesLayout/index.js
vendored
@ -26,6 +26,8 @@ class BundlesLayout {
|
||||
constructor(options) {
|
||||
const opts = validateOpts(options);
|
||||
this._resolver = opts.dependencyResolver;
|
||||
|
||||
this._moduleToBundle = Object.create(null);
|
||||
}
|
||||
|
||||
generateLayout(entryPaths, isDev) {
|
||||
@ -44,9 +46,10 @@ class BundlesLayout {
|
||||
.then(modulesDeps => {
|
||||
let syncDependencies = Object.create(null);
|
||||
modulesDeps.forEach(moduleDeps => {
|
||||
moduleDeps.dependencies.forEach(dep =>
|
||||
moduleDeps.dependencies.forEach(dep => {
|
||||
syncDependencies[dep.path] = dep
|
||||
);
|
||||
this._moduleToBundle[dep.path] = bundles.length;
|
||||
});
|
||||
pending = pending.concat(moduleDeps.asyncDependencies);
|
||||
});
|
||||
|
||||
@ -60,6 +63,10 @@ class BundlesLayout {
|
||||
},
|
||||
);
|
||||
}
|
||||
|
||||
getBundleIDForModule(path) {
|
||||
return this._moduleToBundle[path];
|
||||
}
|
||||
}
|
||||
|
||||
// Runs the body Promise meanwhile the condition callback is satisfied.
|
||||
|
Loading…
x
Reference in New Issue
Block a user