This run took 100 seconds.
$ date --- stdout --- Thu May 8 09:45:40 UTC 2025 --- end --- $ git clone file:///srv/git/mediawiki-extensions-MobileFrontend.git repo --depth=1 -b REL1_44 --- stderr --- Cloning into 'repo'... --- stdout --- --- end --- $ git config user.name libraryupgrader --- stdout --- --- end --- $ git config user.email tools.libraryupgrader@tools.wmflabs.org --- stdout --- --- end --- $ git submodule update --init --- stdout --- --- end --- $ grr init --- stdout --- Installed commit-msg hook. --- end --- $ git show-ref refs/heads/REL1_44 --- stdout --- f4853cfdaefaf078f0ead40cacdf67d249fba45f refs/heads/REL1_44 --- end --- $ /usr/bin/npm audit --json --- stdout --- { "auditReportVersion": 2, "vulnerabilities": { "cross-spawn": { "name": "cross-spawn", "severity": "high", "isDirect": false, "via": [ { "source": 1100562, "name": "cross-spawn", "dependency": "cross-spawn", "title": "Regular Expression Denial of Service (ReDoS) in cross-spawn", "url": "https://github.com/advisories/GHSA-3xgq-45jj-v275", "severity": "high", "cwe": [ "CWE-1333" ], "cvss": { "score": 7.5, "vectorString": "CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:N/I:N/A:H" }, "range": "<6.0.6" } ], "effects": [ "pre-commit" ], "range": "<6.0.6", "nodes": [ "node_modules/pre-commit/node_modules/cross-spawn" ], "fixAvailable": { "name": "pre-commit", "version": "1.0.10", "isSemVerMajor": true } }, "jsdom": { "name": "jsdom", "severity": "moderate", "isDirect": true, "via": [ "request", "tough-cookie" ], "effects": [], "range": "0.1.20 || 0.2.0 - 16.5.3", "nodes": [ "node_modules/jsdom" ], "fixAvailable": { "name": "jsdom", "version": "26.1.0", "isSemVerMajor": true } }, "less": { "name": "less", "severity": "moderate", "isDirect": true, "via": [ "request" ], "effects": [], "range": "1.4.0-b1 - 2.6.1 || 2.7.2 - 3.11.3", "nodes": [ "node_modules/less" ], "fixAvailable": { "name": "less", "version": "3.13.1", "isSemVerMajor": false } }, "pre-commit": { "name": "pre-commit", "severity": "high", "isDirect": true, "via": [ "cross-spawn" ], "effects": [], "range": ">=1.1.0", "nodes": [ "node_modules/pre-commit" ], "fixAvailable": { "name": "pre-commit", "version": "1.0.10", "isSemVerMajor": true } }, "request": { "name": "request", "severity": "moderate", "isDirect": false, "via": [ { "source": 1096727, "name": "request", "dependency": "request", "title": "Server-Side Request Forgery in Request", "url": "https://github.com/advisories/GHSA-p8p7-x288-28g6", "severity": "moderate", "cwe": [ "CWE-918" ], "cvss": { "score": 6.1, "vectorString": "CVSS:3.1/AV:N/AC:L/PR:N/UI:R/S:C/C:L/I:L/A:N" }, "range": "<=2.88.2" }, "tough-cookie" ], "effects": [ "jsdom", "less", "request-promise-core", "request-promise-native" ], "range": "*", "nodes": [ "node_modules/request" ], "fixAvailable": { "name": "jsdom", "version": "26.1.0", "isSemVerMajor": true } }, "request-promise-core": { "name": "request-promise-core", "severity": "moderate", "isDirect": false, "via": [ "request" ], "effects": [ "request-promise-native" ], "range": "*", "nodes": [ "node_modules/request-promise-core" ], "fixAvailable": true }, "request-promise-native": { "name": "request-promise-native", "severity": "moderate", "isDirect": false, "via": [ "request", "request-promise-core", "tough-cookie" ], "effects": [], "range": ">=1.0.0", "nodes": [ "node_modules/request-promise-native" ], "fixAvailable": true }, "tough-cookie": { "name": "tough-cookie", "severity": "moderate", "isDirect": false, "via": [ { "source": 1097682, "name": "tough-cookie", "dependency": "tough-cookie", "title": "tough-cookie Prototype Pollution vulnerability", "url": "https://github.com/advisories/GHSA-72xf-g2v4-qvf3", "severity": "moderate", "cwe": [ "CWE-1321" ], "cvss": { "score": 6.5, "vectorString": "CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:L/I:L/A:N" }, "range": "<4.1.3" } ], "effects": [ "jsdom", "request", "request-promise-native" ], "range": "<4.1.3", "nodes": [ "node_modules/tough-cookie" ], "fixAvailable": { "name": "jsdom", "version": "26.1.0", "isSemVerMajor": true } }, "webpack": { "name": "webpack", "severity": "moderate", "isDirect": true, "via": [ { "source": 1099351, "name": "webpack", "dependency": "webpack", "title": "Webpack's AutoPublicPathRuntimeModule has a DOM Clobbering Gadget that leads to XSS", "url": "https://github.com/advisories/GHSA-4vvj-4cpr-p986", "severity": "moderate", "cwe": [ "CWE-79" ], "cvss": { "score": 6.4, "vectorString": "CVSS:3.1/AV:N/AC:H/PR:L/UI:N/S:U/C:L/I:L/A:H" }, "range": ">=5.0.0-alpha.0 <5.94.0" } ], "effects": [], "range": "5.0.0-alpha.0 - 5.93.0", "nodes": [ "node_modules/webpack" ], "fixAvailable": { "name": "webpack", "version": "5.99.8", "isSemVerMajor": false } } }, "metadata": { "vulnerabilities": { "info": 0, "low": 0, "moderate": 7, "high": 2, "critical": 0, "total": 9 }, "dependencies": { "prod": 1, "dev": 945, "optional": 8, "peer": 14, "peerOptional": 0, "total": 945 } } } --- end --- $ /usr/bin/composer install --- stderr --- No composer.lock file present. Updating dependencies to latest instead of installing from lock file. See https://getcomposer.org/install for more information. Loading composer repositories with package information Updating dependencies Lock file operations: 38 installs, 0 updates, 0 removals - Locking composer/pcre (3.3.2) - Locking composer/semver (3.4.3) - Locking composer/spdx-licenses (1.5.8) - Locking composer/xdebug-handler (3.0.5) - Locking dealerdirect/phpcodesniffer-composer-installer (v1.0.0) - Locking doctrine/deprecations (1.1.5) - Locking felixfbecker/advanced-json-rpc (v3.2.1) - Locking mediawiki/mediawiki-codesniffer (v46.0.0) - Locking mediawiki/mediawiki-phan-config (0.15.0) - Locking mediawiki/minus-x (1.1.3) - Locking mediawiki/phan-taint-check-plugin (6.1.0) - Locking microsoft/tolerant-php-parser (v0.1.2) - Locking netresearch/jsonmapper (v4.5.0) - Locking phan/phan (5.4.5) - Locking php-parallel-lint/php-console-color (v1.0.1) - Locking php-parallel-lint/php-console-highlighter (v1.0.0) - Locking php-parallel-lint/php-parallel-lint (v1.4.0) - Locking phpcsstandards/phpcsextra (1.2.1) - Locking phpcsstandards/phpcsutils (1.0.12) - Locking phpdocumentor/reflection-common (2.2.0) - Locking phpdocumentor/reflection-docblock (5.6.2) - Locking phpdocumentor/type-resolver (1.10.0) - Locking phpstan/phpdoc-parser (2.1.0) - Locking psr/container (2.0.2) - Locking psr/log (3.0.2) - Locking sabre/event (5.1.7) - Locking squizlabs/php_codesniffer (3.11.3) - Locking symfony/console (v7.2.6) - Locking symfony/deprecation-contracts (v3.5.1) - Locking symfony/polyfill-ctype (v1.32.0) - Locking symfony/polyfill-intl-grapheme (v1.32.0) - Locking symfony/polyfill-intl-normalizer (v1.32.0) - Locking symfony/polyfill-mbstring (v1.32.0) - Locking symfony/polyfill-php80 (v1.32.0) - Locking symfony/service-contracts (v3.5.1) - Locking symfony/string (v7.2.6) - Locking tysonandre/var_representation_polyfill (0.1.3) - Locking webmozart/assert (1.11.0) Writing lock file Installing dependencies from lock file (including require-dev) Package operations: 38 installs, 0 updates, 0 removals 0 [>---------------------------] 0 [->--------------------------] - Installing squizlabs/php_codesniffer (3.11.3): Extracting archive - Installing dealerdirect/phpcodesniffer-composer-installer (v1.0.0): Extracting archive - Installing composer/pcre (3.3.2): Extracting archive - Installing symfony/polyfill-php80 (v1.32.0): Extracting archive - Installing phpcsstandards/phpcsutils (1.0.12): Extracting archive - Installing phpcsstandards/phpcsextra (1.2.1): Extracting archive - Installing symfony/polyfill-mbstring (v1.32.0): Extracting archive - Installing composer/spdx-licenses (1.5.8): Extracting archive - Installing composer/semver (3.4.3): Extracting archive - Installing mediawiki/mediawiki-codesniffer (v46.0.0): Extracting archive - Installing tysonandre/var_representation_polyfill (0.1.3): Extracting archive - Installing symfony/polyfill-intl-normalizer (v1.32.0): Extracting archive - Installing symfony/polyfill-intl-grapheme (v1.32.0): Extracting archive - Installing symfony/polyfill-ctype (v1.32.0): Extracting archive - Installing symfony/string (v7.2.6): Extracting archive - Installing symfony/deprecation-contracts (v3.5.1): Extracting archive - Installing psr/container (2.0.2): Extracting archive - Installing symfony/service-contracts (v3.5.1): Extracting archive - Installing symfony/console (v7.2.6): Extracting archive - Installing sabre/event (5.1.7): Extracting archive - Installing netresearch/jsonmapper (v4.5.0): Extracting archive - Installing microsoft/tolerant-php-parser (v0.1.2): Extracting archive - Installing webmozart/assert (1.11.0): Extracting archive - Installing phpstan/phpdoc-parser (2.1.0): Extracting archive - Installing phpdocumentor/reflection-common (2.2.0): Extracting archive - Installing doctrine/deprecations (1.1.5): Extracting archive - Installing phpdocumentor/type-resolver (1.10.0): Extracting archive - Installing phpdocumentor/reflection-docblock (5.6.2): Extracting archive - Installing felixfbecker/advanced-json-rpc (v3.2.1): Extracting archive - Installing psr/log (3.0.2): Extracting archive - Installing composer/xdebug-handler (3.0.5): Extracting archive - Installing phan/phan (5.4.5): Extracting archive - Installing mediawiki/phan-taint-check-plugin (6.1.0): Extracting archive - Installing mediawiki/mediawiki-phan-config (0.15.0): Extracting archive - Installing mediawiki/minus-x (1.1.3): Extracting archive - Installing php-parallel-lint/php-console-color (v1.0.1): Extracting archive - Installing php-parallel-lint/php-console-highlighter (v1.0.0): Extracting archive - Installing php-parallel-lint/php-parallel-lint (v1.4.0): Extracting archive 0/36 [>---------------------------] 0% 20/36 [===============>------------] 55% 33/36 [=========================>--] 91% 36/36 [============================] 100% 1 package suggestions were added by new dependencies, use `composer suggest` to see details. Generating autoload files 16 packages you are using are looking for funding. Use the `composer fund` command to find out more! --- stdout --- PHP CodeSniffer Config installed_paths set to ../../mediawiki/mediawiki-codesniffer,../../phpcsstandards/phpcsextra,../../phpcsstandards/phpcsutils --- end --- $ /usr/bin/npm audit --json --- stdout --- { "auditReportVersion": 2, "vulnerabilities": { "cross-spawn": { "name": "cross-spawn", "severity": "high", "isDirect": false, "via": [ { "source": 1100562, "name": "cross-spawn", "dependency": "cross-spawn", "title": "Regular Expression Denial of Service (ReDoS) in cross-spawn", "url": "https://github.com/advisories/GHSA-3xgq-45jj-v275", "severity": "high", "cwe": [ "CWE-1333" ], "cvss": { "score": 7.5, "vectorString": "CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:N/I:N/A:H" }, "range": "<6.0.6" } ], "effects": [ "pre-commit" ], "range": "<6.0.6", "nodes": [ "node_modules/pre-commit/node_modules/cross-spawn" ], "fixAvailable": { "name": "pre-commit", "version": "1.0.10", "isSemVerMajor": true } }, "jsdom": { "name": "jsdom", "severity": "moderate", "isDirect": true, "via": [ "request", "tough-cookie" ], "effects": [], "range": "0.1.20 || 0.2.0 - 16.5.3", "nodes": [ "node_modules/jsdom" ], "fixAvailable": { "name": "jsdom", "version": "26.1.0", "isSemVerMajor": true } }, "less": { "name": "less", "severity": "moderate", "isDirect": true, "via": [ "request" ], "effects": [], "range": "1.4.0-b1 - 2.6.1 || 2.7.2 - 3.11.3", "nodes": [ "node_modules/less" ], "fixAvailable": { "name": "less", "version": "3.13.1", "isSemVerMajor": false } }, "pre-commit": { "name": "pre-commit", "severity": "high", "isDirect": true, "via": [ "cross-spawn" ], "effects": [], "range": ">=1.1.0", "nodes": [ "node_modules/pre-commit" ], "fixAvailable": { "name": "pre-commit", "version": "1.0.10", "isSemVerMajor": true } }, "request": { "name": "request", "severity": "moderate", "isDirect": false, "via": [ { "source": 1096727, "name": "request", "dependency": "request", "title": "Server-Side Request Forgery in Request", "url": "https://github.com/advisories/GHSA-p8p7-x288-28g6", "severity": "moderate", "cwe": [ "CWE-918" ], "cvss": { "score": 6.1, "vectorString": "CVSS:3.1/AV:N/AC:L/PR:N/UI:R/S:C/C:L/I:L/A:N" }, "range": "<=2.88.2" }, "tough-cookie" ], "effects": [ "jsdom", "less", "request-promise-core", "request-promise-native" ], "range": "*", "nodes": [ "node_modules/request" ], "fixAvailable": { "name": "jsdom", "version": "26.1.0", "isSemVerMajor": true } }, "request-promise-core": { "name": "request-promise-core", "severity": "moderate", "isDirect": false, "via": [ "request" ], "effects": [ "request-promise-native" ], "range": "*", "nodes": [ "node_modules/request-promise-core" ], "fixAvailable": true }, "request-promise-native": { "name": "request-promise-native", "severity": "moderate", "isDirect": false, "via": [ "request", "request-promise-core", "tough-cookie" ], "effects": [], "range": ">=1.0.0", "nodes": [ "node_modules/request-promise-native" ], "fixAvailable": true }, "tough-cookie": { "name": "tough-cookie", "severity": "moderate", "isDirect": false, "via": [ { "source": 1097682, "name": "tough-cookie", "dependency": "tough-cookie", "title": "tough-cookie Prototype Pollution vulnerability", "url": "https://github.com/advisories/GHSA-72xf-g2v4-qvf3", "severity": "moderate", "cwe": [ "CWE-1321" ], "cvss": { "score": 6.5, "vectorString": "CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:L/I:L/A:N" }, "range": "<4.1.3" } ], "effects": [ "jsdom", "request", "request-promise-native" ], "range": "<4.1.3", "nodes": [ "node_modules/tough-cookie" ], "fixAvailable": { "name": "jsdom", "version": "26.1.0", "isSemVerMajor": true } }, "webpack": { "name": "webpack", "severity": "moderate", "isDirect": true, "via": [ { "source": 1099351, "name": "webpack", "dependency": "webpack", "title": "Webpack's AutoPublicPathRuntimeModule has a DOM Clobbering Gadget that leads to XSS", "url": "https://github.com/advisories/GHSA-4vvj-4cpr-p986", "severity": "moderate", "cwe": [ "CWE-79" ], "cvss": { "score": 6.4, "vectorString": "CVSS:3.1/AV:N/AC:H/PR:L/UI:N/S:U/C:L/I:L/A:H" }, "range": ">=5.0.0-alpha.0 <5.94.0" } ], "effects": [], "range": "5.0.0-alpha.0 - 5.93.0", "nodes": [ "node_modules/webpack" ], "fixAvailable": { "name": "webpack", "version": "5.99.8", "isSemVerMajor": false } } }, "metadata": { "vulnerabilities": { "info": 0, "low": 0, "moderate": 7, "high": 2, "critical": 0, "total": 9 }, "dependencies": { "prod": 1, "dev": 945, "optional": 8, "peer": 14, "peerOptional": 0, "total": 945 } } } --- end --- Attempting to npm audit fix $ /usr/bin/npm audit fix --dry-run --only=dev --json --- stderr --- npm WARN invalid config only="dev" set in command line options npm WARN invalid config Must be one of: null, prod, production npm WARN EBADENGINE Unsupported engine { npm WARN EBADENGINE package: undefined, npm WARN EBADENGINE required: { node: '20.19.1' }, npm WARN EBADENGINE current: { node: 'v18.19.0', npm: '9.2.0' } npm WARN EBADENGINE } --- stdout --- { "added": 943, "removed": 0, "changed": 0, "audited": 945, "funding": 121, "audit": { "auditReportVersion": 2, "vulnerabilities": { "cross-spawn": { "name": "cross-spawn", "severity": "high", "isDirect": false, "via": [ { "source": 1100562, "name": "cross-spawn", "dependency": "cross-spawn", "title": "Regular Expression Denial of Service (ReDoS) in cross-spawn", "url": "https://github.com/advisories/GHSA-3xgq-45jj-v275", "severity": "high", "cwe": [ "CWE-1333" ], "cvss": { "score": 7.5, "vectorString": "CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:N/I:N/A:H" }, "range": "<6.0.6" } ], "effects": [ "pre-commit" ], "range": "<6.0.6", "nodes": [ "node_modules/pre-commit/node_modules/cross-spawn" ], "fixAvailable": { "name": "pre-commit", "version": "1.0.10", "isSemVerMajor": true } }, "jsdom": { "name": "jsdom", "severity": "moderate", "isDirect": true, "via": [ "request", "tough-cookie" ], "effects": [], "range": "0.1.20 || 0.2.0 - 16.5.3", "nodes": [ "node_modules/jsdom" ], "fixAvailable": { "name": "jsdom", "version": "26.1.0", "isSemVerMajor": true } }, "less": { "name": "less", "severity": "moderate", "isDirect": true, "via": [ "request" ], "effects": [], "range": "1.4.0-b1 - 2.6.1 || 2.7.2 - 3.11.3", "nodes": [ "node_modules/less" ], "fixAvailable": { "name": "less", "version": "3.13.1", "isSemVerMajor": false } }, "pre-commit": { "name": "pre-commit", "severity": "high", "isDirect": true, "via": [ "cross-spawn" ], "effects": [], "range": ">=1.1.0", "nodes": [ "node_modules/pre-commit" ], "fixAvailable": { "name": "pre-commit", "version": "1.0.10", "isSemVerMajor": true } }, "request": { "name": "request", "severity": "moderate", "isDirect": false, "via": [ { "source": 1096727, "name": "request", "dependency": "request", "title": "Server-Side Request Forgery in Request", "url": "https://github.com/advisories/GHSA-p8p7-x288-28g6", "severity": "moderate", "cwe": [ "CWE-918" ], "cvss": { "score": 6.1, "vectorString": "CVSS:3.1/AV:N/AC:L/PR:N/UI:R/S:C/C:L/I:L/A:N" }, "range": "<=2.88.2" }, "tough-cookie" ], "effects": [ "jsdom", "less", "request-promise-core", "request-promise-native" ], "range": "*", "nodes": [ "node_modules/request" ], "fixAvailable": { "name": "jsdom", "version": "26.1.0", "isSemVerMajor": true } }, "request-promise-core": { "name": "request-promise-core", "severity": "moderate", "isDirect": false, "via": [ "request" ], "effects": [ "request-promise-native" ], "range": "*", "nodes": [ "node_modules/request-promise-core" ], "fixAvailable": true }, "request-promise-native": { "name": "request-promise-native", "severity": "moderate", "isDirect": false, "via": [ "request", "request-promise-core", "tough-cookie" ], "effects": [], "range": ">=1.0.0", "nodes": [ "node_modules/request-promise-native" ], "fixAvailable": true }, "tough-cookie": { "name": "tough-cookie", "severity": "moderate", "isDirect": false, "via": [ { "source": 1097682, "name": "tough-cookie", "dependency": "tough-cookie", "title": "tough-cookie Prototype Pollution vulnerability", "url": "https://github.com/advisories/GHSA-72xf-g2v4-qvf3", "severity": "moderate", "cwe": [ "CWE-1321" ], "cvss": { "score": 6.5, "vectorString": "CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:L/I:L/A:N" }, "range": "<4.1.3" } ], "effects": [ "jsdom", "request", "request-promise-native" ], "range": "<4.1.3", "nodes": [ "node_modules/tough-cookie" ], "fixAvailable": { "name": "jsdom", "version": "26.1.0", "isSemVerMajor": true } }, "webpack": { "name": "webpack", "severity": "moderate", "isDirect": true, "via": [ { "source": 1099351, "name": "webpack", "dependency": "webpack", "title": "Webpack's AutoPublicPathRuntimeModule has a DOM Clobbering Gadget that leads to XSS", "url": "https://github.com/advisories/GHSA-4vvj-4cpr-p986", "severity": "moderate", "cwe": [ "CWE-79" ], "cvss": { "score": 6.4, "vectorString": "CVSS:3.1/AV:N/AC:H/PR:L/UI:N/S:U/C:L/I:L/A:H" }, "range": ">=5.0.0-alpha.0 <5.94.0" } ], "effects": [], "range": "5.0.0-alpha.0 - 5.93.0", "nodes": [ "node_modules/webpack" ], "fixAvailable": { "name": "webpack", "version": "5.99.8", "isSemVerMajor": false } } }, "metadata": { "vulnerabilities": { "info": 0, "low": 0, "moderate": 7, "high": 2, "critical": 0, "total": 9 }, "dependencies": { "prod": 1, "dev": 944, "optional": 9, "peer": 15, "peerOptional": 0, "total": 944 } } } } --- end --- {"added": 943, "removed": 0, "changed": 0, "audited": 945, "funding": 121, "audit": {"auditReportVersion": 2, "vulnerabilities": {"cross-spawn": {"name": "cross-spawn", "severity": "high", "isDirect": false, "via": [{"source": 1100562, "name": "cross-spawn", "dependency": "cross-spawn", "title": "Regular Expression Denial of Service (ReDoS) in cross-spawn", "url": "https://github.com/advisories/GHSA-3xgq-45jj-v275", "severity": "high", "cwe": ["CWE-1333"], "cvss": {"score": 7.5, "vectorString": "CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:N/I:N/A:H"}, "range": "<6.0.6"}], "effects": ["pre-commit"], "range": "<6.0.6", "nodes": ["node_modules/pre-commit/node_modules/cross-spawn"], "fixAvailable": {"name": "pre-commit", "version": "1.0.10", "isSemVerMajor": true}}, "jsdom": {"name": "jsdom", "severity": "moderate", "isDirect": true, "via": ["request", "tough-cookie"], "effects": [], "range": "0.1.20 || 0.2.0 - 16.5.3", "nodes": ["node_modules/jsdom"], "fixAvailable": {"name": "jsdom", "version": "26.1.0", "isSemVerMajor": true}}, "less": {"name": "less", "severity": "moderate", "isDirect": true, "via": ["request"], "effects": [], "range": "1.4.0-b1 - 2.6.1 || 2.7.2 - 3.11.3", "nodes": ["node_modules/less"], "fixAvailable": {"name": "less", "version": "3.13.1", "isSemVerMajor": false}}, "pre-commit": {"name": "pre-commit", "severity": "high", "isDirect": true, "via": ["cross-spawn"], "effects": [], "range": ">=1.1.0", "nodes": ["node_modules/pre-commit"], "fixAvailable": {"name": "pre-commit", "version": "1.0.10", "isSemVerMajor": true}}, "request": {"name": "request", "severity": "moderate", "isDirect": false, "via": [{"source": 1096727, "name": "request", "dependency": "request", "title": "Server-Side Request Forgery in Request", "url": "https://github.com/advisories/GHSA-p8p7-x288-28g6", "severity": "moderate", "cwe": ["CWE-918"], "cvss": {"score": 6.1, "vectorString": "CVSS:3.1/AV:N/AC:L/PR:N/UI:R/S:C/C:L/I:L/A:N"}, "range": "<=2.88.2"}, "tough-cookie"], "effects": ["jsdom", "less", "request-promise-core", "request-promise-native"], "range": "*", "nodes": ["node_modules/request"], "fixAvailable": {"name": "jsdom", "version": "26.1.0", "isSemVerMajor": true}}, "request-promise-core": {"name": "request-promise-core", "severity": "moderate", "isDirect": false, "via": ["request"], "effects": ["request-promise-native"], "range": "*", "nodes": ["node_modules/request-promise-core"], "fixAvailable": true}, "request-promise-native": {"name": "request-promise-native", "severity": "moderate", "isDirect": false, "via": ["request", "request-promise-core", "tough-cookie"], "effects": [], "range": ">=1.0.0", "nodes": ["node_modules/request-promise-native"], "fixAvailable": true}, "tough-cookie": {"name": "tough-cookie", "severity": "moderate", "isDirect": false, "via": [{"source": 1097682, "name": "tough-cookie", "dependency": "tough-cookie", "title": "tough-cookie Prototype Pollution vulnerability", "url": "https://github.com/advisories/GHSA-72xf-g2v4-qvf3", "severity": "moderate", "cwe": ["CWE-1321"], "cvss": {"score": 6.5, "vectorString": "CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:L/I:L/A:N"}, "range": "<4.1.3"}], "effects": ["jsdom", "request", "request-promise-native"], "range": "<4.1.3", "nodes": ["node_modules/tough-cookie"], "fixAvailable": {"name": "jsdom", "version": "26.1.0", "isSemVerMajor": true}}, "webpack": {"name": "webpack", "severity": "moderate", "isDirect": true, "via": [{"source": 1099351, "name": "webpack", "dependency": "webpack", "title": "Webpack's AutoPublicPathRuntimeModule has a DOM Clobbering Gadget that leads to XSS", "url": "https://github.com/advisories/GHSA-4vvj-4cpr-p986", "severity": "moderate", "cwe": ["CWE-79"], "cvss": {"score": 6.4, "vectorString": "CVSS:3.1/AV:N/AC:H/PR:L/UI:N/S:U/C:L/I:L/A:H"}, "range": ">=5.0.0-alpha.0 <5.94.0"}], "effects": [], "range": "5.0.0-alpha.0 - 5.93.0", "nodes": ["node_modules/webpack"], "fixAvailable": {"name": "webpack", "version": "5.99.8", "isSemVerMajor": false}}}, "metadata": {"vulnerabilities": {"info": 0, "low": 0, "moderate": 7, "high": 2, "critical": 0, "total": 9}, "dependencies": {"prod": 1, "dev": 944, "optional": 9, "peer": 15, "peerOptional": 0, "total": 944}}}} {} Upgrading n:less from 3.8.1 -> 3.13.1 {} Upgrading n:webpack from 5.89.0 -> 5.99.8 $ /usr/bin/npm audit fix --only=dev --- stderr --- npm WARN invalid config only="dev" set in command line options npm WARN invalid config Must be one of: null, prod, production npm WARN EBADENGINE Unsupported engine { npm WARN EBADENGINE package: undefined, npm WARN EBADENGINE required: { node: '20.19.1' }, npm WARN EBADENGINE current: { node: 'v18.19.0', npm: '9.2.0' } npm WARN EBADENGINE } npm WARN deprecated inflight@1.0.6: This module is not supported, and leaks memory. Do not use it. Check out lru-cache if you want a good and tested way to coalesce async requests by a key value, which is much more comprehensive and powerful. npm WARN deprecated rimraf@2.7.1: Rimraf versions prior to v4 are no longer supported npm WARN deprecated request-promise-native@1.0.9: request-promise-native has been deprecated because it extends the now deprecated request package, see https://github.com/request/request/issues/3142 npm WARN deprecated har-validator@5.1.5: this library is no longer supported npm WARN deprecated @humanwhocodes/config-array@0.11.14: Use @eslint/config-array instead npm WARN deprecated abab@2.0.6: Use your platform's native atob() and btoa() methods instead npm WARN deprecated rimraf@3.0.2: Rimraf versions prior to v4 are no longer supported npm WARN deprecated rimraf@3.0.2: Rimraf versions prior to v4 are no longer supported npm WARN deprecated rimraf@3.0.2: Rimraf versions prior to v4 are no longer supported npm WARN deprecated rimraf@3.0.2: Rimraf versions prior to v4 are no longer supported npm WARN deprecated domexception@1.0.1: Use your platform's native DOMException instead npm WARN deprecated glob@7.2.0: Glob versions prior to v9 are no longer supported npm WARN deprecated @humanwhocodes/object-schema@2.0.3: Use @eslint/object-schema instead npm WARN deprecated w3c-hr-time@1.0.2: Use your platform's native performance.now() and performance.timeOrigin. npm WARN deprecated domexception@4.0.0: Use your platform's native DOMException instead npm WARN deprecated uuid@3.4.0: Please upgrade to version 7 or higher. Older versions may use Math.random() in certain circumstances, which is known to be problematic. See https://v8.dev/blog/math-random for details. npm WARN deprecated request@2.88.2: request has been deprecated, see https://github.com/request/request/issues/3142 npm WARN deprecated sinon@12.0.1: 16.1.1 --- stdout --- added 938 packages, and audited 940 packages in 14s 120 packages are looking for funding run `npm fund` for details # npm audit report cross-spawn <6.0.6 Severity: high Regular Expression Denial of Service (ReDoS) in cross-spawn - https://github.com/advisories/GHSA-3xgq-45jj-v275 fix available via `npm audit fix --force` Will install pre-commit@1.0.10, which is a breaking change node_modules/pre-commit/node_modules/cross-spawn pre-commit >=1.1.0 Depends on vulnerable versions of cross-spawn node_modules/pre-commit request * Severity: moderate Server-Side Request Forgery in Request - https://github.com/advisories/GHSA-p8p7-x288-28g6 Depends on vulnerable versions of tough-cookie fix available via `npm audit fix --force` Will install jsdom@26.1.0, which is a breaking change node_modules/request jsdom 0.1.20 || 0.2.0 - 16.5.3 Depends on vulnerable versions of request Depends on vulnerable versions of tough-cookie node_modules/jsdom request-promise-core * Depends on vulnerable versions of request node_modules/request-promise-core request-promise-native >=1.0.0 Depends on vulnerable versions of request Depends on vulnerable versions of request-promise-core Depends on vulnerable versions of tough-cookie node_modules/request-promise-native tough-cookie <4.1.3 Severity: moderate tough-cookie Prototype Pollution vulnerability - https://github.com/advisories/GHSA-72xf-g2v4-qvf3 fix available via `npm audit fix --force` Will install jsdom@26.1.0, which is a breaking change node_modules/tough-cookie 7 vulnerabilities (5 moderate, 2 high) To address issues that do not require attention, run: npm audit fix To address all issues (including breaking changes), run: npm audit fix --force --- end --- Verifying that tests still pass $ /usr/bin/npm ci --- stderr --- npm WARN EBADENGINE Unsupported engine { npm WARN EBADENGINE package: undefined, npm WARN EBADENGINE required: { node: '20.19.1' }, npm WARN EBADENGINE current: { node: 'v18.19.0', npm: '9.2.0' } npm WARN EBADENGINE } npm WARN deprecated inflight@1.0.6: This module is not supported, and leaks memory. Do not use it. Check out lru-cache if you want a good and tested way to coalesce async requests by a key value, which is much more comprehensive and powerful. npm WARN deprecated rimraf@2.7.1: Rimraf versions prior to v4 are no longer supported npm WARN deprecated request-promise-native@1.0.9: request-promise-native has been deprecated because it extends the now deprecated request package, see https://github.com/request/request/issues/3142 npm WARN deprecated har-validator@5.1.5: this library is no longer supported npm WARN deprecated @humanwhocodes/config-array@0.11.14: Use @eslint/config-array instead npm WARN deprecated abab@2.0.6: Use your platform's native atob() and btoa() methods instead npm WARN deprecated rimraf@3.0.2: Rimraf versions prior to v4 are no longer supported npm WARN deprecated rimraf@3.0.2: Rimraf versions prior to v4 are no longer supported npm WARN deprecated rimraf@3.0.2: Rimraf versions prior to v4 are no longer supported npm WARN deprecated rimraf@3.0.2: Rimraf versions prior to v4 are no longer supported npm WARN deprecated domexception@1.0.1: Use your platform's native DOMException instead npm WARN deprecated glob@7.2.0: Glob versions prior to v9 are no longer supported npm WARN deprecated @humanwhocodes/object-schema@2.0.3: Use @eslint/object-schema instead npm WARN deprecated w3c-hr-time@1.0.2: Use your platform's native performance.now() and performance.timeOrigin. npm WARN deprecated domexception@4.0.0: Use your platform's native DOMException instead npm WARN deprecated uuid@3.4.0: Please upgrade to version 7 or higher. Older versions may use Math.random() in certain circumstances, which is known to be problematic. See https://v8.dev/blog/math-random for details. npm WARN deprecated request@2.88.2: request has been deprecated, see https://github.com/request/request/issues/3142 npm WARN deprecated sinon@12.0.1: 16.1.1 --- stdout --- added 938 packages, and audited 940 packages in 18s 120 packages are looking for funding run `npm fund` for details 7 vulnerabilities (5 moderate, 2 high) To address issues that do not require attention, run: npm audit fix To address all issues (including breaking changes), run: npm audit fix --force Run `npm audit` for details. --- end --- $ /usr/bin/npm test --- stderr --- The "se" translation has 5 translations with trailing whitespace: * mobile-frontend-editor-disabled * mobile-frontend-editor-error-preview * mobile-frontend-user-page-describe-yourself * tag-advanced_mobile_edit * mobile-frontend-mobile-option-MFShowFirstParagraphBeforeInfobox ERROR: Coverage for lines (55.74%) does not meet global threshold (62%) ERROR: Coverage for functions (52.02%) does not meet global threshold (58%) ERROR: Coverage for branches (43.53%) does not meet global threshold (47%) ERROR: Coverage for statements (55.77%) does not meet global threshold (62%) --- stdout --- > test > npm -s run lint && bash ./dev-scripts/svg_check.sh && npm -s run coverage && npm -s run test:bundle && npm -s run jsdoc Checked 1 message directory. /src/repo/src/mobile.editor.overlay/EditorOverlayBase.js 266:1 warning This line has a length of 103. Maximum allowed is 100 max-len /src/repo/src/mobile.editor.overlay/parseBlockInfo.js 58:1 warning This line has a length of 120. Maximum allowed is 100 max-len /src/repo/src/mobile.languages.structured/LanguageSearcher.js 8:1 warning This line has a length of 106. Maximum allowed is 100 max-len /src/repo/src/mobile.mediaViewer/ImageCarousel.js 42:1 warning This line has a length of 104. Maximum allowed is 100 max-len /src/repo/src/mobile.startup/CtaDrawer.js 34:1 warning This line has a length of 118. Maximum allowed is 100 max-len /src/repo/src/mobile.startup/OverlayManager.js 363:1 warning This line has a length of 102. Maximum allowed is 100 max-len 364:1 warning This line has a length of 102. Maximum allowed is 100 max-len 365:1 warning This line has a length of 101. Maximum allowed is 100 max-len /src/repo/src/mobile.startup/promoCampaign/promoCampaign.js 89:1 warning This line has a length of 107. Maximum allowed is 100 max-len /src/repo/src/mobile.startup/search/searchHeader.js 15:1 warning This line has a length of 110. Maximum allowed is 100 max-len /src/repo/src/mobile.startup/sectionCollapsing.js 7:1 warning Expected @param names to be "content, headingText, icon, isCollapsed". Got "container, headingText, icon, isCollapsed" jsdoc/check-param-names 33:1 warning Expected @param names to be "content, headingText, icon". Got "container, headingText, icon" jsdoc/check-param-names /src/repo/tests/node-qunit/importable.test.js 69:4 warning Found non-literal argument in require security/detect-non-literal-require /src/repo/tests/node-qunit/mobile.startup/CtaDrawer.test.js 87:12 warning Found non-literal argument to RegExp Constructor security/detect-non-literal-regexp 108:12 warning Found non-literal argument to RegExp Constructor security/detect-non-literal-regexp /src/repo/tests/node-qunit/mobile.startup/PageHTMLParser.test.js 215:1 warning This line has a length of 111. Maximum allowed is 100 max-len 222:1 warning This line has a length of 108. Maximum allowed is 100 max-len ✖ 17 problems (0 errors, 17 warnings) TAP version 13 not ok 1 MobileFrontend imports > All our code is importable in headless Node.js --- message: |+ There were no errors when importing any of the modules: src/mobile.editor.overlay/BlockMessageDetails.js src/mobile.editor.overlay/blockMessageDrawer.js src/mobile.editor.overlay/EditorOverlayBase.js src/mobile.editor.overlay/SourceEditorOverlay.js src/mobile.editor.overlay/VisualEditorOverlay.js severity: failed actual : 5 expected: 0 stack: | at Assert.strictEqual (/src/repo/node_modules/qunit/qunit/qunit.js:1639:14) ... not ok 2 MobileFrontend mobile.editor.overlay/BlockMessageDetails > renders block reason --- message: "beforeEach failed on renders block reason: Cannot read properties of undefined (reading 'Button')" severity: failed actual : null expected: undefined stack: | TypeError: Cannot read properties of undefined (reading 'Button') at Object.<anonymous> (/src/repo/src/mobile.editor.overlay/BlockMessageDetails.js:3:29) at Module._compile (node:internal/modules/cjs/loader:1356:14) at Module.replacementCompile (/src/repo/node_modules/append-transform/index.js:60:13) at Module._compile (/src/repo/node_modules/pirates/lib/index.js:117:24) at Module._extensions..js (node:internal/modules/cjs/loader:1414:10) at newLoader (/src/repo/node_modules/pirates/lib/index.js:121:7) at Object.<anonymous> (/src/repo/node_modules/append-transform/index.js:64:4) at Module.load (node:internal/modules/cjs/loader:1197:32) at Function.Module._load (node:internal/modules/cjs/loader:1013:12) at Module.require (node:internal/modules/cjs/loader:1225:19) at require (node:internal/modules/helpers:177:18) at Object.beforeEach (/src/repo/tests/node-qunit/mobile.editor.overlay/BlockMessageDetails.test.js:12:30) ... --- message: |+ Died on test #2: this.BlockMessageDetails is not a constructor at Object.test (/src/repo/node_modules/qunit/qunit/qunit.js:3304:5) severity: failed actual : null expected: undefined stack: | TypeError: this.BlockMessageDetails is not a constructor at Object.<anonymous> (/src/repo/tests/node-qunit/mobile.editor.overlay/BlockMessageDetails.test.js:23:20) ... not ok 3 MobileFrontend mobile.editor.overlay/BlockMessageDetails > does not render block reason if it is empty --- message: "beforeEach failed on does not render block reason if it is empty: Cannot read properties of undefined (reading 'Button')" severity: failed actual : null expected: undefined stack: | TypeError: Cannot read properties of undefined (reading 'Button') at Object.<anonymous> (/src/repo/src/mobile.editor.overlay/BlockMessageDetails.js:3:29) at Module._compile (node:internal/modules/cjs/loader:1356:14) at Module.replacementCompile (/src/repo/node_modules/append-transform/index.js:60:13) at Module._compile (/src/repo/node_modules/pirates/lib/index.js:117:24) at Module._extensions..js (node:internal/modules/cjs/loader:1414:10) at newLoader (/src/repo/node_modules/pirates/lib/index.js:121:7) at Object.<anonymous> (/src/repo/node_modules/append-transform/index.js:64:4) at Module.load (node:internal/modules/cjs/loader:1197:32) at Function.Module._load (node:internal/modules/cjs/loader:1013:12) at Module.require (node:internal/modules/cjs/loader:1225:19) at require (node:internal/modules/helpers:177:18) at Object.beforeEach (/src/repo/tests/node-qunit/mobile.editor.overlay/BlockMessageDetails.test.js:12:30) ... --- message: |+ Died on test #2: this.BlockMessageDetails is not a constructor at Object.test (/src/repo/node_modules/qunit/qunit/qunit.js:3304:5) severity: failed actual : null expected: undefined stack: | TypeError: this.BlockMessageDetails is not a constructor at Object.<anonymous> (/src/repo/tests/node-qunit/mobile.editor.overlay/BlockMessageDetails.test.js:44:20) ... not ok 4 MobileFrontend mobile.editor.overlay/EditorGateway > #getContent (no section) --- message: |+ Died on test #1: actionParams is not a function at Object.test (/src/repo/node_modules/qunit/qunit/qunit.js:3304:5) severity: failed actual : null expected: undefined stack: | TypeError: actionParams is not a function at EditorGateway.getContent (/src/repo/src/mobile.editor.overlay/EditorGateway.js:82:14) at Object.<anonymous> (/src/repo/tests/node-qunit/mobile.editor.overlay/EditorGateway.test.js:227:17) ... not ok 5 MobileFrontend mobile.editor.overlay/EditorGateway > #getContent --- message: |+ Died on test #1: actionParams is not a function at Object.test (/src/repo/node_modules/qunit/qunit/qunit.js:3304:5) severity: failed actual : null expected: undefined stack: | TypeError: actionParams is not a function at EditorGateway.getContent (/src/repo/src/mobile.editor.overlay/EditorGateway.js:82:14) at Object.<anonymous> (/src/repo/tests/node-qunit/mobile.editor.overlay/EditorGateway.test.js:243:17) ... not ok 6 MobileFrontend mobile.editor.overlay/EditorGateway > #getContent, missing section --- message: |+ Died on test #1: actionParams is not a function at Object.test (/src/repo/node_modules/qunit/qunit/qunit.js:3304:5) severity: failed actual : null expected: undefined stack: | TypeError: actionParams is not a function at EditorGateway.getContent (/src/repo/src/mobile.editor.overlay/EditorGateway.js:82:14) at Object.<anonymous> (/src/repo/tests/node-qunit/mobile.editor.overlay/EditorGateway.test.js:259:26) ... ok 7 MobileFrontend mobile.editor.overlay/EditorGateway > #getBlockInfo not ok 8 MobileFrontend mobile.editor.overlay/EditorGateway > #save, success --- message: |+ Died on test #1: actionParams is not a function at Object.test (/src/repo/node_modules/qunit/qunit/qunit.js:3304:5) severity: failed actual : null expected: undefined stack: | TypeError: actionParams is not a function at EditorGateway.getContent (/src/repo/src/mobile.editor.overlay/EditorGateway.js:82:14) at Object.<anonymous> (/src/repo/tests/node-qunit/mobile.editor.overlay/EditorGateway.test.js:296:17) ... not ok 9 MobileFrontend mobile.editor.overlay/EditorGateway > #save, new page --- message: |+ Died on test #1: actionParams is not a function at Object.test (/src/repo/node_modules/qunit/qunit/qunit.js:3304:5) severity: failed actual : null expected: undefined stack: | TypeError: actionParams is not a function at EditorGateway.getContent (/src/repo/src/mobile.editor.overlay/EditorGateway.js:82:14) at Object.<anonymous> (/src/repo/tests/node-qunit/mobile.editor.overlay/EditorGateway.test.js:319:17) ... not ok 10 MobileFrontend mobile.editor.overlay/EditorGateway > #save, submit CAPTCHA --- message: |+ Died on test #1: actionParams is not a function at Object.test (/src/repo/node_modules/qunit/qunit/qunit.js:3304:5) severity: failed actual : null expected: undefined stack: | TypeError: actionParams is not a function at EditorGateway.getContent (/src/repo/src/mobile.editor.overlay/EditorGateway.js:82:14) at Object.<anonymous> (/src/repo/tests/node-qunit/mobile.editor.overlay/EditorGateway.test.js:345:17) ... not ok 11 MobileFrontend mobile.editor.overlay/EditorGateway > #save, request failure --- message: |+ Died on test #1: actionParams is not a function at Object.test (/src/repo/node_modules/qunit/qunit/qunit.js:3304:5) severity: failed actual : null expected: undefined stack: | TypeError: actionParams is not a function at EditorGateway.getContent (/src/repo/src/mobile.editor.overlay/EditorGateway.js:82:14) at Object.<anonymous> (/src/repo/tests/node-qunit/mobile.editor.overlay/EditorGateway.test.js:371:17) ... not ok 12 MobileFrontend mobile.editor.overlay/EditorGateway > #save, API failure --- message: |+ Died on test #1: actionParams is not a function at Object.test (/src/repo/node_modules/qunit/qunit/qunit.js:3304:5) severity: failed actual : null expected: undefined stack: | TypeError: actionParams is not a function at EditorGateway.getContent (/src/repo/src/mobile.editor.overlay/EditorGateway.js:82:14) at Object.<anonymous> (/src/repo/tests/node-qunit/mobile.editor.overlay/EditorGateway.test.js:388:17) ... not ok 13 MobileFrontend mobile.editor.overlay/EditorGateway > #save, CAPTCHA response with image URL --- message: |+ Died on test #1: actionParams is not a function at Object.test (/src/repo/node_modules/qunit/qunit/qunit.js:3304:5) severity: failed actual : null expected: undefined stack: | TypeError: actionParams is not a function at EditorGateway.getContent (/src/repo/src/mobile.editor.overlay/EditorGateway.js:82:14) at Object.<anonymous> (/src/repo/tests/node-qunit/mobile.editor.overlay/EditorGateway.test.js:407:17) ... not ok 14 MobileFrontend mobile.editor.overlay/EditorGateway > #save, AbuseFilter warning --- message: |+ Died on test #1: actionParams is not a function at Object.test (/src/repo/node_modules/qunit/qunit/qunit.js:3304:5) severity: failed actual : null expected: undefined stack: | TypeError: actionParams is not a function at EditorGateway.getContent (/src/repo/src/mobile.editor.overlay/EditorGateway.js:82:14) at Object.<anonymous> (/src/repo/tests/node-qunit/mobile.editor.overlay/EditorGateway.test.js:434:17) ... not ok 15 MobileFrontend mobile.editor.overlay/EditorGateway > #save, AbuseFilter disallow --- message: |+ Died on test #1: actionParams is not a function at Object.test (/src/repo/node_modules/qunit/qunit/qunit.js:3304:5) severity: failed actual : null expected: undefined stack: | TypeError: actionParams is not a function at EditorGateway.getContent (/src/repo/src/mobile.editor.overlay/EditorGateway.js:82:14) at Object.<anonymous> (/src/repo/tests/node-qunit/mobile.editor.overlay/EditorGateway.test.js:459:17) ... not ok 16 MobileFrontend mobile.editor.overlay/EditorGateway > #save, AbuseFilter other --- message: |+ Died on test #1: actionParams is not a function at Object.test (/src/repo/node_modules/qunit/qunit/qunit.js:3304:5) severity: failed actual : null expected: undefined stack: | TypeError: actionParams is not a function at EditorGateway.getContent (/src/repo/src/mobile.editor.overlay/EditorGateway.js:82:14) at Object.<anonymous> (/src/repo/tests/node-qunit/mobile.editor.overlay/EditorGateway.test.js:484:17) ... not ok 17 MobileFrontend mobile.editor.overlay/EditorGateway > #save, extension errors --- message: |+ Died on test #1: actionParams is not a function at Object.test (/src/repo/node_modules/qunit/qunit/qunit.js:3304:5) severity: failed actual : null expected: undefined stack: | TypeError: actionParams is not a function at EditorGateway.getContent (/src/repo/src/mobile.editor.overlay/EditorGateway.js:82:14) at Object.<anonymous> (/src/repo/tests/node-qunit/mobile.editor.overlay/EditorGateway.test.js:509:17) ... not ok 18 MobileFrontend mobile.editor.overlay/EditorGateway > #save, read-only error --- message: |+ Died on test #1: actionParams is not a function at Object.test (/src/repo/node_modules/qunit/qunit/qunit.js:3304:5) severity: failed actual : null expected: undefined stack: | TypeError: actionParams is not a function at EditorGateway.getContent (/src/repo/src/mobile.editor.overlay/EditorGateway.js:82:14) at Object.<anonymous> (/src/repo/tests/node-qunit/mobile.editor.overlay/EditorGateway.test.js:541:10) ... not ok 19 MobileFrontend mobile.editor.overlay/EditorGateway > #save, unknown errors --- message: |+ Died on test #1: actionParams is not a function at Object.test (/src/repo/node_modules/qunit/qunit/qunit.js:3304:5) severity: failed actual : null expected: undefined stack: | TypeError: actionParams is not a function at EditorGateway.getContent (/src/repo/src/mobile.editor.overlay/EditorGateway.js:82:14) at Object.<anonymous> (/src/repo/tests/node-qunit/mobile.editor.overlay/EditorGateway.test.js:559:17) ... not ok 20 MobileFrontend mobile.editor.overlay/EditorGateway > #save, without changes --- message: |+ Died on test #1: actionParams is not a function at Object.test (/src/repo/node_modules/qunit/qunit/qunit.js:3304:5) severity: failed actual : null expected: undefined stack: | TypeError: actionParams is not a function at EditorGateway.getContent (/src/repo/src/mobile.editor.overlay/EditorGateway.js:82:14) at Object.<anonymous> (/src/repo/tests/node-qunit/mobile.editor.overlay/EditorGateway.test.js:577:17) ... not ok 21 MobileFrontend mobile.editor.overlay/EditorGateway > #EditorGateway --- message: |+ Died on test #1: Cannot read properties of undefined (reading 'extend') at Object.test (/src/repo/node_modules/qunit/qunit/qunit.js:3304:5) severity: failed actual : null expected: undefined stack: | TypeError: Cannot read properties of undefined (reading 'extend') at EditorGateway.getPreview (/src/repo/src/mobile.editor.overlay/EditorGateway.js:244:8) at Object.<anonymous> (/src/repo/tests/node-qunit/mobile.editor.overlay/EditorGateway.test.js:600:17) ... not ok 22 MobileFrontend mobile.editor.overlay/EditorGateway > #EditorGateway, check without sectionLine --- message: |+ Died on test #1: Cannot read properties of undefined (reading 'extend') at Object.test (/src/repo/node_modules/qunit/qunit/qunit.js:3304:5) severity: failed actual : null expected: undefined stack: | TypeError: Cannot read properties of undefined (reading 'extend') at EditorGateway.getPreview (/src/repo/src/mobile.editor.overlay/EditorGateway.js:244:8) at Object.<anonymous> (/src/repo/tests/node-qunit/mobile.editor.overlay/EditorGateway.test.js:622:17) ... not ok 23 MobileFrontend mobile.editor.overlay/EditorGateway > #EditorGateway, check with sectionLine --- message: |+ Died on test #1: Cannot read properties of undefined (reading 'extend') at Object.test (/src/repo/node_modules/qunit/qunit/qunit.js:3304:5) severity: failed actual : null expected: undefined stack: | TypeError: Cannot read properties of undefined (reading 'extend') at EditorGateway.getPreview (/src/repo/src/mobile.editor.overlay/EditorGateway.js:244:8) at Object.<anonymous> (/src/repo/tests/node-qunit/mobile.editor.overlay/EditorGateway.test.js:636:17) ... not ok 24 MobileFrontend mobile.editor.overlay/EditorGateway > #save, when token has expired --- message: |+ Died on test #1: actionParams is not a function at Object.test (/src/repo/node_modules/qunit/qunit/qunit.js:3304:5) severity: failed actual : null expected: undefined stack: | TypeError: actionParams is not a function at EditorGateway.getContent (/src/repo/src/mobile.editor.overlay/EditorGateway.js:82:14) at Object.<anonymous> (/src/repo/tests/node-qunit/mobile.editor.overlay/EditorGateway.test.js:650:17) ... not ok 25 MobileFrontend mobile.editor.overlay/SourceEditorOverlay > #initialize, blocked user --- message: "beforeEach failed on #initialize, blocked user: Cannot read properties of undefined (reading 'Overlay')" severity: failed actual : null expected: undefined stack: | TypeError: Cannot read properties of undefined (reading 'Overlay') at Object.<anonymous> (/src/repo/src/mobile.editor.overlay/EditorOverlayBase.js:7:25) at Module._compile (node:internal/modules/cjs/loader:1356:14) at Module.replacementCompile (/src/repo/node_modules/append-transform/index.js:60:13) at Module._compile (/src/repo/node_modules/pirates/lib/index.js:117:24) at Module._extensions..js (node:internal/modules/cjs/loader:1414:10) at newLoader (/src/repo/node_modules/pirates/lib/index.js:121:7) at Object.<anonymous> (/src/repo/node_modules/append-transform/index.js:64:4) at Module.load (node:internal/modules/cjs/loader:1197:32) at Function.Module._load (node:internal/modules/cjs/loader:1013:12) at Module.require (node:internal/modules/cjs/loader:1225:19) at require (node:internal/modules/helpers:177:18) at Object.<anonymous> (/src/repo/src/mobile.editor.overlay/SourceEditorOverlay.js:2:22) at Module._compile (node:internal/modules/cjs/loader:1356:14) at Module.replacementCompile (/src/repo/node_modules/append-transform/index.js:60:13) at Module._compile (/src/repo/node_modules/pirates/lib/index.js:117:24) at Module._extensions..js (node:internal/modules/cjs/loader:1414:10) at newLoader (/src/repo/node_modules/pirates/lib/index.js:121:7) at Object.<anonymous> (/src/repo/node_modules/append-transform/index.js:64:4) at Module.load (node:internal/modules/cjs/loader:1197:32) at Function.Module._load (node:internal/modules/cjs/loader:1013:12) at Module.require (node:internal/modules/cjs/loader:1225:19) at require (node:internal/modules/helpers:177:18) at Object.beforeEach (/src/repo/tests/node-qunit/mobile.editor.overlay/SourceEditorOverlay.test.js:30:25) ... --- message: |+ Died on test #2: SourceEditorOverlay is not a constructor at Object.test (/src/repo/node_modules/qunit/qunit/qunit.js:3304:5) severity: failed actual : null expected: undefined stack: | TypeError: SourceEditorOverlay is not a constructor at Object.<anonymous> (/src/repo/tests/node-qunit/mobile.editor.overlay/SourceEditorOverlay.test.js:96:2) ... not ok 26 MobileFrontend mobile.editor.overlay/SourceEditorOverlay > #initialize, with given page and section --- message: "beforeEach failed on #initialize, with given page and section: Cannot read properties of undefined (reading 'Overlay')" severity: failed actual : null expected: undefined stack: | TypeError: Cannot read properties of undefined (reading 'Overlay') at Object.<anonymous> (/src/repo/src/mobile.editor.overlay/EditorOverlayBase.js:7:25) at Module._compile (node:internal/modules/cjs/loader:1356:14) at Module.replacementCompile (/src/repo/node_modules/append-transform/index.js:60:13) at Module._compile (/src/repo/node_modules/pirates/lib/index.js:117:24) at Module._extensions..js (node:internal/modules/cjs/loader:1414:10) at newLoader (/src/repo/node_modules/pirates/lib/index.js:121:7) at Object.<anonymous> (/src/repo/node_modules/append-transform/index.js:64:4) at Module.load (node:internal/modules/cjs/loader:1197:32) at Function.Module._load (node:internal/modules/cjs/loader:1013:12) at Module.require (node:internal/modules/cjs/loader:1225:19) at require (node:internal/modules/helpers:177:18) at Object.<anonymous> (/src/repo/src/mobile.editor.overlay/SourceEditorOverlay.js:2:22) at Module._compile (node:internal/modules/cjs/loader:1356:14) at Module.replacementCompile (/src/repo/node_modules/append-transform/index.js:60:13) at Module._compile (/src/repo/node_modules/pirates/lib/index.js:117:24) at Module._extensions..js (node:internal/modules/cjs/loader:1414:10) at newLoader (/src/repo/node_modules/pirates/lib/index.js:121:7) at Object.<anonymous> (/src/repo/node_modules/append-transform/index.js:64:4) at Module.load (node:internal/modules/cjs/loader:1197:32) at Function.Module._load (node:internal/modules/cjs/loader:1013:12) at Module.require (node:internal/modules/cjs/loader:1225:19) at require (node:internal/modules/helpers:177:18) at Object.beforeEach (/src/repo/tests/node-qunit/mobile.editor.overlay/SourceEditorOverlay.test.js:30:25) ... --- message: |+ Died on test #2: SourceEditorOverlay is not a constructor at Object.test (/src/repo/node_modules/qunit/qunit/qunit.js:3304:5) severity: failed actual : null expected: undefined stack: | TypeError: SourceEditorOverlay is not a constructor at Object.<anonymous> (/src/repo/tests/node-qunit/mobile.editor.overlay/SourceEditorOverlay.test.js:116:24) ... not ok 27 MobileFrontend mobile.editor.overlay/SourceEditorOverlay > #initialize, without a section --- message: "beforeEach failed on #initialize, without a section: Cannot read properties of undefined (reading 'Overlay')" severity: failed actual : null expected: undefined stack: | TypeError: Cannot read properties of undefined (reading 'Overlay') at Object.<anonymous> (/src/repo/src/mobile.editor.overlay/EditorOverlayBase.js:7:25) at Module._compile (node:internal/modules/cjs/loader:1356:14) at Module.replacementCompile (/src/repo/node_modules/append-transform/index.js:60:13) at Module._compile (/src/repo/node_modules/pirates/lib/index.js:117:24) at Module._extensions..js (node:internal/modules/cjs/loader:1414:10) at newLoader (/src/repo/node_modules/pirates/lib/index.js:121:7) at Object.<anonymous> (/src/repo/node_modules/append-transform/index.js:64:4) at Module.load (node:internal/modules/cjs/loader:1197:32) at Function.Module._load (node:internal/modules/cjs/loader:1013:12) at Module.require (node:internal/modules/cjs/loader:1225:19) at require (node:internal/modules/helpers:177:18) at Object.<anonymous> (/src/repo/src/mobile.editor.overlay/SourceEditorOverlay.js:2:22) at Module._compile (node:internal/modules/cjs/loader:1356:14) at Module.replacementCompile (/src/repo/node_modules/append-transform/index.js:60:13) at Module._compile (/src/repo/node_modules/pirates/lib/index.js:117:24) at Module._extensions..js (node:internal/modules/cjs/loader:1414:10) at newLoader (/src/repo/node_modules/pirates/lib/index.js:121:7) at Object.<anonymous> (/src/repo/node_modules/append-transform/index.js:64:4) at Module.load (node:internal/modules/cjs/loader:1197:32) at Function.Module._load (node:internal/modules/cjs/loader:1013:12) at Module.require (node:internal/modules/cjs/loader:1225:19) at require (node:internal/modules/helpers:177:18) at Object.beforeEach (/src/repo/tests/node-qunit/mobile.editor.overlay/SourceEditorOverlay.test.js:30:25) ... --- message: |+ Died on test #2: SourceEditorOverlay is not a constructor at Object.test (/src/repo/node_modules/qunit/qunit/qunit.js:3304:5) severity: failed actual : null expected: undefined stack: | TypeError: SourceEditorOverlay is not a constructor at Object.<anonymous> (/src/repo/tests/node-qunit/mobile.editor.overlay/SourceEditorOverlay.test.js:133:24) ... not ok 28 MobileFrontend mobile.editor.overlay/SourceEditorOverlay > #preview --- message: "beforeEach failed on #preview: Cannot read properties of undefined (reading 'Overlay')" severity: failed actual : null expected: undefined stack: | TypeError: Cannot read properties of undefined (reading 'Overlay') at Object.<anonymous> (/src/repo/src/mobile.editor.overlay/EditorOverlayBase.js:7:25) at Module._compile (node:internal/modules/cjs/loader:1356:14) at Module.replacementCompile (/src/repo/node_modules/append-transform/index.js:60:13) at Module._compile (/src/repo/node_modules/pirates/lib/index.js:117:24) at Module._extensions..js (node:internal/modules/cjs/loader:1414:10) at newLoader (/src/repo/node_modules/pirates/lib/index.js:121:7) at Object.<anonymous> (/src/repo/node_modules/append-transform/index.js:64:4) at Module.load (node:internal/modules/cjs/loader:1197:32) at Function.Module._load (node:internal/modules/cjs/loader:1013:12) at Module.require (node:internal/modules/cjs/loader:1225:19) at require (node:internal/modules/helpers:177:18) at Object.<anonymous> (/src/repo/src/mobile.editor.overlay/SourceEditorOverlay.js:2:22) at Module._compile (node:internal/modules/cjs/loader:1356:14) at Module.replacementCompile (/src/repo/node_modules/append-transform/index.js:60:13) at Module._compile (/src/repo/node_modules/pirates/lib/index.js:117:24) at Module._extensions..js (node:internal/modules/cjs/loader:1414:10) at newLoader (/src/repo/node_modules/pirates/lib/index.js:121:7) at Object.<anonymous> (/src/repo/node_modules/append-transform/index.js:64:4) at Module.load (node:internal/modules/cjs/loader:1197:32) at Function.Module._load (node:internal/modules/cjs/loader:1013:12) at Module.require (node:internal/modules/cjs/loader:1225:19) at require (node:internal/modules/helpers:177:18) at Object.beforeEach (/src/repo/tests/node-qunit/mobile.editor.overlay/SourceEditorOverlay.test.js:30:25) ... --- message: |+ Died on test #2: SourceEditorOverlay is not a constructor at Object.test (/src/repo/node_modules/qunit/qunit/qunit.js:3304:5) severity: failed actual : null expected: undefined stack: | TypeError: SourceEditorOverlay is not a constructor at Object.<anonymous> (/src/repo/tests/node-qunit/mobile.editor.overlay/SourceEditorOverlay.test.js:145:24) ... not ok 29 MobileFrontend mobile.editor.overlay/SourceEditorOverlay > #initialize, as anonymous --- message: "beforeEach failed on #initialize, as anonymous: Cannot read properties of undefined (reading 'Overlay')" severity: failed actual : null expected: undefined stack: | TypeError: Cannot read properties of undefined (reading 'Overlay') at Object.<anonymous> (/src/repo/src/mobile.editor.overlay/EditorOverlayBase.js:7:25) at Module._compile (node:internal/modules/cjs/loader:1356:14) at Module.replacementCompile (/src/repo/node_modules/append-transform/index.js:60:13) at Module._compile (/src/repo/node_modules/pirates/lib/index.js:117:24) at Module._extensions..js (node:internal/modules/cjs/loader:1414:10) at newLoader (/src/repo/node_modules/pirates/lib/index.js:121:7) at Object.<anonymous> (/src/repo/node_modules/append-transform/index.js:64:4) at Module.load (node:internal/modules/cjs/loader:1197:32) at Function.Module._load (node:internal/modules/cjs/loader:1013:12) at Module.require (node:internal/modules/cjs/loader:1225:19) at require (node:internal/modules/helpers:177:18) at Object.<anonymous> (/src/repo/src/mobile.editor.overlay/SourceEditorOverlay.js:2:22) at Module._compile (node:internal/modules/cjs/loader:1356:14) at Module.replacementCompile (/src/repo/node_modules/append-transform/index.js:60:13) at Module._compile (/src/repo/node_modules/pirates/lib/index.js:117:24) at Module._extensions..js (node:internal/modules/cjs/loader:1414:10) at newLoader (/src/repo/node_modules/pirates/lib/index.js:121:7) at Object.<anonymous> (/src/repo/node_modules/append-transform/index.js:64:4) at Module.load (node:internal/modules/cjs/loader:1197:32) at Function.Module._load (node:internal/modules/cjs/loader:1013:12) at Module.require (node:internal/modules/cjs/loader:1225:19) at require (node:internal/modules/helpers:177:18) at Object.beforeEach (/src/repo/tests/node-qunit/mobile.editor.overlay/SourceEditorOverlay.test.js:30:25) ... --- message: |+ Died on test #2: SourceEditorOverlay is not a constructor at Object.test (/src/repo/node_modules/qunit/qunit/qunit.js:3304:5) severity: failed actual : null expected: undefined stack: | TypeError: SourceEditorOverlay is not a constructor at Object.<anonymous> (/src/repo/tests/node-qunit/mobile.editor.overlay/SourceEditorOverlay.test.js:158:24) ... not ok 30 MobileFrontend mobile.editor.overlay/blockMessageDrawer > blockMessageDrawer --- message: "beforeEach failed on blockMessageDrawer: Cannot read properties of undefined (reading 'Overlay')" severity: failed actual : null expected: undefined stack: | TypeError: Cannot read properties of undefined (reading 'Overlay') at Object.<anonymous> (/src/repo/src/mobile.editor.overlay/EditorOverlayBase.js:7:25) at Module._compile (node:internal/modules/cjs/loader:1356:14) at Module.replacementCompile (/src/repo/node_modules/append-transform/index.js:60:13) at Module._compile (/src/repo/node_modules/pirates/lib/index.js:117:24) at Module._extensions..js (node:internal/modules/cjs/loader:1414:10) at newLoader (/src/repo/node_modules/pirates/lib/index.js:121:7) at Object.<anonymous> (/src/repo/node_modules/append-transform/index.js:64:4) at Module.load (node:internal/modules/cjs/loader:1197:32) at Function.Module._load (node:internal/modules/cjs/loader:1013:12) at Module.require (node:internal/modules/cjs/loader:1225:19) at require (node:internal/modules/helpers:177:18) at Object.<anonymous> (/src/repo/src/mobile.editor.overlay/SourceEditorOverlay.js:2:22) at Module._compile (node:internal/modules/cjs/loader:1356:14) at Module.replacementCompile (/src/repo/node_modules/append-transform/index.js:60:13) at Module._compile (/src/repo/node_modules/pirates/lib/index.js:117:24) at Module._extensions..js (node:internal/modules/cjs/loader:1414:10) at newLoader (/src/repo/node_modules/pirates/lib/index.js:121:7) at Object.<anonymous> (/src/repo/node_modules/append-transform/index.js:64:4) at Module.load (node:internal/modules/cjs/loader:1197:32) at Function.Module._load (node:internal/modules/cjs/loader:1013:12) at Module.require (node:internal/modules/cjs/loader:1225:19) at require (node:internal/modules/helpers:177:18) at Object.beforeEach (/src/repo/tests/node-qunit/mobile.editor.overlay/blockMessageDrawer.test.js:35:25) ... --- message: "Promise rejected during \"blockMessageDrawer\": blockMessageDrawer is not a function" severity: failed actual : null expected: undefined stack: | TypeError: blockMessageDrawer is not a function at call (/src/repo/tests/node-qunit/mobile.editor.overlay/blockMessageDrawer.test.js:93:17) at s (/src/repo/tests/node-qunit/mobile.editor.overlay/blockMessageDrawer.test.js:2:1) at Generator._invoke (/src/repo/tests/node-qunit/mobile.editor.overlay/blockMessageDrawer.test.js:2:1) at Generator.next (/src/repo/tests/node-qunit/mobile.editor.overlay/blockMessageDrawer.test.js:2:1) at asyncGeneratorStep (/src/repo/tests/node-qunit/mobile.editor.overlay/blockMessageDrawer.test.js:2:1) at _next (/src/repo/tests/node-qunit/mobile.editor.overlay/blockMessageDrawer.test.js:2:1) at /src/repo/tests/node-qunit/mobile.editor.overlay/blockMessageDrawer.test.js:2:1 at new Promise (<anonymous>) at Object.apply (/src/repo/tests/node-qunit/mobile.editor.overlay/blockMessageDrawer.test.js:2:1) at Object.<anonymous> (/src/repo/tests/node-qunit/mobile.editor.overlay/blockMessageDrawer.test.js:109:2) ... ok 31 MobileFrontend mobile.editor.overlay/identifyLeadParagraph > identifyLeadParagraph ok 32 MobileFrontend editorLoadingOverlay.js > editorLoadingOverlay calls the callbacks ok 33 MobileFrontend lazyLoadedImages > initNative ok 34 MobileFrontend LanguageSearcher.js > renders output ok 35 MobileFrontend LanguageSearcher.js > saves the language count when link is clicked ok 36 MobileFrontend LanguageSearcher.js > without variants, input event filters languages ok 37 MobileFrontend LanguageSearcher.js > with variants, input event filters languages ok 38 MobileFrontend mobile.languages.structured/util.test.js > #getFrequentlyUsedLanguages ok 39 MobileFrontend mobile.languages.structured/util.test.js > #saveLanguageUsageCount ok 40 MobileFrontend mobile.languages.structured/util.test.js > #getStructuredLanguages ok 41 MobileFrontend mobile.languages.structured/util.test.js > #getStructuredLanguages device language ok 42 MobileFrontend mobile.languages.structured/util.test.js > #getStructuredLanguages variants ok 43 MobileFrontend mobile.mediaViewer/ImageCarousel.js > Shows details bar and image with successful api response ok 44 MobileFrontend mobile.mediaViewer/ImageCarousel.js > Shows error message with failed api response ok 45 MobileFrontend mobile.mediaViewer/ImageCarousel.js > Toggling of details is disabled when overlay has load failure ok 46 MobileFrontend mobile.mediaViewer/ImageCarousel.js > Toggling of details is enabled when overlay loads successfully ok 47 MobileFrontend mobile.mediaViewer/ImageGateway > #findSizeBucket ok 48 MobileFrontend mobile.mediaViewer/ImageGateway > ImageGateway#getThumb (missing page) ok 49 mobile.special.mobileoptions.scripts > addClientPreferencesToForm (named user) ok 50 MobileFrontend ScrollEndEventEmitter.js > initializes properly ok 51 MobileFrontend ScrollEndEventEmitter.js > emits scroll end event ok 52 MobileFrontend ScrollEndEventEmitter.js > doesn't emit when disabled ok 53 MobileFrontend WatchList.js > In watched mode ok 54 MobileFrontend WatchListGateway.js > loadWatchlist() loads results from the first page ok 55 MobileFrontend WatchListGateway.js > loadWatchlist() loads results from the second page from last item of first ok 56 MobileFrontend WatchListGateway.js > loadWatchlist() doesn't throw an error when no pages are returned ok 57 MobileFrontend WatchListGateway.js > loadWatchlist() marks pages as new if necessary ok 58 MobileFrontend Browser.js > isIos() ok 59 MobileFrontend Browser.js > Methods are cached ok 60 MobileFrontend Browser.js > isWideScreen() ok 61 MobileFrontend Browser.js > supportsTouchEvents() ok 62 MobileFrontend Button.js > creates a link if passed href option ok 63 MobileFrontend Button.js > does not add href attribute when not a link ok 64 MobileFrontend CtaDrawer.js > redirectParams() > empty props, default URL ok 65 MobileFrontend CtaDrawer.js > redirectParams() > empty props, nondefault URL ok 66 MobileFrontend CtaDrawer.js > redirectParams() > nonempty props ok 67 MobileFrontend CtaDrawer.js > signUpParams() > empty props ok 68 MobileFrontend CtaDrawer.js > signUpParams() > nonempty props ok 69 MobileFrontend CtaDrawer.js > HTML > defaults ok 70 MobileFrontend CtaDrawer.js > HTML > overrides ok 71 MobileFrontend Drawer.js > visible on show() ok 72 MobileFrontend Drawer.js > accepts onShow and events ok 73 MobileFrontend Drawer.js > hidden on hide() ok 74 MobileFrontend Drawer.js > hidden on mask click ok 75 MobileFrontend Drawer.js > HTML is valid ok 76 MobileFrontend Icon.js > getIconClasses generates icon classes using icon ok 77 MobileFrontend Icon.js > getIconClasses generates icon classes using custom icon prefix ok 78 MobileFrontend Icon.js > getRotationClasses returns rotation classes ok 79 MobileFrontend Icon.js > getGlyphClassName uses icon prefix ok 80 MobileFrontend Icon.js > getGlyphClassName does not use icon prefix if not provided ok 81 MobileFrontend Icon.js > adds small classes ok 82 MobileFrontend IconButton.js > creates a link if passed href option ok 83 MobileFrontend IconButton.js > does not add href attribute when not a link ok 84 MobileFrontend IconButton.js > adds disabled attribute when a button ok 85 MobileFrontend IconButton.js > does not add disabled attribute when not a button ok 86 MobileFrontend IconButton.js > adds additional classes ok 87 MobileFrontend: Overlay.js > Simple overlay ok 88 MobileFrontend: Overlay.js > #make ok 89 MobileFrontend: Overlay.js > HTML overlay ok 90 MobileFrontend: Overlay.js > headerActions property ok 91 MobileFrontend: Overlay.js > onBeforeExit ok 92 MobileFrontend: Overlay.js > Close overlay ok 93 MobileFrontend mobile.startup/OverlayManager > #getSingleton (hash present and overlay not managed) ok 94 MobileFrontend mobile.startup/OverlayManager > #getSingleton (hash present and overlay managed) ok 95 MobileFrontend mobile.startup/OverlayManager > #getSingleton ok 96 MobileFrontend mobile.startup/OverlayManager > #add ok 97 MobileFrontend mobile.startup/OverlayManager > #show ok 98 MobileFrontend mobile.startup/OverlayManager > #add, with current path ok 99 MobileFrontend mobile.startup/OverlayManager > #add, with string literal (matching) ok 100 MobileFrontend mobile.startup/OverlayManager > #add, with string literal (not matching) ok 101 MobileFrontend mobile.startup/OverlayManager > #replaceCurrent ok 102 MobileFrontend mobile.startup/OverlayManager > route with params ok 103 MobileFrontend mobile.startup/OverlayManager > hide when route changes ok 104 MobileFrontend mobile.startup/OverlayManager > go back (change route) if overlay hidden but not by route change ok 105 MobileFrontend mobile.startup/OverlayManager > go back if overlayManager still matches ok 106 MobileFrontend mobile.startup/OverlayManager > go back if overlayManager still matches (non-regex) ok 107 MobileFrontend mobile.startup/OverlayManager > do not go back (change route) if overlay hidden by change in route ok 108 MobileFrontend mobile.startup/OverlayManager > preventDefault called when you cancel an exit request ok 109 MobileFrontend mobile.startup/OverlayManager > Browser back can be overidden ok 110 MobileFrontend mobile.startup/OverlayManager > stacked overlays ok 111 MobileFrontend mobile.startup/OverlayManager > prevent route change ok 112 MobileFrontend mobile.startup/OverlayManager > stack increases and decreases at right times ok 113 MobileFrontend mobile.startup/OverlayManager > replace overlay when route event path is equal to current path ok 114 MobileFrontend Page.js > #isMainPage ok 115 MobileFrontend PageHTMLParser.js > #findInSectionLead ok 116 MobileFrontend PageHTMLParser.js > #getThumbnail ok 117 MobileFrontend PageHTMLParser.js > #getThumbnails ok 118 MobileFrontend PageHTMLParser.js > #getLanguages ok 119 MobileFrontend PageHTMLParser.js > #getLanguages (no hyphen) ok 120 MobileFrontend PageHTMLParser.js > #getLanguages (T349000) ok 121 MobileFrontend Section.js > initialize with options ok 122 MobileFrontend Section.js > initialize with subsections ok 123 MobileFrontend Toggler.js > Mobile mode - Toggle section ok 124 MobileFrontend Toggler.js > Mobile mode - Clicking a hash link to reveal an already open section ok 125 MobileFrontend Toggler.js > Mobile mode - Reveal element ok 126 MobileFrontend Toggler.js > Mobile mode - Clicking hash links ok 127 MobileFrontend Toggler.js > Mobile mode - Tap event toggles section ok 128 MobileFrontend Toggler.js > Accessibility - Verify ARIA attributes ok 129 MobileFrontend Toggler.js > Tablet mode - Open by default ok 130 MobileFrontend Toggler.js > Tablet mode - Open by default 2 ok 131 MobileFrontend Toggler.js > Accessibility - Pressing space/ enter toggles a heading ok 132 MobileFrontend Toggler.js > Clicking a link within a heading isn't triggering a toggle ok 133 MobileFrontend Toggler.js > MobileFrontend toggle.js - T320753: Presence of class disables toggling. ok 134 MobileFrontend mobile.startup/View > View ok 135 MobileFrontend mobile.startup/View > View, jQuery proxy functions ok 136 MobileFrontend mobile.startup/View > View#preRender ok 137 MobileFrontend mobile.startup/View > View#postRender ok 138 MobileFrontend mobile.startup/View > View#delegateEvents ok 139 MobileFrontend mobile.startup/View > View#render (with isTemplateMode) ok 140 MobileFrontend mobile.startup/View > View#render events (with isTemplateMode) ok 141 MobileFrontend mobile.startup/View > View with className option ok 142 MobileFrontend mobile.startup/View > View.make() ok 143 MobileFrontend amcOutreach/AmcEnableForm.js > renders correctly ok 144 MobileFrontend amcOutreachDrawer.js > returns a drawer ok 145 MobileFrontend amcOutreachDrawer.js > calls promoCampaign.makeActionIneligible and onBeforeHide callback when dismissed ok 146 MobileFrontend amcOutreachDrawer.js > calls promoCampaign.makeActionIneligible and toast.showOnPageReload when user enables ok 147 MobileFrontend cache.js > cache set() and get() ok 148 MobileFrontend extendSearchParams.js > it throws if the feature is invalid ok 149 MobileFrontend extendSearchParams.js > it extends the parameters ok 150 MobileFrontend extendSearchParams.js > it doesn't include Wikibase-specific parameters if the feature is disabled ok 151 MobileFrontend extendSearchParams.js > it adds the MobileFrontend configuration to given terms types ok 152 MobileFrontend extendSearchParams.js > it prioritizes MobileFrontend configuration ok 153 MobileFrontend extendSearchParams.js > it is variadic ok 154 MobileFrontend icons.js > #cancel() ok 155 MobileFrontend icons.js > #cancel(variant) ok 156 MobileFrontend icons.js > #cancel(, props) ok 157 MobileFrontend icons.js > #spinner(props) ok 158 MobileFrontend icons.js > #spinner() ok 159 MobileFrontend getDeviceLanguage > returns language code of device in lowercase ok 160 MobileFrontend languageOverlay.js > #constructor ok 161 MobileFrontend lazyImageLoader.js > #queryPlaceholders() empty ok 162 MobileFrontend lazyImageLoader.js > #queryPlaceholders() nonempty ok 163 MobileFrontend lazyImageLoader.js > #loadImage() copy attributes ok 164 MobileFrontend lazyImageLoader.js > #loadImage() loaded ok 165 MobileFrontend lazyImageLoader.js > #loadImage() load error ok 166 MobileFrontend lazyImageLoader.js > #loadImages() empty ok 167 MobileFrontend lazyImageLoader.js > #loadImages() nonempty ok 168 MobileFrontend lazyImageLoader.js > #loadImages() plural ok 169 MobileFrontend lazyImageLoader.js > #loadImages() one fails to load, one succeeds ok 170 MobileFrontend ModuleLoader > #require ok 171 MobileFrontend ModuleLoader > #define ok 172 MobileFrontend pageJSONParser > .parse() ok 173 MobileFrontend promisedView.js > #constructor happyView ok 174 MobileFrontend promisedView.js > #constructor when promise rejects but not to a sadView ok 175 MobileFrontend promisedView.js > #constructor when promise rejects to a sadView ok 176 MobileFrontend promoCampaign.js > #showIfEligible throws when invalid ok 177 MobileFrontend promoCampaign.js > #showIfEligible when campaign off ok 178 MobileFrontend promoCampaign.js > #showIfEligible when user ineligible ok 179 MobileFrontend promoCampaign.js > #showIfEligible when storage is not available ok 180 MobileFrontend promoCampaign.js > #showIfEligible when storage key is ineligible ok 181 MobileFrontend promoCampaign.js > #showIfEligible when eligible ok 182 MobileFrontend promoCampaign.js > #showIfEligible when eligible and passed additional args ok 183 MobileFrontend promoCampaign.js > #makeActionIneligible when successful ok 184 MobileFrontend promoCampaign.js > #makeActionIneligible when unsuccessful ok 185 MobileFrontend promoCampaign.js > #makeActionIneligible when invalid action ok 186 MobileFrontend promoCampaign.js > #makeAllActionsIneligible ok 187 MobileFrontend promoCampaign.js > #isCampaignActive when true ok 188 MobileFrontend promoCampaign.js > #isCampaignActive when false ok 189 MobileFrontend ReferencesHtmlScraperGateway.test.js > getReference() checking good reference ok 190 MobileFrontend ReferencesHtmlScraperGateway.test.js > getReference() checking bad reference ok 191 MobileFrontend ReferencesHtmlScraperGateway.test.js > getReference() adds an extra class for external links ok 192 MobileFrontend: references > Bad reference not shown ok 193 MobileFrontend: references > Good reference causes render ok 194 MobileFrontend: references > Reference failure renders error in drawer ok 195 MobileFrontend: references > makeOnNestedReferenceClickHandler runs when associated with link ok 196 MobileFrontend: SearchGateway > ._highlightSearchTerm ok 197 MobileFrontend: SearchGateway > show redirect targets ok 198 MobileFrontend: SearchGateway > MobileFrontend SearchGateway (Wikidata Descriptions) > Wikidata Description in search results ok 199 MobileFrontend mobile.startup/SearchOverlay.js > renders correctly ok 200 MobileFrontend mobile.startup/SearchOverlay.js > resetSearch ok 201 MobileFrontend mobile.startup/SearchOverlay.js > onClickOverlayContent ok 202 MobileFrontend mobile.startup/SearchResultsView.js > renders correctly ok 203 MobileFrontend sectionCollapsing.js > init() - article pages ok 204 MobileFrontend sectionCollapsing.js > init() - article pages on tablet page ok 205 MobileFrontend sectionCollapsing.js > init() - talk pages ok 206 MobileFrontend time.js > timeAgo() ok 207 MobileFrontend util.js > Promise.all() success ok 208 MobileFrontend util.js > Promise.all() reject ok 209 MobileFrontend util.js > escapeSelector() ok 210 MobileFrontend util.js > docReady() ok 211 MobileFrontend util.js > Deferred() - resolve ok 212 MobileFrontend util.js > Deferred() - reject ok 213 MobileFrontend util.js > getDocument() ok 214 MobileFrontend util.js > getWindow() ok 215 MobileFrontend util.js > parseHTML() ok 216 MobileFrontend util.js > extend() ok 217 MobileFrontend Watchstar.js > Render a watchstar ok 218 MobileFrontend: WatchstarGateway.js > getStatuses(nonempty) ok 219 MobileFrontend: WatchstarGateway.js > getStatuses(empty) ok 220 MobileFrontend: WatchstarGateway.js > getStatusesByID(nonempty) ok 221 MobileFrontend: WatchstarGateway.js > getStatusesByID(empty) ok 222 MobileFrontend: WatchstarGateway.js > getStatusesByTitle(nonempty) ok 223 MobileFrontend: WatchstarGateway.js > getStatusesByTitle(empty) ok 224 MobileFrontend: WatchstarGateway.js > _unmarshalGetResponse(nonempty) ok 225 MobileFrontend: WatchstarGateway.js > _unmarshalGetResponse(empty) ok 226 MobileFrontend mobile.startup/WatchstarPageList > Watchlist status check if no ids ok 227 MobileFrontend mobile.startup/WatchstarPageList > Checks watchlist status once 1..227 # pass 198 # skip 0 # todo 0 # fail 29 ----------------------------------|---------|----------|---------|---------|------------------------ File | % Stmts | % Branch | % Funcs | % Lines | Uncovered Line #s ----------------------------------|---------|----------|---------|---------|------------------------ All files | 55.77 | 43.53 | 52.02 | 55.74 | mobile.editor.overlay | 7.87 | 4.38 | 5.19 | 7.81 | BlockMessageDetails.js | 3.63 | 0 | 0 | 3.7 | 4-210 EditorGateway.js | 30.68 | 16.66 | 31.25 | 31.03 | ...1,80,97-228,260-293 EditorOverlayBase.js | 1.19 | 0 | 0 | 1.19 | 10-790 SourceEditorOverlay.js | 0.99 | 0 | 0 | 0.99 | 3-594 VisualEditorOverlay.js | 1.8 | 0 | 0 | 1.8 | 4-328 blockMessageDrawer.js | 2.94 | 0 | 0 | 3.12 | 2-93 identifyLeadParagraph.js | 94.11 | 83.33 | 100 | 93.75 | 23 parseBlockInfo.js | 8.69 | 0 | 0 | 9.09 | 8-64 saveFailureMessage.js | 11.11 | 0 | 0 | 11.11 | 12-28 setPreferredEditor.js | 20 | 0 | 0 | 20 | 7-12 mobile.init | 17.56 | 1.33 | 11.11 | 17.56 | editor.js | 6.7 | 0 | 0 | 6.7 | 33-576,580-587 editorLoadingOverlay.js | 69.69 | 50 | 62.5 | 69.69 | 38,43,59-74 fakeToolbar.js | 100 | 100 | 100 | 100 | lazyLoadedImages.js | 21.42 | 0 | 10 | 21.42 | 18-87,99-100,104 toggling.js | 5.55 | 0 | 0 | 5.55 | 3-54 mobile.languages.structured | 89.38 | 81.66 | 87.5 | 89.28 | LanguageSearcher.js | 89.79 | 95 | 81.81 | 89.79 | 149-156 mobile.languages.structured.js | 100 | 100 | 100 | 100 | rtlLanguages.js | 100 | 100 | 100 | 100 | util.js | 88.33 | 75 | 92.3 | 88.13 | 48,65,137-139,170,180 mobile.mediaViewer | 80.29 | 52 | 80 | 80.88 | ImageCarousel.js | 77.35 | 41.66 | 75 | 78.09 | ...278,324-325,332,351 ImageGateway.js | 94.73 | 78.57 | 100 | 94.73 | 44 LoadErrorMessage.js | 83.33 | 100 | 83.33 | 83.33 | 73-75 mobile.special.watchlist.scripts | 81.81 | 72.72 | 72 | 81.39 | ScrollEndEventEmitter.js | 79.31 | 60 | 88.88 | 78.57 | 116-122 WatchList.js | 70 | 50 | 45.45 | 70 | 37,41,85-114 WatchListGateway.js | 96.55 | 87.5 | 100 | 96.42 | 51 mobile.startup | 82.67 | 73.83 | 73.6 | 82.75 | Anchor.js | 100 | 100 | 100 | 100 | Browser.js | 96.77 | 93.75 | 100 | 96.66 | 70 Button.js | 90.47 | 75 | 100 | 90.47 | 69,76 CtaDrawer.js | 100 | 100 | 100 | 100 | Drawer.js | 100 | 100 | 91.66 | 100 | Icon.js | 94.59 | 87.5 | 100 | 94.59 | 44-46 IconButton.js | 100 | 87.5 | 100 | 100 | 52-55 LanguageInfo.js | 15.78 | 0 | 0 | 16.66 | 14-61 MessageBox.js | 42.85 | 100 | 0 | 42.85 | 13-36 Overlay.js | 82.14 | 70 | 63.15 | 82.14 | ...119,221-222,250-263 OverlayManager.js | 98.07 | 94.73 | 95.23 | 98.97 | 46 Page.js | 38.46 | 62.85 | 33.33 | 38.46 | 83-127,146-155,174-181 PageHTMLParser.js | 95.38 | 95.55 | 92.3 | 95.31 | 43,88,231 PageList.js | 100 | 50 | 100 | 100 | 52 Section.js | 100 | 100 | 100 | 100 | Skin.js | 20 | 0 | 0 | 20 | 24-116,126-133 Thumbnail.js | 87.5 | 100 | 80 | 87.5 | 44 Toggler.js | 85.26 | 67.3 | 80 | 86.17 | ...231,256-262,280,304 View.js | 91.42 | 78.57 | 86.95 | 91.3 | 196-199,338,515-516 actionParams.js | 100 | 50 | 100 | 100 | 17 cache.js | 100 | 100 | 50 | 100 | currentPage.js | 18.18 | 0 | 0 | 18.18 | 17-44 currentPageHTMLParser.js | 83.33 | 50 | 100 | 83.33 | 19 eventBusSingleton.js | 100 | 100 | 100 | 100 | extendSearchParams.js | 94.44 | 70 | 100 | 94.44 | 67 headers.js | 90.9 | 100 | 66.66 | 90.9 | 90-114 icons.js | 96.15 | 81.25 | 83.33 | 96.15 | 31 isCollapsedByDefault.js | 100 | 100 | 100 | 100 | loadingOverlay.js | 50 | 100 | 0 | 50 | 13-18 mobile.startup.js | 83.33 | 100 | 0 | 83.33 | 123-230 moduleLoader.js | 71.42 | 50 | 66.66 | 71.42 | 41-43,70-90 moduleLoaderSingleton.js | 100 | 100 | 100 | 100 | promisedView.js | 100 | 100 | 100 | 100 | sectionCollapsing.js | 100 | 100 | 100 | 100 | showOnPageReload.js | 41.66 | 25 | 50 | 41.66 | 14-16,39-46 time.js | 24.24 | 9.09 | 16.66 | 24.24 | 32-144 util.js | 94.11 | 66.66 | 92.3 | 94.11 | 17 mobile.startup/amcOutreach | 84.84 | 50 | 77.77 | 84.84 | AmcEnableForm.js | 100 | 100 | 100 | 100 | amcOutreach.js | 61.53 | 0 | 0 | 61.53 | 51-92 amcOutreachDrawer.js | 100 | 100 | 100 | 100 | mobile.startup/languageOverlay | 79.31 | 100 | 54.54 | 81.48 | getDeviceLanguage.js | 100 | 100 | 100 | 100 | languageInfoOverlay.js | 54.54 | 100 | 0 | 60 | 15-39 languageOverlay.js | 93.33 | 100 | 83.33 | 92.85 | 33 mobile.startup/lazyImages | 93.75 | 85 | 100 | 93.75 | lazyImageLoader.js | 93.75 | 85 | 100 | 93.75 | 63,70 mobile.startup/mediaViewer | 63.63 | 100 | 0 | 63.63 | overlay.js | 63.63 | 100 | 0 | 63.63 | 22-39 mobile.startup/page | 100 | 87.5 | 100 | 100 | pageJSONParser.js | 100 | 87.5 | 100 | 100 | 19 mobile.startup/promoCampaign | 100 | 100 | 100 | 100 | promoCampaign.js | 100 | 100 | 100 | 100 | mobile.startup/references | 82.75 | 75 | 73.33 | 82.75 | ReferencesGateway.js | 100 | 100 | 50 | 100 | ReferencesHtmlScraperGateway.js | 94.73 | 87.5 | 100 | 94.73 | 38 references.js | 74.28 | 68.75 | 66.66 | 74.28 | 56,69,136-149 mobile.startup/search | 60.11 | 29.62 | 54.34 | 60 | SearchGateway.js | 91.3 | 50 | 84.61 | 90.9 | 54-55,161,169 SearchHeaderView.js | 57.14 | 0 | 66.66 | 57.14 | 31-36,68-73 SearchOverlay.js | 34.09 | 14.7 | 22.72 | 34.48 | ...180,187-190,202-288 SearchResultsView.js | 100 | 100 | 100 | 100 | searchHeader.js | 100 | 100 | 100 | 100 | mobile.startup/watchstar | 88.88 | 69.23 | 91.66 | 88.88 | WatchstarGateway.js | 81.81 | 80 | 90 | 81.81 | 105-112 WatchstarPageList.js | 95 | 75 | 100 | 95 | 93,122 watchstar.js | 84.21 | 50 | 50 | 84.21 | 27-30 ----------------------------------|---------|----------|---------|---------|------------------------ --- end --- Traceback (most recent call last): File "/venv/lib/python3.11/site-packages/runner-0.1.0-py3.11.egg/runner/__init__.py", line 2026, in main libup.run(args.repo, args.output, args.branch) File "/venv/lib/python3.11/site-packages/runner-0.1.0-py3.11.egg/runner/__init__.py", line 1968, in run self.npm_audit_fix(new_npm_audit) File "/venv/lib/python3.11/site-packages/runner-0.1.0-py3.11.egg/runner/__init__.py", line 275, in npm_audit_fix self.npm_test() File "/venv/lib/python3.11/site-packages/runner-0.1.0-py3.11.egg/runner/__init__.py", line 325, in npm_test self.check_call(["npm", "test"]) File "/venv/lib/python3.11/site-packages/runner-0.1.0-py3.11.egg/runner/shell2.py", line 59, in check_call res.check_returncode() File "/usr/lib/python3.11/subprocess.py", line 502, in check_returncode raise CalledProcessError(self.returncode, self.args, self.stdout, subprocess.CalledProcessError: Command '['/usr/bin/npm', 'test']' returned non-zero exit status 1.