mirror of
https://github.com/bringout/oca-ocb-core.git
synced 2026-04-19 23:11:59 +02:00
vanilla 17.0
This commit is contained in:
parent
d72e748793
commit
a9bcec8e91
1986 changed files with 1613876 additions and 568976 deletions
|
|
@ -0,0 +1,64 @@
|
|||
/** @odoo-module **/
|
||||
|
||||
/**
|
||||
* @param {string} folder folder that can only import from `allowedFolders`
|
||||
* @param {string[]} allowedFolders folders from which `folder` can import
|
||||
* @returns {{[key: string]: string[]}} an object where the keys are modules and
|
||||
* the values are an array of imports that the module is not allowed to import
|
||||
*/
|
||||
function invalidImportsFrom(folder, allowedFolders) {
|
||||
// modules within a folder can always depend on one another
|
||||
allowedFolders.push(folder);
|
||||
const modulesToCheck = Array.from(odoo.loader.modules.keys()).filter((module) =>
|
||||
module.startsWith(`@web/${folder}/`)
|
||||
);
|
||||
const invalidDeps = {};
|
||||
for (const module of modulesToCheck) {
|
||||
const invalid = odoo.loader.factories.get(module).deps.filter((dep) => {
|
||||
// owl and @web/session are allowed everywhere
|
||||
if (dep === "@odoo/owl" || dep === "@web/session") {
|
||||
return false;
|
||||
}
|
||||
return !allowedFolders.some((allowed) => dep.startsWith(`@web/${allowed}/`));
|
||||
});
|
||||
if (invalid.length) {
|
||||
invalidDeps[module] = invalid;
|
||||
}
|
||||
}
|
||||
return invalidDeps;
|
||||
}
|
||||
|
||||
QUnit.module("module dependencies", {}, () => {
|
||||
QUnit.test("modules only import from allowed folders", (assert) => {
|
||||
// Using deepEqual with {} in this test to get a good diff view when failing
|
||||
assert.deepEqual(
|
||||
invalidImportsFrom("core", []),
|
||||
// FIXME: this dependency should not exist. Temporarily whitelist it so we don't add more, and remove ASAP
|
||||
{ "@web/core/utils/hooks": ["@web/env"] },
|
||||
"Core modules don't depend on any other folder"
|
||||
);
|
||||
assert.deepEqual(
|
||||
invalidImportsFrom("search", ["core"]),
|
||||
// FIXME: this dependency should not exist. Temporarily whitelist it so we don't add more, and remove ASAP
|
||||
{ "@web/search/with_search/with_search": ["@web/webclient/actions/action_hook"] },
|
||||
"Search modules only depend on core"
|
||||
);
|
||||
assert.deepEqual(
|
||||
invalidImportsFrom("model", ["core", "search"]),
|
||||
// FIXME: this dependency should not exist. Temporarily whitelist it so we don't add more, and remove ASAP
|
||||
{ "@web/model/model": ["@web/views/view_hook"] },
|
||||
"Model modules only depend on core and search"
|
||||
);
|
||||
assert.deepEqual(
|
||||
invalidImportsFrom("views", ["core", "search", "model"]),
|
||||
// FIXME: these dependencies should not exist. Temporarily whitelist them so we don't add more, and remove ASAP
|
||||
{
|
||||
"@web/views/fields/many2one/many2one_field": [
|
||||
"@web/webclient/barcode/barcode_scanner",
|
||||
],
|
||||
"@web/views/view_hook": ["@web/webclient/actions/action_hook"],
|
||||
},
|
||||
"View modules only depend on core, search and model"
|
||||
);
|
||||
});
|
||||
});
|
||||
Loading…
Add table
Add a link
Reference in a new issue