mediawiki/extensions/GuidedTour: main (log #2503789)

sourcepatches

This run took 100 seconds.

$ date
--- stdout ---
Sun Jun 14 09:01:51 UTC 2026

--- end ---
$ git clone file:///srv/git/mediawiki-extensions-GuidedTour.git /src/repo --depth=1 -b master
--- stderr ---
Cloning into '/src/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/master
--- stdout ---
8322e0fe58f9368b7de5ab63ddd847365db047b8 refs/heads/master

--- end ---
$ /usr/bin/npm audit --json
--- stdout ---
{
  "auditReportVersion": 2,
  "vulnerabilities": {
    "@cypress/request": {
      "name": "@cypress/request",
      "severity": "moderate",
      "isDirect": false,
      "via": [
        "qs",
        "uuid"
      ],
      "effects": [
        "cypress"
      ],
      "range": "<=4.0.0",
      "nodes": [
        "node_modules/@cypress/request"
      ],
      "fixAvailable": true
    },
    "cypress": {
      "name": "cypress",
      "severity": "moderate",
      "isDirect": true,
      "via": [
        "@cypress/request"
      ],
      "effects": [],
      "range": "13.15.0 - 15.14.2",
      "nodes": [
        "node_modules/cypress"
      ],
      "fixAvailable": true
    },
    "qs": {
      "name": "qs",
      "severity": "moderate",
      "isDirect": false,
      "via": [
        {
          "source": 1119502,
          "name": "qs",
          "dependency": "qs",
          "title": "qs has a remotely triggerable DoS: qs.stringify crashes with TypeError on null/undefined entries in comma-format arrays when encodeValuesOnly is set",
          "url": "https://github.com/advisories/GHSA-q8mj-m7cp-5q26",
          "severity": "moderate",
          "cwe": [
            "CWE-476"
          ],
          "cvss": {
            "score": 5.3,
            "vectorString": "CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:N/I:N/A:L"
          },
          "range": ">=6.11.1 <=6.15.1"
        }
      ],
      "effects": [
        "@cypress/request"
      ],
      "range": "6.11.1 - 6.15.1",
      "nodes": [
        "node_modules/qs"
      ],
      "fixAvailable": true
    },
    "shell-quote": {
      "name": "shell-quote",
      "severity": "critical",
      "isDirect": false,
      "via": [
        {
          "source": 1120422,
          "name": "shell-quote",
          "dependency": "shell-quote",
          "title": "shell-quote quote() does not escape newlines in object .op values",
          "url": "https://github.com/advisories/GHSA-w7jw-789q-3m8p",
          "severity": "critical",
          "cwe": [
            "CWE-77",
            "CWE-78"
          ],
          "cvss": {
            "score": 8.1,
            "vectorString": "CVSS:3.1/AV:N/AC:H/PR:N/UI:N/S:U/C:H/I:H/A:H"
          },
          "range": ">=1.1.0 <=1.8.3"
        }
      ],
      "effects": [],
      "range": "1.1.0 - 1.8.3",
      "nodes": [
        "node_modules/shell-quote"
      ],
      "fixAvailable": true
    },
    "tmp": {
      "name": "tmp",
      "severity": "high",
      "isDirect": false,
      "via": [
        {
          "source": 1120654,
          "name": "tmp",
          "dependency": "tmp",
          "title": "tmp has Path Traversal via unsanitized prefix/postfix that enables directory escape",
          "url": "https://github.com/advisories/GHSA-ph9p-34f9-6g65",
          "severity": "high",
          "cwe": [
            "CWE-22"
          ],
          "cvss": {
            "score": 0,
            "vectorString": null
          },
          "range": "<0.2.6"
        }
      ],
      "effects": [],
      "range": "<0.2.6",
      "nodes": [
        "node_modules/tmp"
      ],
      "fixAvailable": true
    },
    "uuid": {
      "name": "uuid",
      "severity": "moderate",
      "isDirect": false,
      "via": [
        {
          "source": 1119441,
          "name": "uuid",
          "dependency": "uuid",
          "title": "uuid: Missing buffer bounds check in v3/v5/v6 when buf is provided",
          "url": "https://github.com/advisories/GHSA-w5hq-g745-h8pq",
          "severity": "moderate",
          "cwe": [
            "CWE-787",
            "CWE-1285"
          ],
          "cvss": {
            "score": 7.5,
            "vectorString": "CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:N/I:H/A:N"
          },
          "range": "<11.1.1"
        }
      ],
      "effects": [
        "@cypress/request"
      ],
      "range": "<11.1.1",
      "nodes": [
        "node_modules/uuid"
      ],
      "fixAvailable": true
    }
  },
  "metadata": {
    "vulnerabilities": {
      "info": 0,
      "low": 0,
      "moderate": 4,
      "high": 1,
      "critical": 1,
      "total": 6
    },
    "dependencies": {
      "prod": 1,
      "dev": 733,
      "optional": 4,
      "peer": 0,
      "peerOptional": 0,
      "total": 733
    }
  }
}

--- 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.4.0)
  - Locking composer/semver (3.4.4)
  - Locking composer/spdx-licenses (1.6.0)
  - Locking composer/xdebug-handler (3.0.5)
  - Locking danog/advanced-json-rpc (v3.2.3)
  - Locking dealerdirect/phpcodesniffer-composer-installer (v1.2.1)
  - Locking doctrine/deprecations (1.1.6)
  - Locking mediawiki/mediawiki-codesniffer (v51.0.0)
  - Locking mediawiki/mediawiki-phan-config (0.20.0)
  - Locking mediawiki/minus-x (2.0.1)
  - Locking mediawiki/phan-taint-check-plugin (9.1.0)
  - Locking netresearch/jsonmapper (v5.0.1)
  - Locking phan/phan (6.0.2)
  - Locking phan/tolerant-php-parser (v0.2.0)
  - Locking phan/var_representation_polyfill (0.1.4)
  - 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.5.0)
  - Locking phpcsstandards/phpcsutils (1.2.2)
  - Locking phpdocumentor/reflection-common (2.2.0)
  - Locking phpdocumentor/reflection-docblock (6.0.3)
  - Locking phpdocumentor/type-resolver (2.0.0)
  - Locking phpstan/phpdoc-parser (2.3.2)
  - Locking psr/container (2.0.2)
  - Locking psr/log (3.0.2)
  - Locking sabre/event (6.1.0)
  - Locking squizlabs/php_codesniffer (3.13.5)
  - Locking symfony/console (v8.1.0)
  - Locking symfony/deprecation-contracts (v3.7.0)
  - Locking symfony/polyfill-ctype (v1.37.0)
  - Locking symfony/polyfill-intl-grapheme (v1.38.1)
  - Locking symfony/polyfill-intl-normalizer (v1.38.0)
  - Locking symfony/polyfill-mbstring (v1.38.2)
  - Locking symfony/polyfill-php85 (v1.38.1)
  - Locking symfony/service-contracts (v3.7.0)
  - Locking symfony/string (v8.1.0)
  - Locking webmozart/assert (2.4.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.13.5): Extracting archive
  - Installing dealerdirect/phpcodesniffer-composer-installer (v1.2.1): Extracting archive
  - Installing composer/pcre (3.4.0): Extracting archive
  - Installing phpcsstandards/phpcsutils (1.2.2): Extracting archive
  - Installing phpcsstandards/phpcsextra (1.5.0): Extracting archive
  - Installing symfony/polyfill-mbstring (v1.38.2): Extracting archive
  - Installing composer/spdx-licenses (1.6.0): Extracting archive
  - Installing composer/semver (3.4.4): Extracting archive
  - Installing mediawiki/mediawiki-codesniffer (v51.0.0): Extracting archive
  - Installing symfony/polyfill-intl-normalizer (v1.38.0): Extracting archive
  - Installing symfony/polyfill-intl-grapheme (v1.38.1): Extracting archive
  - Installing symfony/polyfill-ctype (v1.37.0): Extracting archive
  - Installing symfony/string (v8.1.0): Extracting archive
  - Installing symfony/deprecation-contracts (v3.7.0): Extracting archive
  - Installing psr/container (2.0.2): Extracting archive
  - Installing symfony/service-contracts (v3.7.0): Extracting archive
  - Installing symfony/polyfill-php85 (v1.38.1): Extracting archive
  - Installing symfony/console (v8.1.0): Extracting archive
  - Installing sabre/event (6.1.0): Extracting archive
  - Installing phan/var_representation_polyfill (0.1.4): Extracting archive
  - Installing phan/tolerant-php-parser (v0.2.0): Extracting archive
  - Installing netresearch/jsonmapper (v5.0.1): Extracting archive
  - Installing webmozart/assert (2.4.0): Extracting archive
  - Installing phpstan/phpdoc-parser (2.3.2): Extracting archive
  - Installing phpdocumentor/reflection-common (2.2.0): Extracting archive
  - Installing doctrine/deprecations (1.1.6): Extracting archive
  - Installing phpdocumentor/type-resolver (2.0.0): Extracting archive
  - Installing phpdocumentor/reflection-docblock (6.0.3): Extracting archive
  - Installing danog/advanced-json-rpc (v3.2.3): Extracting archive
  - Installing psr/log (3.0.2): Extracting archive
  - Installing composer/xdebug-handler (3.0.5): Extracting archive
  - Installing phan/phan (6.0.2): Extracting archive
  - Installing mediawiki/phan-taint-check-plugin (9.1.0): Extracting archive
  - Installing mediawiki/mediawiki-phan-config (0.20.0): Extracting archive
  - Installing mediawiki/minus-x (2.0.1): 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%
 27/36 [=====================>------]  75%
 35/36 [===========================>]  97%
 36/36 [============================] 100%
1 package suggestions were added by new dependencies, use `composer suggest` to see details.
Generating autoload files
17 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 ---
Upgrading n:stylelint-config-wikimedia from 0.18.0 -> 0.19.2
Upgrading n:jsdoc-wmf-theme from 1.2.0 -> 1.3.0
$ /usr/bin/npm install
--- stderr ---
npm WARN EBADENGINE Unsupported engine {
npm WARN EBADENGINE   package: '@wikimedia/codex-design-tokens@2.5.1',
npm WARN EBADENGINE   required: { npm: '>=10.8.1', node: '>=20.20.2' },
npm WARN EBADENGINE   current: { node: 'v20.19.2', npm: '9.2.0' }
npm WARN EBADENGINE }
npm WARN deprecated @humanwhocodes/config-array@0.13.0: Use @eslint/config-array instead
npm WARN deprecated @humanwhocodes/object-schema@2.0.3: Use @eslint/object-schema instead
npm WARN deprecated eslint@8.57.1: This version is no longer supported. Please see https://eslint.org/version-support for other options.
--- stdout ---

added 759 packages, and audited 760 packages in 33s

229 packages are looking for funding
  run `npm fund` for details

6 vulnerabilities (4 moderate, 1 high, 1 critical)

To address all issues, run:
  npm audit fix

Run `npm audit` for details.

--- end ---
$ package-lock-lint /src/repo/package-lock.json
--- stdout ---
Checking /src/repo/package-lock.json

--- end ---
$ ./node_modules/.bin/stylelint modules/ext.guidedTour.vector.less modules/ext.guidedTour.animations.less modules/ext.guidedTour.less modules/ext.guidedTour.monobook.less --fix
--- stderr ---
modules/ext.guidedTour.vector.less
  1:1  ✖  Unknown rule property-no-deprecated                    property-no-deprecated
  1:1  ✖  Unknown rule media-type-no-deprecated                  media-type-no-deprecated
  1:1  ✖  Unknown rule nesting-selector-no-missing-scoping-root  nesting-selector-no-missing-scoping-root
  1:1  ✖  Unknown rule no-invalid-position-declaration           no-invalid-position-declaration

modules/ext.guidedTour.animations.less
  1:1  ✖  Unknown rule property-no-deprecated                    property-no-deprecated
  1:1  ✖  Unknown rule media-type-no-deprecated                  media-type-no-deprecated
  1:1  ✖  Unknown rule nesting-selector-no-missing-scoping-root  nesting-selector-no-missing-scoping-root
  1:1  ✖  Unknown rule no-invalid-position-declaration           no-invalid-position-declaration

modules/ext.guidedTour.less
  1:1  ✖  Unknown rule property-no-deprecated                    property-no-deprecated
  1:1  ✖  Unknown rule media-type-no-deprecated                  media-type-no-deprecated
  1:1  ✖  Unknown rule nesting-selector-no-missing-scoping-root  nesting-selector-no-missing-scoping-root
  1:1  ✖  Unknown rule no-invalid-position-declaration           no-invalid-position-declaration

modules/ext.guidedTour.monobook.less
  1:1  ✖  Unknown rule property-no-deprecated                    property-no-deprecated
  1:1  ✖  Unknown rule media-type-no-deprecated                  media-type-no-deprecated
  1:1  ✖  Unknown rule nesting-selector-no-missing-scoping-root  nesting-selector-no-missing-scoping-root
  1:1  ✖  Unknown rule no-invalid-position-declaration           no-invalid-position-declaration

✖ 16 problems (16 errors, 0 warnings)
--- stdout ---

--- end ---
$ ./node_modules/.bin/stylelint modules/ext.guidedTour.vector.less modules/ext.guidedTour.animations.less modules/ext.guidedTour.less modules/ext.guidedTour.monobook.less -f json
--- stdout ---
[{"source":"/src/repo/modules/ext.guidedTour.vector.less","deprecations":[],"invalidOptionWarnings":[],"parseErrors":[],"errored":true,"warnings":[{"line":1,"column":1,"endLine":4,"endColumn":2,"rule":"property-no-deprecated","severity":"error","text":"Unknown rule property-no-deprecated."},{"line":1,"column":1,"endLine":4,"endColumn":2,"rule":"media-type-no-deprecated","severity":"error","text":"Unknown rule media-type-no-deprecated."},{"line":1,"column":1,"endLine":4,"endColumn":2,"rule":"nesting-selector-no-missing-scoping-root","severity":"error","text":"Unknown rule nesting-selector-no-missing-scoping-root."},{"line":1,"column":1,"endLine":4,"endColumn":2,"rule":"no-invalid-position-declaration","severity":"error","text":"Unknown rule no-invalid-position-declaration."}]},{"source":"/src/repo/modules/ext.guidedTour.animations.less","deprecations":[],"invalidOptionWarnings":[],"parseErrors":[],"errored":true,"warnings":[{"line":1,"column":1,"endLine":102,"endColumn":2,"rule":"property-no-deprecated","severity":"error","text":"Unknown rule property-no-deprecated."},{"line":1,"column":1,"endLine":102,"endColumn":2,"rule":"media-type-no-deprecated","severity":"error","text":"Unknown rule media-type-no-deprecated."},{"line":1,"column":1,"endLine":102,"endColumn":2,"rule":"nesting-selector-no-missing-scoping-root","severity":"error","text":"Unknown rule nesting-selector-no-missing-scoping-root."},{"line":1,"column":1,"endLine":102,"endColumn":2,"rule":"no-invalid-position-declaration","severity":"error","text":"Unknown rule no-invalid-position-declaration."}]},{"source":"/src/repo/modules/ext.guidedTour.less","deprecations":[],"invalidOptionWarnings":[],"parseErrors":[],"errored":true,"warnings":[{"line":1,"column":1,"endLine":198,"endColumn":2,"rule":"property-no-deprecated","severity":"error","text":"Unknown rule property-no-deprecated."},{"line":1,"column":1,"endLine":198,"endColumn":2,"rule":"media-type-no-deprecated","severity":"error","text":"Unknown rule media-type-no-deprecated."},{"line":1,"column":1,"endLine":198,"endColumn":2,"rule":"nesting-selector-no-missing-scoping-root","severity":"error","text":"Unknown rule nesting-selector-no-missing-scoping-root."},{"line":1,"column":1,"endLine":198,"endColumn":2,"rule":"no-invalid-position-declaration","severity":"error","text":"Unknown rule no-invalid-position-declaration."}]},{"source":"/src/repo/modules/ext.guidedTour.monobook.less","deprecations":[],"invalidOptionWarnings":[],"parseErrors":[],"errored":true,"warnings":[{"line":1,"column":1,"endLine":6,"endColumn":2,"rule":"property-no-deprecated","severity":"error","text":"Unknown rule property-no-deprecated."},{"line":1,"column":1,"endLine":6,"endColumn":2,"rule":"media-type-no-deprecated","severity":"error","text":"Unknown rule media-type-no-deprecated."},{"line":1,"column":1,"endLine":6,"endColumn":2,"rule":"nesting-selector-no-missing-scoping-root","severity":"error","text":"Unknown rule nesting-selector-no-missing-scoping-root."},{"line":1,"column":1,"endLine":6,"endColumn":2,"rule":"no-invalid-position-declaration","severity":"error","text":"Unknown rule no-invalid-position-declaration."}]}]
--- end ---
$ /usr/bin/npm ci
--- stderr ---
npm WARN EBADENGINE Unsupported engine {
npm WARN EBADENGINE   package: '@wikimedia/codex-design-tokens@2.5.1',
npm WARN EBADENGINE   required: { node: '>=20.20.2', npm: '>=10.8.1' },
npm WARN EBADENGINE   current: { node: 'v20.19.2', npm: '9.2.0' }
npm WARN EBADENGINE }
npm WARN deprecated @humanwhocodes/config-array@0.13.0: Use @eslint/config-array instead
npm WARN deprecated @humanwhocodes/object-schema@2.0.3: Use @eslint/object-schema instead
npm WARN deprecated eslint@8.57.1: This version is no longer supported. Please see https://eslint.org/version-support for other options.
--- stdout ---

added 759 packages, and audited 760 packages in 12s

229 packages are looking for funding
  run `npm fund` for details

6 vulnerabilities (4 moderate, 1 high, 1 critical)

To address all issues, run:
  npm audit fix

Run `npm audit` for details.

--- end ---
$ /usr/bin/npm test
--- stderr ---
modules/ext.guidedTour.animations.less
  1:1  ✖  Unknown rule property-no-deprecated                    property-no-deprecated
  1:1  ✖  Unknown rule media-type-no-deprecated                  media-type-no-deprecated
  1:1  ✖  Unknown rule nesting-selector-no-missing-scoping-root  nesting-selector-no-missing-scoping-root
  1:1  ✖  Unknown rule no-invalid-position-declaration           no-invalid-position-declaration

modules/ext.guidedTour.less
  1:1  ✖  Unknown rule property-no-deprecated                    property-no-deprecated
  1:1  ✖  Unknown rule media-type-no-deprecated                  media-type-no-deprecated
  1:1  ✖  Unknown rule nesting-selector-no-missing-scoping-root  nesting-selector-no-missing-scoping-root
  1:1  ✖  Unknown rule no-invalid-position-declaration           no-invalid-position-declaration

modules/ext.guidedTour.monobook.less
  1:1  ✖  Unknown rule property-no-deprecated                    property-no-deprecated
  1:1  ✖  Unknown rule media-type-no-deprecated                  media-type-no-deprecated
  1:1  ✖  Unknown rule nesting-selector-no-missing-scoping-root  nesting-selector-no-missing-scoping-root
  1:1  ✖  Unknown rule no-invalid-position-declaration           no-invalid-position-declaration

modules/ext.guidedTour.vector.less
  1:1  ✖  Unknown rule property-no-deprecated                    property-no-deprecated
  1:1  ✖  Unknown rule media-type-no-deprecated                  media-type-no-deprecated
  1:1  ✖  Unknown rule nesting-selector-no-missing-scoping-root  nesting-selector-no-missing-scoping-root
  1:1  ✖  Unknown rule no-invalid-position-declaration           no-invalid-position-declaration

✖ 16 problems (16 errors, 0 warnings)

ERROR: "test:stylelint" exited with 2.
--- stdout ---

> test
> npm-run-all test:* && npm run doc


> test:types
> tsc --noEmit -p cypress/tsconfig.json


> test:eslint
> eslint --cache .


/src/repo/modules/ext.guidedTour.lib/ext.guidedTour.lib.Tour.js
  191:20  warning  Where possible, maintain application state in JS to avoid slower DOM queries  no-jquery/no-class-state

/src/repo/modules/ext.guidedTour.lib/ext.guidedTour.lib.TransitionEvent.js
  4:1  warning  Invalid JSDoc tag name "alternateClassName"  jsdoc/check-tag-names

/src/repo/modules/ext.guidedTour.lib/ext.guidedTour.lib.main.js
  285:3  warning  Found more than one @return declaration  jsdoc/require-returns
  285:3  warning  Found more than one @return declaration  jsdoc/require-returns-check

/src/repo/modules/mediawiki.libs.guiders/mediawiki.libs.guiders.js
  386:17  warning  Positional selector extensions are not allowed  no-jquery/no-sizzle
  445:17  warning  Positional selector extensions are not allowed  no-jquery/no-sizzle
  744:3   warning  Selector extensions are not allowed             no-jquery/no-sizzle

✖ 7 problems (0 errors, 7 warnings)


> test:stylelint
> stylelint --cache "**/*.{vue,less}"


--- end ---
Traceback (most recent call last):
  File "/venv/lib/python3.13/site-packages/runner/__init__.py", line 1268, in main
    libup.run()
    ~~~~~~~~~^^
  File "/venv/lib/python3.13/site-packages/runner/__init__.py", line 1202, in run
    self.npm_upgrade(plan)
    ~~~~~~~~~~~~~~~~^^^^^^
  File "/venv/lib/python3.13/site-packages/runner/__init__.py", line 1064, in npm_upgrade
    self.npm_test()
    ~~~~~~~~~~~~~^^
  File "/venv/lib/python3.13/site-packages/runner/__init__.py", line 289, in npm_test
    self.check_call(["npm", "test"])
    ~~~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^
  File "/venv/lib/python3.13/site-packages/runner/shell2.py", line 66, in check_call
    res.check_returncode()
    ~~~~~~~~~~~~~~~~~~~~^^
  File "/usr/lib/python3.13/subprocess.py", line 508, in check_returncode
    raise CalledProcessError(self.returncode, self.args, self.stdout,
                             self.stderr)
subprocess.CalledProcessError: Command '['/usr/bin/npm', 'test']' returned non-zero exit status 1.
Source code is licensed under the AGPL.