Skip to content
This repository has been archived by the owner on Aug 1, 2024. It is now read-only.

Commit

Permalink
RELNOTES: Disallow adding an extra edge from a module if it already h…
Browse files Browse the repository at this point in the history
…as loaded.

PiperOrigin-RevId: 411824384
Change-Id: I23ccd6416edacf2b92390af0e825998073e2892c
  • Loading branch information
Closure Team authored and copybara-github committed Nov 23, 2021
1 parent 617847e commit a43ba1d
Show file tree
Hide file tree
Showing 2 changed files with 30 additions and 1 deletion.
11 changes: 10 additions & 1 deletion closure/goog/module/modulemanager.js
Original file line number Diff line number Diff line change
Expand Up @@ -378,10 +378,19 @@ goog.module.ModuleManager.prototype.getModuleInfo = function(id) {
};


/** @override */
/**
* @param {string} fromModule
* @param {string} toModule
* @override
*/
goog.module.ModuleManager.prototype.addExtraEdge = function(
fromModule, toModule) {
'use strict';
if (this.getModuleInfo(fromModule).isLoaded()) {
throw new Error(
`The extra edge ${fromModule} -> ${toModule} cannot be added since ${
fromModule} has already been loaded.`);
}
if (!this.extraEdges_[fromModule]) {
this.extraEdges_[fromModule] = {};
}
Expand Down
20 changes: 20 additions & 0 deletions closure/goog/module/modulemanager_test.js
Original file line number Diff line number Diff line change
Expand Up @@ -1024,6 +1024,26 @@ testSuite({
assertThrows(() => mm.load('modA'));
},

testAddExtraEdge_fromModuleAlreadyLoaded() {
const mm = getModuleManager({'modA': [], 'modC': []});

const loaderCalls = [];
mm.setLoader(createModuleLoaderWithExtraEdgesSupport(loaderCalls));

// Set modA as loaded.
mm.beforeLoadModuleCode('modA');
mm.setLoaded('modA');

// Assert error is thrown since modA has already loaded.
const e = assertThrows(() => mm.addExtraEdge('modA', 'modB'));
assertEquals(
'The extra edge modA -> modB cannot be added since modA has already been loaded.',
e.message);

// Assert no error is thrown since modC has not been loaded yet.
assertNotThrows(() => mm.addExtraEdge('modC', 'modB'));
},

testRemoveExtraEdge() {
const mm =
getModuleManager({'modA': [], 'modB': [], 'modC': [], 'modD': []});
Expand Down

0 comments on commit a43ba1d

Please sign in to comment.