mediawiki/extensions/WikiLambda: main (log #2093175)

sourcepatches

This run took 1969 seconds.

$ date
--- stdout ---
Sun Sep  7 16:41:06 UTC 2025

--- end ---
$ git clone file:///srv/git/mediawiki-extensions-WikiLambda.git repo --depth=1 -b master
--- 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
--- stderr ---
Submodule 'function-schemata' (https://gitlab.wikimedia.org/repos/abstract-wiki/wikifunctions/function-schemata.git) registered for path 'function-schemata'
Cloning into '/src/repo/function-schemata'...
--- stdout ---
Submodule path 'function-schemata': checked out '4df73e6a741e8b723011df88ae0ed9ba9307a146'

--- end ---
$ grr init
--- stdout ---
Installed commit-msg hook.

--- end ---
$ git show-ref refs/heads/master
--- stdout ---
9deac3453b39921a3210054b71f649952da1ed3a refs/heads/master

--- end ---
$ /usr/bin/npm audit --json
--- stdout ---
{
  "auditReportVersion": 2,
  "vulnerabilities": {
    "@wdio/cli": {
      "name": "@wdio/cli",
      "severity": "high",
      "isDirect": true,
      "via": [
        "inquirer",
        "webdriverio",
        "yarn-install"
      ],
      "effects": [
        "@wdio/junit-reporter",
        "@wdio/local-runner",
        "@wdio/spec-reporter"
      ],
      "range": "<=9.0.0-alpha.426",
      "nodes": [
        "node_modules/@wdio/cli"
      ],
      "fixAvailable": {
        "name": "@wdio/cli",
        "version": "9.19.2",
        "isSemVerMajor": true
      }
    },
    "@wdio/junit-reporter": {
      "name": "@wdio/junit-reporter",
      "severity": "high",
      "isDirect": true,
      "via": [
        "@wdio/cli"
      ],
      "effects": [],
      "range": "6.0.4 - 8.0.0-alpha.631",
      "nodes": [
        "node_modules/@wdio/junit-reporter"
      ],
      "fixAvailable": {
        "name": "@wdio/junit-reporter",
        "version": "9.19.2",
        "isSemVerMajor": true
      }
    },
    "@wdio/local-runner": {
      "name": "@wdio/local-runner",
      "severity": "high",
      "isDirect": true,
      "via": [
        "@wdio/cli",
        "@wdio/runner"
      ],
      "effects": [],
      "range": "6.0.4 - 8.46.0",
      "nodes": [
        "node_modules/@wdio/local-runner"
      ],
      "fixAvailable": {
        "name": "@wdio/local-runner",
        "version": "9.19.2",
        "isSemVerMajor": true
      }
    },
    "@wdio/runner": {
      "name": "@wdio/runner",
      "severity": "high",
      "isDirect": false,
      "via": [
        "webdriverio"
      ],
      "effects": [
        "@wdio/local-runner"
      ],
      "range": "7.16.5 - 8.46.0",
      "nodes": [
        "node_modules/@wdio/runner"
      ],
      "fixAvailable": {
        "name": "@wdio/local-runner",
        "version": "9.19.2",
        "isSemVerMajor": true
      }
    },
    "@wdio/spec-reporter": {
      "name": "@wdio/spec-reporter",
      "severity": "high",
      "isDirect": true,
      "via": [
        "@wdio/cli"
      ],
      "effects": [],
      "range": "6.0.4 - 8.0.0-alpha.631",
      "nodes": [
        "node_modules/@wdio/spec-reporter"
      ],
      "fixAvailable": {
        "name": "@wdio/spec-reporter",
        "version": "9.19.2",
        "isSemVerMajor": true
      }
    },
    "cross-spawn": {
      "name": "cross-spawn",
      "severity": "high",
      "isDirect": false,
      "via": [
        {
          "source": 1104663,
          "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": [
        "yarn-install"
      ],
      "range": "<6.0.6",
      "nodes": [
        "node_modules/yarn-install/node_modules/cross-spawn"
      ],
      "fixAvailable": {
        "name": "@wdio/cli",
        "version": "9.19.2",
        "isSemVerMajor": true
      }
    },
    "devtools": {
      "name": "devtools",
      "severity": "high",
      "isDirect": false,
      "via": [
        "puppeteer-core"
      ],
      "effects": [],
      "range": ">=7.16.5",
      "nodes": [
        "node_modules/devtools"
      ],
      "fixAvailable": true
    },
    "external-editor": {
      "name": "external-editor",
      "severity": "low",
      "isDirect": false,
      "via": [
        "tmp"
      ],
      "effects": [
        "inquirer"
      ],
      "range": ">=1.1.1",
      "nodes": [
        "node_modules/external-editor"
      ],
      "fixAvailable": {
        "name": "@wdio/cli",
        "version": "9.19.2",
        "isSemVerMajor": true
      }
    },
    "form-data": {
      "name": "form-data",
      "severity": "critical",
      "isDirect": false,
      "via": [
        {
          "source": 1106509,
          "name": "form-data",
          "dependency": "form-data",
          "title": "form-data uses unsafe random function in form-data for choosing boundary",
          "url": "https://github.com/advisories/GHSA-fjxv-7rqg-78g4",
          "severity": "critical",
          "cwe": [
            "CWE-330"
          ],
          "cvss": {
            "score": 0,
            "vectorString": null
          },
          "range": "<2.5.4"
        }
      ],
      "effects": [
        "request"
      ],
      "range": "<2.5.4",
      "nodes": [
        "node_modules/request/node_modules/form-data"
      ],
      "fixAvailable": false
    },
    "inquirer": {
      "name": "inquirer",
      "severity": "low",
      "isDirect": false,
      "via": [
        "external-editor"
      ],
      "effects": [
        "@wdio/cli"
      ],
      "range": "3.0.0 - 8.2.6 || 9.0.0 - 9.3.7",
      "nodes": [
        "node_modules/inquirer"
      ],
      "fixAvailable": {
        "name": "@wdio/cli",
        "version": "9.19.2",
        "isSemVerMajor": true
      }
    },
    "mwbot": {
      "name": "mwbot",
      "severity": "moderate",
      "isDirect": false,
      "via": [
        "request"
      ],
      "effects": [
        "wdio-mediawiki"
      ],
      "range": ">=0.1.6",
      "nodes": [
        "node_modules/mwbot"
      ],
      "fixAvailable": false
    },
    "puppeteer-core": {
      "name": "puppeteer-core",
      "severity": "high",
      "isDirect": false,
      "via": [
        "tar-fs",
        "ws"
      ],
      "effects": [
        "devtools",
        "webdriverio"
      ],
      "range": "10.0.0 - 22.11.1",
      "nodes": [
        "node_modules/puppeteer-core"
      ],
      "fixAvailable": {
        "name": "@wdio/cli",
        "version": "9.19.2",
        "isSemVerMajor": true
      }
    },
    "request": {
      "name": "request",
      "severity": "critical",
      "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"
        },
        "form-data",
        "tough-cookie"
      ],
      "effects": [
        "mwbot"
      ],
      "range": "*",
      "nodes": [
        "node_modules/request"
      ],
      "fixAvailable": false
    },
    "tar-fs": {
      "name": "tar-fs",
      "severity": "high",
      "isDirect": false,
      "via": [
        {
          "source": 1104677,
          "name": "tar-fs",
          "dependency": "tar-fs",
          "title": "tar-fs Vulnerable to Link Following and Path Traversal via Extracting a Crafted tar File",
          "url": "https://github.com/advisories/GHSA-pq67-2wwv-3xjx",
          "severity": "high",
          "cwe": [
            "CWE-22"
          ],
          "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": ">=2.0.0 <2.1.2"
        },
        {
          "source": 1106930,
          "name": "tar-fs",
          "dependency": "tar-fs",
          "title": "tar-fs can extract outside the specified dir with a specific tarball",
          "url": "https://github.com/advisories/GHSA-8cj5-5rvv-wf4v",
          "severity": "high",
          "cwe": [
            "CWE-22"
          ],
          "cvss": {
            "score": 0,
            "vectorString": null
          },
          "range": ">=2.0.0 <2.1.3"
        }
      ],
      "effects": [
        "puppeteer-core"
      ],
      "range": "2.0.0 - 2.1.2",
      "nodes": [
        "node_modules/tar-fs"
      ],
      "fixAvailable": {
        "name": "@wdio/cli",
        "version": "9.19.2",
        "isSemVerMajor": true
      }
    },
    "tmp": {
      "name": "tmp",
      "severity": "low",
      "isDirect": false,
      "via": [
        {
          "source": 1106849,
          "name": "tmp",
          "dependency": "tmp",
          "title": "tmp allows arbitrary temporary file / directory write via symbolic link `dir` parameter",
          "url": "https://github.com/advisories/GHSA-52f5-9888-hmc6",
          "severity": "low",
          "cwe": [
            "CWE-59"
          ],
          "cvss": {
            "score": 2.5,
            "vectorString": "CVSS:3.1/AV:L/AC:H/PR:L/UI:N/S:U/C:N/I:L/A:N"
          },
          "range": "<=0.2.3"
        }
      ],
      "effects": [
        "external-editor"
      ],
      "range": "<=0.2.3",
      "nodes": [
        "node_modules/tmp"
      ],
      "fixAvailable": {
        "name": "@wdio/cli",
        "version": "9.19.2",
        "isSemVerMajor": 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": [
        "request"
      ],
      "range": "<4.1.3",
      "nodes": [
        "node_modules/request/node_modules/tough-cookie"
      ],
      "fixAvailable": false
    },
    "wdio-mediawiki": {
      "name": "wdio-mediawiki",
      "severity": "moderate",
      "isDirect": true,
      "via": [
        "mwbot"
      ],
      "effects": [],
      "range": "*",
      "nodes": [
        "node_modules/wdio-mediawiki"
      ],
      "fixAvailable": false
    },
    "webdriverio": {
      "name": "webdriverio",
      "severity": "high",
      "isDirect": false,
      "via": [
        "devtools",
        "puppeteer-core"
      ],
      "effects": [
        "@wdio/cli",
        "@wdio/runner"
      ],
      "range": "7.16.5 - 8.46.0",
      "nodes": [
        "node_modules/webdriverio"
      ],
      "fixAvailable": {
        "name": "@wdio/cli",
        "version": "9.19.2",
        "isSemVerMajor": true
      }
    },
    "ws": {
      "name": "ws",
      "severity": "high",
      "isDirect": false,
      "via": [
        {
          "source": 1098392,
          "name": "ws",
          "dependency": "ws",
          "title": "ws affected by a DoS when handling a request with many HTTP headers",
          "url": "https://github.com/advisories/GHSA-3h5v-q93c-6h6q",
          "severity": "high",
          "cwe": [
            "CWE-476"
          ],
          "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": ">=8.0.0 <8.17.1"
        }
      ],
      "effects": [
        "puppeteer-core"
      ],
      "range": "8.0.0 - 8.17.0",
      "nodes": [
        "node_modules/puppeteer-core/node_modules/ws"
      ],
      "fixAvailable": {
        "name": "@wdio/cli",
        "version": "9.19.2",
        "isSemVerMajor": true
      }
    },
    "yarn-install": {
      "name": "yarn-install",
      "severity": "high",
      "isDirect": false,
      "via": [
        "cross-spawn"
      ],
      "effects": [
        "@wdio/cli"
      ],
      "range": "*",
      "nodes": [
        "node_modules/yarn-install"
      ],
      "fixAvailable": {
        "name": "@wdio/cli",
        "version": "9.19.2",
        "isSemVerMajor": true
      }
    }
  },
  "metadata": {
    "vulnerabilities": {
      "info": 0,
      "low": 3,
      "moderate": 3,
      "high": 12,
      "critical": 2,
      "total": 20
    },
    "dependencies": {
      "prod": 1,
      "dev": 1359,
      "optional": 9,
      "peer": 6,
      "peerOptional": 0,
      "total": 1359
    }
  }
}

--- 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: 41 installs, 0 updates, 0 removals
  - Locking composer/pcre (3.3.2)
  - Locking composer/semver (3.4.3)
  - Locking composer/spdx-licenses (1.5.9)
  - Locking composer/xdebug-handler (3.0.5)
  - Locking dealerdirect/phpcodesniffer-composer-installer (v1.1.2)
  - Locking diff/diff (3.4.0)
  - Locking doctrine/deprecations (1.1.5)
  - Locking felixfbecker/advanced-json-rpc (v3.2.1)
  - Locking mediawiki/mediawiki-codesniffer (v47.0.0)
  - Locking mediawiki/mediawiki-phan-config (0.17.0)
  - Locking mediawiki/minus-x (1.1.3)
  - Locking mediawiki/phan-taint-check-plugin (7.0.0)
  - Locking microsoft/tolerant-php-parser (v0.1.2)
  - Locking netresearch/jsonmapper (v4.5.0)
  - Locking phan/phan (5.5.1)
  - 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.3)
  - Locking phpdocumentor/type-resolver (1.10.0)
  - Locking phpstan/phpdoc-parser (2.3.0)
  - Locking psr/container (2.0.2)
  - Locking psr/log (3.0.2)
  - Locking sabre/event (5.1.7)
  - Locking squizlabs/php_codesniffer (3.12.2)
  - Locking symfony/console (v7.3.3)
  - Locking symfony/deprecation-contracts (v3.6.0)
  - Locking symfony/polyfill-ctype (v1.33.0)
  - Locking symfony/polyfill-intl-grapheme (v1.33.0)
  - Locking symfony/polyfill-intl-normalizer (v1.33.0)
  - Locking symfony/polyfill-mbstring (v1.33.0)
  - Locking symfony/polyfill-php80 (v1.33.0)
  - Locking symfony/service-contracts (v3.6.0)
  - Locking symfony/string (v7.3.3)
  - Locking tysonandre/var_representation_polyfill (0.1.3)
  - Locking webmozart/assert (1.11.0)
  - Locking wikimedia/remex-html (5.1.0)
  - Locking wikimedia/utfnormal (4.0.0)
Writing lock file
Installing dependencies from lock file (including require-dev)
Package operations: 41 installs, 0 updates, 0 removals
    0 [>---------------------------]    0 [->--------------------------]
  - Installing squizlabs/php_codesniffer (3.12.2): Extracting archive
  - Installing dealerdirect/phpcodesniffer-composer-installer (v1.1.2): Extracting archive
  - Installing composer/pcre (3.3.2): Extracting archive
  - Installing diff/diff (3.4.0): Extracting archive
  - Installing symfony/polyfill-php80 (v1.33.0): Extracting archive
  - Installing phpcsstandards/phpcsutils (1.0.12): Extracting archive
  - Installing phpcsstandards/phpcsextra (1.2.1): Extracting archive
  - Installing symfony/polyfill-mbstring (v1.33.0): Extracting archive
  - Installing composer/spdx-licenses (1.5.9): Extracting archive
  - Installing composer/semver (3.4.3): Extracting archive
  - Installing mediawiki/mediawiki-codesniffer (v47.0.0): Extracting archive
  - Installing tysonandre/var_representation_polyfill (0.1.3): Extracting archive
  - Installing symfony/polyfill-intl-normalizer (v1.33.0): Extracting archive
  - Installing symfony/polyfill-intl-grapheme (v1.33.0): Extracting archive
  - Installing symfony/polyfill-ctype (v1.33.0): Extracting archive
  - Installing symfony/string (v7.3.3): Extracting archive
  - Installing symfony/deprecation-contracts (v3.6.0): Extracting archive
  - Installing psr/container (2.0.2): Extracting archive
  - Installing symfony/service-contracts (v3.6.0): Extracting archive
  - Installing symfony/console (v7.3.3): 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.3.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.3): 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.5.1): Extracting archive
  - Installing mediawiki/phan-taint-check-plugin (7.0.0): Extracting archive
  - Installing mediawiki/mediawiki-phan-config (0.17.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
  - Installing wikimedia/utfnormal (4.0.0): Extracting archive
  - Installing wikimedia/remex-html (5.1.0): Extracting archive
  0/39 [>---------------------------]   0%
 21/39 [===============>------------]  53%
 37/39 [==========================>-]  94%
 39/39 [============================] 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:@wikimedia/codex from 2.2.1 -> 2.3.1
$ /usr/bin/npm install
--- stderr ---
npm WARN EBADENGINE Unsupported engine {
npm WARN EBADENGINE   package: '@wikimedia/codex@2.3.1',
npm WARN EBADENGINE   required: { npm: '>=10.8.2', node: '>=20.19.1' },
npm WARN EBADENGINE   current: { node: 'v18.19.0', npm: '9.2.0' }
npm WARN EBADENGINE }
npm WARN EBADENGINE Unsupported engine {
npm WARN EBADENGINE   package: '@wikimedia/codex-icons@2.3.1',
npm WARN EBADENGINE   required: { npm: '>=10.8.2', node: '>=20.19.1' },
npm WARN EBADENGINE   current: { node: 'v18.19.0', npm: '9.2.0' }
npm WARN EBADENGINE }
npm WARN deprecated @types/easy-table@1.2.3: This is a stub types definition. easy-table provides its own type definitions, so you do not need this installed.
npm WARN deprecated osenv@0.1.5: This package is no longer supported.
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 har-validator@5.1.5: this library is no longer supported
npm WARN deprecated @humanwhocodes/config-array@0.13.0: Use @eslint/config-array instead
npm WARN deprecated rimraf@3.0.2: Rimraf versions prior to v4 are no longer supported
npm WARN deprecated abab@2.0.6: Use your platform's native atob() and btoa() methods instead
npm WARN deprecated glob@8.1.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 glob@7.2.3: Glob versions prior to v9 are no longer supported
npm WARN deprecated glob@7.2.3: Glob versions prior to v9 are no longer supported
npm WARN deprecated glob@7.2.3: Glob versions prior to v9 are no longer supported
npm WARN deprecated glob@7.2.3: Glob versions prior to v9 are no longer supported
npm WARN deprecated glob@7.2.3: Glob versions prior to v9 are no longer supported
npm WARN deprecated glob@7.2.3: Glob versions prior to v9 are no longer supported
npm WARN deprecated glob@7.2.3: Glob versions prior to v9 are no longer supported
npm WARN deprecated glob@7.1.7: Glob versions prior to v9 are no longer supported
npm WARN deprecated glob@7.1.7: Glob versions prior to v9 are no longer supported
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 eslint@8.57.1: This version is no longer supported. Please see https://eslint.org/version-support for other options.
--- stdout ---

added 1358 packages, and audited 1359 packages in 19s

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

20 vulnerabilities (3 low, 3 moderate, 12 high, 2 critical)

To address issues that do not require attention, run:
  npm audit fix

To address all issues possible (including breaking changes), run:
  npm audit fix --force

Some issues need review, and may require choosing
a different dependency.

Run `npm audit` for details.

--- end ---
$ package-lock-lint package-lock.json
--- stdout ---
Checking package-lock.json

--- end ---
$ /usr/bin/npm ci
--- stderr ---
npm WARN EBADENGINE Unsupported engine {
npm WARN EBADENGINE   package: '@wikimedia/codex@2.3.1',
npm WARN EBADENGINE   required: { node: '>=20.19.1', npm: '>=10.8.2' },
npm WARN EBADENGINE   current: { node: 'v18.19.0', npm: '9.2.0' }
npm WARN EBADENGINE }
npm WARN EBADENGINE Unsupported engine {
npm WARN EBADENGINE   package: '@wikimedia/codex-icons@2.3.1',
npm WARN EBADENGINE   required: { node: '>=20.19.1', npm: '>=10.8.2' },
npm WARN EBADENGINE   current: { node: 'v18.19.0', npm: '9.2.0' }
npm WARN EBADENGINE }
npm WARN deprecated @types/easy-table@1.2.3: This is a stub types definition. easy-table provides its own type definitions, so you do not need this installed.
npm WARN deprecated osenv@0.1.5: This package is no longer supported.
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 har-validator@5.1.5: this library is no longer supported
npm WARN deprecated @humanwhocodes/config-array@0.13.0: Use @eslint/config-array instead
npm WARN deprecated rimraf@3.0.2: Rimraf versions prior to v4 are no longer supported
npm WARN deprecated abab@2.0.6: Use your platform's native atob() and btoa() methods instead
npm WARN deprecated @humanwhocodes/object-schema@2.0.3: Use @eslint/object-schema instead
npm WARN deprecated glob@8.1.0: Glob versions prior to v9 are no longer supported
npm WARN deprecated glob@7.2.3: Glob versions prior to v9 are no longer supported
npm WARN deprecated glob@7.2.3: Glob versions prior to v9 are no longer supported
npm WARN deprecated glob@7.2.3: Glob versions prior to v9 are no longer supported
npm WARN deprecated glob@7.2.3: Glob versions prior to v9 are no longer supported
npm WARN deprecated glob@7.2.3: Glob versions prior to v9 are no longer supported
npm WARN deprecated glob@7.2.3: Glob versions prior to v9 are no longer supported
npm WARN deprecated glob@7.2.3: Glob versions prior to v9 are no longer supported
npm WARN deprecated glob@7.1.7: Glob versions prior to v9 are no longer supported
npm WARN deprecated glob@7.1.7: Glob versions prior to v9 are no longer supported
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 eslint@8.57.1: This version is no longer supported. Please see https://eslint.org/version-support for other options.
--- stdout ---

added 1358 packages, and audited 1359 packages in 25s

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

20 vulnerabilities (3 low, 3 moderate, 12 high, 2 critical)

To address issues that do not require attention, run:
  npm audit fix

To address all issues possible (including breaking changes), run:
  npm audit fix --force

Some issues need review, and may require choosing
a different dependency.

Run `npm audit` for details.

--- end ---
$ /usr/bin/npm test
--- stderr ---
PASS tests/jest/utils/zobjectUtils.test.js
PASS tests/jest/store/stores/submission.test.js
PASS tests/jest/store/stores/zobject.test.js
PASS tests/jest/store/stores/library.test.js
PASS tests/jest/store/stores/factory.test.js
PASS tests/jest/components/default/ZObjectKeyValue.test.js (5.161 s)
PASS tests/jest/components/widgets/about/About.test.js
PASS tests/jest/components/widgets/about/AboutLanguageBlock.test.js
PASS tests/jest/store/stores/router.test.js
PASS tests/jest/components/visualeditor/FunctionInputPreview.test.js
PASS tests/jest/components/default/ZObjectStringRenderer.test.js
PASS tests/jest/utils/typeUtils.test.js
FAIL tests/jest/components/base/ModeSelector.test.js
  ● ModeSelector › basic rendering › opens the menu when button is clicked

    expect(received).toBe(expected) // Object.is equality

    Expected: true
    Received: false

    Ignored nodes: comments, script, style
    <html>
      <head />
      <body>
        
        
        
        
        
        
      </body>
    </html>

      85 | 			await wrapper.vm.$nextTick();
      86 |
    > 87 | 			await waitFor( () => expect( menu.isVisible() ).toBe( true ) );
         | 			                                                ^
      88 | 		} );
      89 | 	} );
      90 |

      at tests/jest/components/base/ModeSelector.test.js:87:52
      at runWithExpensiveErrorDiagnosticsDisabled (node_modules/@testing-library/dom/dist/config.js:47:12)
      at checkCallback (node_modules/@testing-library/dom/dist/wait-for.js:124:77)
      at checkRealTimersCallback (node_modules/@testing-library/dom/dist/wait-for.js:118:16)
      at Timeout.task [as _onTimeout] (node_modules/jsdom/lib/jsdom/browser/Window.js:520:19)

PASS tests/jest/components/default/ZObjectToString.test.js (10.396 s)
PASS tests/jest/store/stores/testResults.test.js
PASS tests/jest/store/stores/zfunction.test.js
PASS tests/jest/components/widgets/function-evaluator/FunctionEvaluator.test.js
PASS tests/jest/components/base/ZObjectSelector.test.js
PASS tests/jest/store/stores/wikidata/lexemes.test.js
node:internal/process/promises:288
            triggerUncaughtException(err, true /* fromPromise */);
            ^

[UnhandledPromiseRejection: This error originated either by throwing inside of an async function without a catch block, or by rejecting a promise which was not handled with .catch(). The promise rejected with the reason "Maximum recursive updates exceeded in component <CdxSelect>. This means you have a reactive effect that is mutating its own dependencies and thus recursively triggering itself. Possible sources include component template, render function, updated hook or watcher source function.".] {
  code: 'ERR_UNHANDLED_REJECTION'
}

Node.js v18.19.0
PASS tests/jest/components/widgets/function-explorer/FunctionExplorer.test.js
PASS tests/jest/store/stores/ztype.test.js
PASS tests/jest/utils/schemata.test.js
PASS tests/jest/components/default/ZCode.test.js
PASS tests/jest/components/function/viewer/FunctionViewerDetails.test.js
PASS tests/jest/store/stores/wikidata/entities.test.js
PASS tests/jest/store/classes/ApiError.test.js
node:internal/process/promises:288
            triggerUncaughtException(err, true /* fromPromise */);
            ^

[UnhandledPromiseRejection: This error originated either by throwing inside of an async function without a catch block, or by rejecting a promise which was not handled with .catch(). The promise rejected with the reason "Maximum recursive updates exceeded in component <CdxSelect>. This means you have a reactive effect that is mutating its own dependencies and thus recursively triggering itself. Possible sources include component template, render function, updated hook or watcher source function.".] {
  code: 'ERR_UNHANDLED_REJECTION'
}

Node.js v18.19.0
PASS tests/jest/components/widgets/about/AboutLanguagesDialog.test.js
PASS tests/jest/components/default/ZImplementation.test.js
PASS tests/jest/components/default/wikidata/EntitySelector.test.js
PASS tests/jest/languageselector/LanguageSelector.test.js
PASS tests/jest/components/widgets/publish/PublishDialog.test.js
node:internal/process/promises:288
            triggerUncaughtException(err, true /* fromPromise */);
            ^

[UnhandledPromiseRejection: This error originated either by throwing inside of an async function without a catch block, or by rejecting a promise which was not handled with .catch(). The promise rejected with the reason "Maximum recursive updates exceeded in component <CdxSelect>. This means you have a reactive effect that is mutating its own dependencies and thus recursively triggering itself. Possible sources include component template, render function, updated hook or watcher source function.".] {
  code: 'ERR_UNHANDLED_REJECTION'
}

Node.js v18.19.0
PASS tests/jest/store/stores/wikidata/properties.test.js
PASS tests/jest/components/default/ZTester.test.js
PASS tests/jest/store/stores/wikidata/items.test.js
node:internal/process/promises:288
            triggerUncaughtException(err, true /* fromPromise */);
            ^

[UnhandledPromiseRejection: This error originated either by throwing inside of an async function without a catch block, or by rejecting a promise which was not handled with .catch(). The promise rejected with the reason "Maximum recursive updates exceeded in component <CdxSelect>. This means you have a reactive effect that is mutating its own dependencies and thus recursively triggering itself. Possible sources include component template, render function, updated hook or watcher source function.".] {
  code: 'ERR_UNHANDLED_REJECTION'
}

Node.js v18.19.0
FAIL tests/jest/components/widgets/function-evaluator/FunctionMetadataDialog.test.js
  ● Test suite failed to run

    Jest worker encountered 4 child process exceptions, exceeding retry limit

      at ChildProcessWorker.initialize (node_modules/jest-worker/build/workers/ChildProcessWorker.js:181:21)

PASS tests/jest/components/widgets/publish/Publish.test.js
PASS tests/jest/integration/DisconnectFunctionImplementation.test.js
node:internal/process/promises:288
            triggerUncaughtException(err, true /* fromPromise */);
            ^

[UnhandledPromiseRejection: This error originated either by throwing inside of an async function without a catch block, or by rejecting a promise which was not handled with .catch(). The promise rejected with the reason "Maximum recursive updates exceeded in component <CdxLookup>. This means you have a reactive effect that is mutating its own dependencies and thus recursively triggering itself. Possible sources include component template, render function, updated hook or watcher source function.".] {
  code: 'ERR_UNHANDLED_REJECTION'
}

Node.js v18.19.0
node:internal/process/promises:288
            triggerUncaughtException(err, true /* fromPromise */);
            ^

[UnhandledPromiseRejection: This error originated either by throwing inside of an async function without a catch block, or by rejecting a promise which was not handled with .catch(). The promise rejected with the reason "Maximum recursive updates exceeded in component <CdxLookup>. This means you have a reactive effect that is mutating its own dependencies and thus recursively triggering itself. Possible sources include component template, render function, updated hook or watcher source function.".] {
  code: 'ERR_UNHANDLED_REJECTION'
}

Node.js v18.19.0
node:internal/process/promises:288
            triggerUncaughtException(err, true /* fromPromise */);
            ^

[UnhandledPromiseRejection: This error originated either by throwing inside of an async function without a catch block, or by rejecting a promise which was not handled with .catch(). The promise rejected with the reason "Maximum recursive updates exceeded in component <CdxLookup>. This means you have a reactive effect that is mutating its own dependencies and thus recursively triggering itself. Possible sources include component template, render function, updated hook or watcher source function.".] {
  code: 'ERR_UNHANDLED_REJECTION'
}

Node.js v18.19.0
node:internal/process/promises:288
            triggerUncaughtException(err, true /* fromPromise */);
            ^

[UnhandledPromiseRejection: This error originated either by throwing inside of an async function without a catch block, or by rejecting a promise which was not handled with .catch(). The promise rejected with the reason "Maximum recursive updates exceeded in component <CdxLookup>. This means you have a reactive effect that is mutating its own dependencies and thus recursively triggering itself. Possible sources include component template, render function, updated hook or watcher source function.".] {
  code: 'ERR_UNHANDLED_REJECTION'
}

Node.js v18.19.0
node:internal/process/promises:288
            triggerUncaughtException(err, true /* fromPromise */);
            ^

[UnhandledPromiseRejection: This error originated either by throwing inside of an async function without a catch block, or by rejecting a promise which was not handled with .catch(). The promise rejected with the reason "Maximum recursive updates exceeded in component <CdxLookup>. This means you have a reactive effect that is mutating its own dependencies and thus recursively triggering itself. Possible sources include component template, render function, updated hook or watcher source function.".] {
  code: 'ERR_UNHANDLED_REJECTION'
}

Node.js v18.19.0
node:internal/process/promises:288
            triggerUncaughtException(err, true /* fromPromise */);
            ^

[UnhandledPromiseRejection: This error originated either by throwing inside of an async function without a catch block, or by rejecting a promise which was not handled with .catch(). The promise rejected with the reason "Maximum recursive updates exceeded in component <CdxLookup>. This means you have a reactive effect that is mutating its own dependencies and thus recursively triggering itself. Possible sources include component template, render function, updated hook or watcher source function.".] {
  code: 'ERR_UNHANDLED_REJECTION'
}

Node.js v18.19.0
node:internal/process/promises:288
            triggerUncaughtException(err, true /* fromPromise */);
            ^

[UnhandledPromiseRejection: This error originated either by throwing inside of an async function without a catch block, or by rejecting a promise which was not handled with .catch(). The promise rejected with the reason "Maximum recursive updates exceeded in component <CdxLookup>. This means you have a reactive effect that is mutating its own dependencies and thus recursively triggering itself. Possible sources include component template, render function, updated hook or watcher source function.".] {
  code: 'ERR_UNHANDLED_REJECTION'
}

Node.js v18.19.0
FAIL tests/jest/integration/CreateNewTester.test.js
  ● Test suite failed to run

    Jest worker encountered 4 child process exceptions, exceeding retry limit

      at ChildProcessWorker.initialize (node_modules/jest-worker/build/workers/ChildProcessWorker.js:181:21)

PASS tests/jest/components/default/wikidata/LexemeForm.test.js
PASS tests/jest/components/visualeditor/FunctionInputField.test.js
PASS tests/jest/components/base/CodeEditor.test.js
PASS tests/jest/components/default/wikidata/Property.test.js
PASS tests/jest/components/default/wikidata/Lexeme.test.js
PASS tests/jest/components/base/TypeSelector.test.js
PASS tests/jest/components/widgets/function-report/FunctionReport.test.js
PASS tests/jest/store/stores/currentPage.test.js
PASS tests/jest/components/default/wikidata/Item.test.js
PASS tests/jest/components/visualeditor/fields/FunctionInputParser.test.js
node:internal/process/promises:288
            triggerUncaughtException(err, true /* fromPromise */);
            ^

[UnhandledPromiseRejection: This error originated either by throwing inside of an async function without a catch block, or by rejecting a promise which was not handled with .catch(). The promise rejected with the reason "Maximum recursive updates exceeded in component <CdxLookup>. This means you have a reactive effect that is mutating its own dependencies and thus recursively triggering itself. Possible sources include component template, render function, updated hook or watcher source function.".] {
  code: 'ERR_UNHANDLED_REJECTION'
}

Node.js v18.19.0
node:internal/process/promises:288
            triggerUncaughtException(err, true /* fromPromise */);
            ^

[UnhandledPromiseRejection: This error originated either by throwing inside of an async function without a catch block, or by rejecting a promise which was not handled with .catch(). The promise rejected with the reason "Maximum recursive updates exceeded in component <CdxLookup>. This means you have a reactive effect that is mutating its own dependencies and thus recursively triggering itself. Possible sources include component template, render function, updated hook or watcher source function.".] {
  code: 'ERR_UNHANDLED_REJECTION'
}

Node.js v18.19.0
node:internal/process/promises:288
            triggerUncaughtException(err, true /* fromPromise */);
            ^

[UnhandledPromiseRejection: This error originated either by throwing inside of an async function without a catch block, or by rejecting a promise which was not handled with .catch(). The promise rejected with the reason "Maximum recursive updates exceeded in component <CdxLookup>. This means you have a reactive effect that is mutating its own dependencies and thus recursively triggering itself. Possible sources include component template, render function, updated hook or watcher source function.".] {
  code: 'ERR_UNHANDLED_REJECTION'
}

Node.js v18.19.0
node:internal/process/promises:288
            triggerUncaughtException(err, true /* fromPromise */);
            ^

[UnhandledPromiseRejection: This error originated either by throwing inside of an async function without a catch block, or by rejecting a promise which was not handled with .catch(). The promise rejected with the reason "Maximum recursive updates exceeded in component <CdxLookup>. This means you have a reactive effect that is mutating its own dependencies and thus recursively triggering itself. Possible sources include component template, render function, updated hook or watcher source function.".] {
  code: 'ERR_UNHANDLED_REJECTION'
}

Node.js v18.19.0
FAIL tests/jest/integration/CreateNewCompositionImplementation.test.js
  ● Test suite failed to run

    Jest worker encountered 4 child process exceptions, exceeding retry limit

      at ChildProcessWorker.initialize (node_modules/jest-worker/build/workers/ChildProcessWorker.js:181:21)

PASS tests/jest/integration/CreateNewFunction.test.js
PASS tests/jest/components/base/Pagination.test.js
PASS tests/jest/components/visualeditor/fields/FunctionInputWikidata.test.js
PASS tests/jest/components/default/ZArgumentReference.test.js
PASS tests/jest/integration/EditFunction.test.js
PASS tests/jest/integration/FunctionEditorEdgeCases.test.js
PASS tests/jest/components/function/editor/FunctionEditorInputsItem.test.js
PASS tests/jest/store/stores/visualeditor.test.js
PASS tests/jest/components/function/editor/FunctionEditorName.test.js
PASS tests/jest/components/visualeditor/FunctionInputSetup.test.js
PASS tests/jest/store/stores/errors.test.js
PASS tests/jest/components/default/ZReference.test.js
PASS tests/jest/components/visualeditor/fields/FunctionInputLanguage.test.js
PASS tests/jest/components/visualeditor/fields/FunctionInputEnum.test.js
PASS tests/jest/components/default/ZTypedList.test.js
PASS tests/jest/utils/miscUtils.test.js
PASS tests/jest/components/function/editor/FunctionEditorDescription.test.js
PASS tests/jest/mixins/pageTitleMixin.test.js
node:internal/process/promises:288
            triggerUncaughtException(err, true /* fromPromise */);
            ^

[UnhandledPromiseRejection: This error originated either by throwing inside of an async function without a catch block, or by rejecting a promise which was not handled with .catch(). The promise rejected with the reason "Maximum recursive updates exceeded in component <CdxLookup>. This means you have a reactive effect that is mutating its own dependencies and thus recursively triggering itself. Possible sources include component template, render function, updated hook or watcher source function.".] {
  code: 'ERR_UNHANDLED_REJECTION'
}

Node.js v18.19.0
PASS tests/jest/components/base/ClipboardManager.test.js
PASS tests/jest/integration/RunFunctionCall.test.js
PASS tests/jest/integration/FunctionEditorGenericTypes.test.js (5.103 s)
PASS tests/jest/mixins/errorMixin.test.js
PASS tests/jest/components/function/editor/FunctionEditorLanguageBlock.test.js
PASS tests/jest/components/default/wikidata/ReferenceSelector.test.js
PASS tests/jest/components/function/editor/FunctionEditorInputs.test.js
PASS tests/jest/components/visualeditor/FunctionSelect.test.js
PASS tests/jest/components/function/editor/FunctionEditorAliases.test.js
PASS tests/jest/components/widgets/function-report/FunctionReportItem.test.js
PASS tests/jest/composables/useBreakpoints.test.js
PASS tests/jest/store/stores/listItems.test.js
PASS tests/jest/components/default/wikidata/Enum.test.js
PASS tests/jest/components/App.test.js
PASS tests/jest/store/stores/user.test.js
PASS tests/jest/utils/urlUtils.test.js
PASS tests/jest/components/default/ZMonolingualString.test.js
PASS tests/jest/integration/ConnectFunctionImplementation.test.js
PASS tests/jest/mixins/zobjectMixin.test.js
PASS tests/jest/integration/ConnectFunctionTest.test.js
PASS tests/jest/mixins/eventLogMixin.test.js
PASS tests/jest/integration/CancelEditExistingFunction.test.js
PASS tests/jest/components/base/ExpandedToggle.test.js
PASS tests/jest/integration/DisconnectFunctionTest.test.js
PASS tests/jest/components/widgets/function-evaluator/EvaluationResult.test.js
PASS tests/jest/components/function/editor/FunctionEditor.test.js
PASS tests/jest/store/stores/languages.test.js
PASS tests/jest/store/stores/functionCall.test.js
PASS tests/jest/components/function/editor/FunctionEditorOutput.test.js
PASS tests/jest/components/default/ZTypedListItems.test.js
PASS tests/jest/components/visualeditor/FunctionCallSetup.test.js
PASS tests/jest/components/default/ZBoolean.test.js
PASS tests/jest/components/function/editor/FunctionEditorLanguage.test.js
PASS tests/jest/mixins/clipboardMixin.test.js
PASS tests/jest/integration/CancelEditNewFunction.test.js
PASS tests/jest/components/visualeditor/ExpandableDescription.test.js
PASS tests/jest/components/base/LocalizedLabel.test.js
PASS tests/jest/components/default/ZHTMLFragment.test.js
PASS tests/jest/components/base/TypeToString.test.js
PASS tests/jest/components/default/ZString.test.js
PASS tests/jest/components/default/ZTypedListType.test.js
PASS tests/jest/views/FunctionViewer.test.js
PASS tests/jest/store/stores/programmingLanguages.test.js
PASS tests/jest/components/widgets/publish/LeaveEditorDialog.test.js
PASS tests/jest/components/default/ZFunctionCall.test.js
PASS tests/jest/components/visualeditor/fields/FunctionInputString.test.js
PASS tests/jest/utils/wikidataUtils.test.js
PASS tests/jest/components/function/viewer/FunctionViewerDetailsTable.test.js
PASS tests/jest/store/index.test.js
node:internal/process/promises:288
            triggerUncaughtException(err, true /* fromPromise */);
            ^

[UnhandledPromiseRejection: This error originated either by throwing inside of an async function without a catch block, or by rejecting a promise which was not handled with .catch(). The promise rejected with the reason "Maximum recursive updates exceeded in component <CdxLookup>. This means you have a reactive effect that is mutating its own dependencies and thus recursively triggering itself. Possible sources include component template, render function, updated hook or watcher source function.".] {
  code: 'ERR_UNHANDLED_REJECTION'
}

Node.js v18.19.0
node:internal/process/promises:288
            triggerUncaughtException(err, true /* fromPromise */);
            ^

[UnhandledPromiseRejection: This error originated either by throwing inside of an async function without a catch block, or by rejecting a promise which was not handled with .catch(). The promise rejected with the reason "Maximum recursive updates exceeded in component <CdxLookup>. This means you have a reactive effect that is mutating its own dependencies and thus recursively triggering itself. Possible sources include component template, render function, updated hook or watcher source function.".] {
  code: 'ERR_UNHANDLED_REJECTION'
}

Node.js v18.19.0
FAIL tests/jest/integration/CreateNewWikidataEnum.test.js
  ● Test suite failed to run

    Jest worker encountered 4 child process exceptions, exceeding retry limit

      at ChildProcessWorker.initialize (node_modules/jest-worker/build/workers/ChildProcessWorker.js:181:21)

node:internal/process/promises:288
            triggerUncaughtException(err, true /* fromPromise */);
            ^

[UnhandledPromiseRejection: This error originated either by throwing inside of an async function without a catch block, or by rejecting a promise which was not handled with .catch(). The promise rejected with the reason "Maximum recursive updates exceeded in component <CdxLookup>. This means you have a reactive effect that is mutating its own dependencies and thus recursively triggering itself. Possible sources include component template, render function, updated hook or watcher source function.".] {
  code: 'ERR_UNHANDLED_REJECTION'
}

Node.js v18.19.0
node:internal/process/promises:288
            triggerUncaughtException(err, true /* fromPromise */);
            ^

[UnhandledPromiseRejection: This error originated either by throwing inside of an async function without a catch block, or by rejecting a promise which was not handled with .catch(). The promise rejected with the reason "Maximum recursive updates exceeded in component <CdxLookup>. This means you have a reactive effect that is mutating its own dependencies and thus recursively triggering itself. Possible sources include component template, render function, updated hook or watcher source function.".] {
  code: 'ERR_UNHANDLED_REJECTION'
}

Node.js v18.19.0
FAIL tests/jest/integration/CreateNewCodeImplementation.test.js
  ● Test suite failed to run

    Jest worker encountered 4 child process exceptions, exceeding retry limit

      at ChildProcessWorker.initialize (node_modules/jest-worker/build/workers/ChildProcessWorker.js:181:21)

Jest: "./resources/ext.wikilambda.app/" coverage threshold for functions (95%) not met: 93.62%
Summary of all failing tests
FAIL tests/jest/components/base/ModeSelector.test.js
  ● ModeSelector › basic rendering › opens the menu when button is clicked

    expect(received).toBe(expected) // Object.is equality

    Expected: true
    Received: false

    Ignored nodes: comments, script, style
    <html>
      <head />
      <body>
        
        
        
        
        
        
      </body>
    </html>

      85 | 			await wrapper.vm.$nextTick();
      86 |
    > 87 | 			await waitFor( () => expect( menu.isVisible() ).toBe( true ) );
         | 			                                                ^
      88 | 		} );
      89 | 	} );
      90 |

      at tests/jest/components/base/ModeSelector.test.js:87:52
      at runWithExpensiveErrorDiagnosticsDisabled (node_modules/@testing-library/dom/dist/config.js:47:12)
      at checkCallback (node_modules/@testing-library/dom/dist/wait-for.js:124:77)
      at checkRealTimersCallback (node_modules/@testing-library/dom/dist/wait-for.js:118:16)
      at Timeout.task [as _onTimeout] (node_modules/jsdom/lib/jsdom/browser/Window.js:520:19)

FAIL tests/jest/components/widgets/function-evaluator/FunctionMetadataDialog.test.js
  ● Test suite failed to run

    Jest worker encountered 4 child process exceptions, exceeding retry limit

      at ChildProcessWorker.initialize (node_modules/jest-worker/build/workers/ChildProcessWorker.js:181:21)

FAIL tests/jest/integration/CreateNewTester.test.js
  ● Test suite failed to run

    Jest worker encountered 4 child process exceptions, exceeding retry limit

      at ChildProcessWorker.initialize (node_modules/jest-worker/build/workers/ChildProcessWorker.js:181:21)

FAIL tests/jest/integration/CreateNewCompositionImplementation.test.js
  ● Test suite failed to run

    Jest worker encountered 4 child process exceptions, exceeding retry limit

      at ChildProcessWorker.initialize (node_modules/jest-worker/build/workers/ChildProcessWorker.js:181:21)

FAIL tests/jest/integration/CreateNewWikidataEnum.test.js
  ● Test suite failed to run

    Jest worker encountered 4 child process exceptions, exceeding retry limit

      at ChildProcessWorker.initialize (node_modules/jest-worker/build/workers/ChildProcessWorker.js:181:21)

FAIL tests/jest/integration/CreateNewCodeImplementation.test.js
  ● Test suite failed to run

    Jest worker encountered 4 child process exceptions, exceeding retry limit

      at ChildProcessWorker.initialize (node_modules/jest-worker/build/workers/ChildProcessWorker.js:181:21)


Test Suites: 6 failed, 112 passed, 118 total
Tests:       1 failed, 1 skipped, 1752 passed, 1754 total
Snapshots:   0 total
Time:        923.998 s
Ran all test suites.
--- stdout ---

> test
> grunt test && npm run test:unit

Running "eslint:all" (eslint) task

/src/repo/docker-compose.sample.yml
   3:1  warning  This line has a length of 103. Maximum allowed is 100  max-len
   4:1  warning  This line has a length of 107. Maximum allowed is 100  max-len
  48:1  warning  This line has a length of 117. Maximum allowed is 100  max-len
  49:1  warning  This line has a length of 104. Maximum allowed is 100  max-len
  50:1  warning  This line has a length of 106. Maximum allowed is 100  max-len
  56:1  warning  This line has a length of 120. Maximum allowed is 100  max-len
  57:1  warning  This line has a length of 104. Maximum allowed is 100  max-len
  58:1  warning  This line has a length of 109. Maximum allowed is 100  max-len

✖ 8 problems (0 errors, 8 warnings)


Running "banana:WikiLambda" (banana) task
>> 3 message directories checked.

Running "stylelint:all" (stylelint) task
>> Linted 304 files without errors

Done.

> test:unit
> jest

----------------------------------------------------------|---------|----------|---------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
File                                                      | % Stmts | % Branch | % Funcs | % Lines | Uncovered Line #s                                                                                                                                                                           
----------------------------------------------------------|---------|----------|---------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
All files                                                 |   97.34 |    92.63 |   93.62 |   97.34 |                                                                                                                                                                                             
 ext.wikilambda.app/components                            |   97.74 |      100 |     100 |   97.74 |                                                                                                                                                                                             
  App.vue                                                 |   97.74 |      100 |     100 |   97.74 | 93,97,117                                                                                                                                                                                   
 ext.wikilambda.app/components/base                       |   97.83 |    90.57 |   94.62 |   97.83 |                                                                                                                                                                                             
  ClipboardManager.vue                                    |   97.77 |    85.71 |     100 |   97.77 | 70-71                                                                                                                                                                                       
  CodeEditor.vue                                          |   95.59 |       92 |    92.3 |   95.59 | 90-92,100,263-270,290-291                                                                                                                                                                   
  CustomDialogHeader.vue                                  |     100 |      100 |     100 |     100 |                                                                                                                                                                                             
  ExpandedToggle.vue                                      |     100 |      100 |     100 |     100 |                                                                                                                                                                                             
  KeyBlock.vue                                            |     100 |      100 |     100 |     100 |                                                                                                                                                                                             
  KeyValueBlock.vue                                       |   99.09 |      100 |   66.66 |   99.09 | 151-152                                                                                                                                                                                     
  LocalizedLabel.vue                                      |     100 |      100 |     100 |     100 |                                                                                                                                                                                             
  ModeSelector.vue                                        |     100 |    93.47 |     100 |     100 | 91,159,253                                                                                                                                                                                  
  Pagination.vue                                          |     100 |      100 |     100 |     100 |                                                                                                                                                                                             
  StatusIcon.vue                                          |     100 |      100 |     100 |     100 |                                                                                                                                                                                             
  TypeSelector.vue                                        |   94.71 |    78.57 |   85.71 |   94.71 | 163-167,179-181,185-188                                                                                                                                                                     
  TypeToString.vue                                        |   99.34 |    94.11 |     100 |   99.34 | 81                                                                                                                                                                                          
  WidgetBase.vue                                          |     100 |      100 |     100 |     100 |                                                                                                                                                                                             
  ZObjectSelector.vue                                     |   95.86 |    87.23 |    92.3 |   95.86 | 185-186,189-190,198-199,206-207,394,402-407,499-501,516-517,543-544,555-556,585-587,636-637                                                                                                 
 ext.wikilambda.app/components/function/editor            |   99.58 |    93.05 |     100 |   99.58 |                                                                                                                                                                                             
  FunctionEditor.vue                                      |   98.62 |    83.78 |     100 |   98.62 | 126,130-132                                                                                                                                                                                 
  FunctionEditorAliases.vue                               |     100 |      100 |     100 |     100 |                                                                                                                                                                                             
  FunctionEditorDescription.vue                           |   98.88 |    94.44 |     100 |   98.88 | 139-140                                                                                                                                                                                     
  FunctionEditorField.vue                                 |     100 |      100 |     100 |     100 |                                                                                                                                                                                             
  FunctionEditorInputs.vue                                |     100 |      100 |     100 |     100 |                                                                                                                                                                                             
  FunctionEditorInputsItem.vue                            |     100 |    84.61 |     100 |     100 | 222,231                                                                                                                                                                                     
  FunctionEditorLanguage.vue                              |     100 |      100 |     100 |     100 |                                                                                                                                                                                             
  FunctionEditorLanguageBlock.vue                         |     100 |      100 |     100 |     100 |                                                                                                                                                                                             
  FunctionEditorName.vue                                  |   98.94 |    94.44 |     100 |   98.94 | 147-148                                                                                                                                                                                     
  FunctionEditorOutput.vue                                |     100 |      100 |     100 |     100 |                                                                                                                                                                                             
 ext.wikilambda.app/components/function/viewer            |   98.73 |    96.06 |   97.95 |   98.73 |                                                                                                                                                                                             
  FunctionTesterTable.vue                                 |      95 |    85.71 |    87.5 |      95 | 91-92,109,159-164                                                                                                                                                                           
  FunctionViewerDetails.vue                               |   99.28 |    97.97 |     100 |   99.28 | 225-226,551,570,588                                                                                                                                                                         
  FunctionViewerDetailsTable.vue                          |     100 |      100 |     100 |     100 |                                                                                                                                                                                             
 ext.wikilambda.app/components/types                      |   97.16 |    86.69 |   93.71 |   97.16 |                                                                                                                                                                                             
  ZArgumentReference.vue                                  |     100 |    91.66 |     100 |     100 | 145                                                                                                                                                                                         
  ZBoolean.vue                                            |     100 |      100 |     100 |     100 |                                                                                                                                                                                             
  ZCode.vue                                               |   96.53 |    91.83 |   91.66 |   96.53 | 164,207,335,381-392,472-473                                                                                                                                                                 
  ZFunctionCall.vue                                       |     100 |       75 |     100 |     100 | 78                                                                                                                                                                                          
  ZHTMLFragment.vue                                       |     100 |       80 |     100 |     100 | 115                                                                                                                                                                                         
  ZImplementation.vue                                     |   97.45 |      100 |    90.9 |   97.45 | 192-198                                                                                                                                                                                     
  ZMonolingualString.vue                                  |     100 |     92.3 |     100 |     100 | 144                                                                                                                                                                                         
  ZObjectKeyValue.vue                                     |   93.01 |     80.7 |    91.3 |   93.01 | 218-219,247-248,268-269,481-482,530-532,555-556,561-564,576-578,593-594,621-626,662-667,681-682,701-706,784-788,790-791,793-794,796-797,799,801,811-812                                     
  ZObjectKeyValueSet.vue                                  |     100 |       60 |     100 |     100 | 70,78                                                                                                                                                                                       
  ZObjectStringRenderer.vue                               |   94.64 |    83.01 |   80.76 |   94.64 | 256,277-278,283-284,330-331,342-343,388-393,466,491-494,519-520,527-534                                                                                                                     
  ZObjectToString.vue                                     |   97.31 |    87.77 |   96.29 |   97.31 | 333-335,351-353,409-411,415-416,421-422,573-576                                                                                                                                             
  ZReference.vue                                          |     100 |    90.47 |     100 |     100 | 110,137                                                                                                                                                                                     
  ZString.vue                                             |     100 |      100 |     100 |     100 |                                                                                                                                                                                             
  ZTester.vue                                             |   99.25 |    95.65 |     100 |   99.25 | 197-198                                                                                                                                                                                     
  ZTypedList.vue                                          |     100 |    85.71 |     100 |     100 | 94                                                                                                                                                                                          
  ZTypedListItems.vue                                     |     100 |      100 |     100 |     100 |                                                                                                                                                                                             
  ZTypedListType.vue                                      |     100 |      100 |     100 |     100 |                                                                                                                                                                                             
 ext.wikilambda.app/components/types/wikidata             |   98.07 |    83.92 |   91.93 |   98.07 |                                                                                                                                                                                             
  EntitySelector.vue                                      |   94.84 |    78.78 |      90 |   94.84 | 89,93,182-188,198-199,225-226                                                                                                                                                               
  Enum.vue                                                |     100 |    88.88 |     100 |     100 | 131,143                                                                                                                                                                                     
  Item.vue                                                |   98.94 |    81.81 |    87.5 |   98.94 | 153-154                                                                                                                                                                                     
  Lexeme.vue                                              |    97.9 |    81.81 |    87.5 |    97.9 | 153-156                                                                                                                                                                                     
  LexemeForm.vue                                          |   97.43 |    81.81 |    87.5 |   97.43 | 155-159                                                                                                                                                                                     
  Property.vue                                            |   98.94 |    81.81 |    87.5 |   98.94 | 154-155                                                                                                                                                                                     
  ReferenceSelector.vue                                   |     100 |    93.33 |     100 |     100 | 119                                                                                                                                                                                         
  wikidataIconSvg.js                                      |     100 |      100 |     100 |     100 |                                                                                                                                                                                             
 ext.wikilambda.app/components/visualeditor               |   98.08 |    96.57 |    87.5 |   98.08 |                                                                                                                                                                                             
  ExpandableDescription.vue                               |   98.62 |      100 |   83.33 |   98.62 | 91-92                                                                                                                                                                                       
  FunctionCallSetup.vue                                   |   95.52 |      100 |   66.66 |   95.52 | 99,106,112-115                                                                                                                                                                              
  FunctionInputField.vue                                  |     100 |      100 |     100 |     100 |                                                                                                                                                                                             
  FunctionInputPreview.vue                                |   98.09 |    95.08 |   85.18 |   98.09 | 148-149,389-390,411,499-503                                                                                                                                                                 
  FunctionInputSetup.vue                                  |   98.88 |      100 |      95 |   98.88 | 116-119                                                                                                                                                                                     
  FunctionSelect.vue                                      |   95.89 |    88.88 |      90 |   95.89 | 186-187,197-198,213-215,232-235                                                                                                                                                             
  FunctionSelectItem.vue                                  |     100 |      100 |     100 |     100 |                                                                                                                                                                                             
  wikifunctionsIconSvg.js                                 |     100 |      100 |     100 |     100 |                                                                                                                                                                                             
 ext.wikilambda.app/components/visualeditor/fields        |   96.75 |    90.35 |   96.22 |   96.75 |                                                                                                                                                                                             
  FunctionInputEnum.vue                                   |   98.46 |    95.83 |    92.3 |   98.46 | 92,163-164                                                                                                                                                                                  
  FunctionInputLanguage.vue                               |   98.78 |     90.9 |     100 |   98.78 | 101-102                                                                                                                                                                                     
  FunctionInputParser.vue                                 |   93.09 |     87.8 |      95 |   93.09 | 105-107,184-189,200-201,241-242,321-327,339-343                                                                                                                                             
  FunctionInputString.vue                                 |     100 |      100 |     100 |     100 |                                                                                                                                                                                             
  FunctionInputWikidata.vue                               |   99.04 |       88 |     100 |   99.04 | 135-136                                                                                                                                                                                     
 ext.wikilambda.app/components/widgets/about              |   97.94 |    93.33 |      90 |   97.94 |                                                                                                                                                                                             
  About.vue                                               |    98.5 |    97.46 |   92.85 |    98.5 | 238,280-283,318-319,402-403                                                                                                                                                                 
  AboutLanguageBlock.vue                                  |   99.18 |    97.56 |   83.33 |   99.18 | 418,444,470,499-500                                                                                                                                                                         
  AboutLanguagesDialog.vue                                |   95.15 |    76.66 |   92.85 |   95.15 | 252-254,266-268,283-284,316-317,319-320,322-323,325-326,332-334                                                                                                                             
 ext.wikilambda.app/components/widgets/function-evaluator |   84.02 |    83.51 |   67.74 |   84.02 |                                                                                                                                                                                             
  EvaluationResult.vue                                    |   96.71 |    71.42 |   71.42 |   96.71 | 112,121-122,134-135                                                                                                                                                                         
  FunctionEvaluator.vue                                   |     100 |    91.66 |     100 |     100 | 440,469-471                                                                                                                                                                                 
  FunctionMetadataDialog.vue                              |   72.59 |       75 |   45.45 |   72.59 | 218-219,252-253,262,271-275,299-300,306-307,331-383,396-424,432,438-439,524-527,550-567,575-577,593-596,604-608,619-628,639-650,663-673,685-696,706-712,723-733,742,761-763,774-814,833-836 
 ext.wikilambda.app/components/widgets/function-explorer  |   99.43 |      100 |   91.66 |   99.43 |                                                                                                                                                                                             
  FunctionExplorer.vue                                    |   99.43 |      100 |   91.66 |   99.43 | 293-294                                                                                                                                                                                     
 ext.wikilambda.app/components/widgets/function-report    |   97.71 |    93.97 |   89.65 |   97.71 |                                                                                                                                                                                             
  FunctionReport.vue                                      |   97.61 |    90.74 |   90.47 |   97.61 | 228-230,288-290,296-298                                                                                                                                                                     
  FunctionReportItem.vue                                  |   97.88 |      100 |    87.5 |   97.88 | 182-186                                                                                                                                                                                     
 ext.wikilambda.app/components/widgets/publish            |   96.59 |    85.13 |   94.73 |   96.59 |                                                                                                                                                                                             
  LeaveEditorDialog.vue                                   |     100 |      100 |     100 |     100 |                                                                                                                                                                                             
  Publish.vue                                             |   90.96 |    82.35 |    87.5 |   90.96 | 105-112,196-205,208,210-214,232-234                                                                                                                                                         
  PublishDialog.vue                                       |     100 |    85.71 |     100 |     100 | 238,300,349-351                                                                                                                                                                             
 ext.wikilambda.app/composables                           |     100 |      100 |     100 |     100 |                                                                                                                                                                                             
  useBreakpoints.js                                       |     100 |      100 |     100 |     100 |                                                                                                                                                                                             
 ext.wikilambda.app/mixins                                |   99.36 |    94.11 |     100 |   99.36 |                                                                                                                                                                                             
  clipboardMixin.js                                       |     100 |      100 |     100 |     100 |                                                                                                                                                                                             
  errorMixin.js                                           |   98.13 |    89.47 |     100 |   98.13 | 61-62                                                                                                                                                                                       
  eventLogMixin.js                                        |   97.43 |    93.33 |     100 |   97.43 | 45-46                                                                                                                                                                                       
  metadataMixin.js                                        |     100 |      100 |     100 |     100 |                                                                                                                                                                                             
  pageTitleMixin.js                                       |     100 |    93.33 |     100 |     100 | 71                                                                                                                                                                                          
  typeMixin.js                                            |     100 |      100 |     100 |     100 |                                                                                                                                                                                             
  zobjectMixin.js                                         |     100 |    94.11 |     100 |     100 | 80                                                                                                                                                                                          
 ext.wikilambda.app/store                                 |     100 |      100 |     100 |     100 |                                                                                                                                                                                             
  index.js                                                |     100 |      100 |     100 |     100 |                                                                                                                                                                                             
 ext.wikilambda.app/store/classes                         |    97.2 |    88.67 |     100 |    97.2 |                                                                                                                                                                                             
  ApiError.js                                             |   95.73 |    82.35 |     100 |   95.73 | 151-153,159-160,200-203                                                                                                                                                                     
  LabelData.js                                            |     100 |      100 |     100 |     100 |                                                                                                                                                                                             
 ext.wikilambda.app/store/stores                          |   98.84 |    95.51 |   98.16 |   98.84 |                                                                                                                                                                                             
  errors.js                                               |    97.9 |       96 |    92.3 |    97.9 | 60,167-169                                                                                                                                                                                  
  functionCall.js                                         |   97.22 |     87.5 |     100 |   97.22 | 31-32                                                                                                                                                                                       
  languages.js                                            |   92.39 |    76.92 |     100 |   92.39 | 26-29,43-45                                                                                                                                                                                 
  library.js                                              |      98 |    95.32 |   98.24 |      98 | 138-139,514-515,540-541,552-555,559,650-655,683-685,890,1038-1039,1169                                                                                                                      
  listItems.js                                            |     100 |      100 |     100 |     100 |                                                                                                                                                                                             
  programmingLanguages.js                                 |     100 |      100 |     100 |     100 |                                                                                                                                                                                             
  router.js                                               |     100 |     97.5 |     100 |     100 | 21                                                                                                                                                                                          
  testResults.js                                          |     100 |    91.66 |     100 |     100 | 135,205,255-257                                                                                                                                                                             
  user.js                                                 |     100 |      100 |     100 |     100 |                                                                                                                                                                                             
  visualeditor.js                                         |   98.31 |    95.45 |   89.47 |   98.31 | 62,72,95-96                                                                                                                                                                                 
  zfunction.js                                            |     100 |    96.49 |     100 |     100 | 90                                                                                                                                                                                          
  zobject.js                                              |   99.28 |    96.29 |     100 |   99.28 | 539-540,579-580,716-717,1089-1090                                                                                                                                                           
  ztype.js                                                |   99.38 |      100 |     100 |   99.38 | 274-275                                                                                                                                                                                     
 ext.wikilambda.app/store/stores/wikidata                 |   99.88 |    95.37 |     100 |   99.88 |                                                                                                                                                                                             
  entities.js                                             |   99.49 |    98.03 |     100 |   99.49 | 83                                                                                                                                                                                          
  items.js                                                |     100 |    93.75 |     100 |     100 | 92,95,116                                                                                                                                                                                   
  lexemes.js                                              |     100 |    95.65 |     100 |     100 | 113,116,149                                                                                                                                                                                 
  properties.js                                           |     100 |    93.75 |     100 |     100 | 89,92,114                                                                                                                                                                                   
 ext.wikilambda.app/store/stores/zobject                  |   98.73 |     94.8 |     100 |   98.73 |                                                                                                                                                                                             
  currentPage.js                                          |     100 |       95 |     100 |     100 | 121                                                                                                                                                                                         
  factory.js                                              |   98.59 |    95.23 |     100 |   98.59 | 169-175,364-367,827                                                                                                                                                                         
  submission.js                                           |    98.5 |    94.23 |     100 |    98.5 | 198,373-374,505-506,511-512,543-544                                                                                                                                                         
 ext.wikilambda.app/utils                                 |   97.96 |    95.22 |    98.8 |   97.96 |                                                                                                                                                                                             
  apiUtils.js                                             |   98.64 |       78 |     100 |   98.64 | 263-265,329-330                                                                                                                                                                             
  miscUtils.js                                            |     100 |      100 |     100 |     100 |                                                                                                                                                                                             
  schemata.js                                             |   96.45 |    91.57 |    90.9 |   96.45 | 123,174-179,211-212,214-215                                                                                                                                                                 
  typeUtils.js                                            |   96.91 |    98.68 |     100 |   96.91 | 508-529                                                                                                                                                                                     
  urlUtils.js                                             |     100 |      100 |     100 |     100 |                                                                                                                                                                                             
  wikidataUtils.js                                        |     100 |      100 |     100 |     100 |                                                                                                                                                                                             
  zobjectUtils.js                                         |   98.67 |    99.03 |     100 |   98.67 | 612-616,658-662                                                                                                                                                                             
 ext.wikilambda.app/views                                 |   90.09 |    77.77 |   33.33 |   90.09 |                                                                                                                                                                                             
  Default.vue                                             |   85.41 |      100 |       0 |   85.41 | 99-101,120-121,131,140,150-153,160,167,174-175,188-200,210-213,216-218                                                                                                                      
  FunctionEditor.vue                                      |     100 |      100 |     100 |     100 |                                                                                                                                                                                             
  FunctionEvaluator.vue                                   |     100 |      100 |     100 |     100 |                                                                                                                                                                                             
  FunctionViewer.vue                                      |   93.54 |    71.42 |      80 |   93.54 | 87-94                                                                                                                                                                                       
 ext.wikilambda.languageselector/components               |   98.05 |    93.75 |   94.11 |   98.05 |                                                                                                                                                                                             
  LanguageSelector.vue                                    |   98.05 |    93.75 |   94.11 |   98.05 | 229-230,268-269,290-291                                                                                                                                                                     
----------------------------------------------------------|---------|----------|---------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

--- end ---
$ node_modules/.bin/jest -u
--- stderr ---
PASS tests/jest/components/default/ZObjectKeyValue.test.js
FAIL tests/jest/components/base/ModeSelector.test.js
  ● ModeSelector › basic rendering › opens the menu when button is clicked

    expect(received).toBe(expected) // Object.is equality

    Expected: true
    Received: false

    Ignored nodes: comments, script, style
    <html>
      <head />
      <body>
        
        
        
        
        
        
      </body>
    </html>

      85 | 			await wrapper.vm.$nextTick();
      86 |
    > 87 | 			await waitFor( () => expect( menu.isVisible() ).toBe( true ) );
         | 			                                                ^
      88 | 		} );
      89 | 	} );
      90 |

      at tests/jest/components/base/ModeSelector.test.js:87:52
      at runWithExpensiveErrorDiagnosticsDisabled (node_modules/@testing-library/dom/dist/config.js:47:12)
      at checkCallback (node_modules/@testing-library/dom/dist/wait-for.js:124:77)
      at checkRealTimersCallback (node_modules/@testing-library/dom/dist/wait-for.js:118:16)
      at Timeout.task [as _onTimeout] (node_modules/jsdom/lib/jsdom/browser/Window.js:520:19)

PASS tests/jest/integration/CreateNewFunction.test.js
PASS tests/jest/integration/FunctionEditorGenericTypes.test.js (5.403 s)
PASS tests/jest/components/default/ZObjectToString.test.js (8.772 s)
PASS tests/jest/integration/CancelEditExistingFunction.test.js
PASS tests/jest/integration/FunctionEditorEdgeCases.test.js (5.024 s)
PASS tests/jest/components/base/ZObjectSelector.test.js
PASS tests/jest/components/widgets/about/About.test.js
PASS tests/jest/integration/DisconnectFunctionImplementation.test.js
PASS tests/jest/integration/CancelEditNewFunction.test.js
PASS tests/jest/components/widgets/function-evaluator/FunctionEvaluator.test.js
PASS tests/jest/integration/RunFunctionCall.test.js
PASS tests/jest/integration/EditFunction.test.js
PASS tests/jest/integration/DisconnectFunctionTest.test.js
PASS tests/jest/integration/ConnectFunctionImplementation.test.js
PASS tests/jest/integration/ConnectFunctionTest.test.js
PASS tests/jest/components/default/ZTypedListType.test.js
PASS tests/jest/languageselector/LanguageSelector.test.js
PASS tests/jest/components/widgets/function-explorer/FunctionExplorer.test.js
PASS tests/jest/components/visualeditor/FunctionInputPreview.test.js
PASS tests/jest/components/widgets/function-evaluator/EvaluationResult.test.js
PASS tests/jest/components/function/viewer/FunctionViewerDetails.test.js
PASS tests/jest/components/default/ZObjectStringRenderer.test.js
PASS tests/jest/components/visualeditor/FunctionInputField.test.js
PASS tests/jest/components/visualeditor/FunctionInputSetup.test.js
PASS tests/jest/store/stores/zobject.test.js
PASS tests/jest/components/default/wikidata/EntitySelector.test.js
PASS tests/jest/components/default/ZString.test.js
PASS tests/jest/components/App.test.js
PASS tests/jest/components/function/viewer/FunctionViewerDetailsTable.test.js
PASS tests/jest/store/index.test.js
PASS tests/jest/components/visualeditor/ExpandableDescription.test.js
PASS tests/jest/components/default/ZTester.test.js
PASS tests/jest/components/visualeditor/FunctionSelect.test.js
PASS tests/jest/components/visualeditor/FunctionCallSetup.test.js
PASS tests/jest/components/widgets/publish/PublishDialog.test.js
PASS tests/jest/components/base/ExpandedToggle.test.js
PASS tests/jest/views/FunctionViewer.test.js
PASS tests/jest/utils/wikidataUtils.test.js
PASS tests/jest/components/function/editor/FunctionEditorLanguage.test.js
PASS tests/jest/components/widgets/publish/LeaveEditorDialog.test.js
PASS tests/jest/components/default/ZTypedListItems.test.js
PASS tests/jest/components/visualeditor/fields/FunctionInputString.test.js
PASS tests/jest/components/widgets/function-report/FunctionReport.test.js
PASS tests/jest/components/default/ZFunctionCall.test.js
PASS tests/jest/components/default/ZHTMLFragment.test.js
PASS tests/jest/components/base/TypeToString.test.js
PASS tests/jest/components/base/Pagination.test.js
PASS tests/jest/mixins/clipboardMixin.test.js
PASS tests/jest/store/stores/programmingLanguages.test.js
PASS tests/jest/composables/useBreakpoints.test.js
PASS tests/jest/components/default/ZBoolean.test.js
PASS tests/jest/components/base/LocalizedLabel.test.js
PASS tests/jest/mixins/eventLogMixin.test.js
PASS tests/jest/components/function/editor/FunctionEditorOutput.test.js
PASS tests/jest/components/function/editor/FunctionEditor.test.js
PASS tests/jest/store/stores/languages.test.js
PASS tests/jest/components/default/ZCode.test.js
PASS tests/jest/components/widgets/publish/Publish.test.js
PASS tests/jest/mixins/zobjectMixin.test.js
PASS tests/jest/components/default/ZImplementation.test.js
PASS tests/jest/store/stores/functionCall.test.js
PASS tests/jest/components/widgets/about/AboutLanguagesDialog.test.js
PASS tests/jest/components/visualeditor/fields/FunctionInputEnum.test.js
PASS tests/jest/components/visualeditor/fields/FunctionInputLanguage.test.js
PASS tests/jest/store/stores/zfunction.test.js
PASS tests/jest/store/stores/user.test.js
PASS tests/jest/components/default/ZMonolingualString.test.js
PASS tests/jest/components/widgets/function-report/FunctionReportItem.test.js
PASS tests/jest/store/stores/wikidata/items.test.js
PASS tests/jest/store/stores/submission.test.js
PASS tests/jest/components/function/editor/FunctionEditorAliases.test.js
PASS tests/jest/components/visualeditor/fields/FunctionInputWikidata.test.js
PASS tests/jest/store/stores/listItems.test.js
PASS tests/jest/components/function/editor/FunctionEditorInputs.test.js
PASS tests/jest/components/default/wikidata/Enum.test.js
PASS tests/jest/components/default/wikidata/ReferenceSelector.test.js
PASS tests/jest/utils/zobjectUtils.test.js
PASS tests/jest/components/visualeditor/fields/FunctionInputParser.test.js
PASS tests/jest/components/function/editor/FunctionEditorLanguageBlock.test.js
PASS tests/jest/store/stores/wikidata/properties.test.js
PASS tests/jest/utils/urlUtils.test.js
PASS tests/jest/components/default/ZTypedList.test.js
PASS tests/jest/store/stores/library.test.js
PASS tests/jest/store/stores/router.test.js
PASS tests/jest/store/stores/wikidata/entities.test.js
PASS tests/jest/components/widgets/about/AboutLanguageBlock.test.js
PASS tests/jest/components/default/wikidata/LexemeForm.test.js
PASS tests/jest/mixins/errorMixin.test.js
PASS tests/jest/utils/miscUtils.test.js
PASS tests/jest/store/stores/visualeditor.test.js
PASS tests/jest/store/stores/errors.test.js
PASS tests/jest/components/base/ClipboardManager.test.js
PASS tests/jest/store/stores/wikidata/lexemes.test.js
PASS tests/jest/mixins/pageTitleMixin.test.js
PASS tests/jest/components/base/CodeEditor.test.js
PASS tests/jest/components/function/editor/FunctionEditorInputsItem.test.js
PASS tests/jest/components/default/ZReference.test.js
PASS tests/jest/components/function/editor/FunctionEditorDescription.test.js
PASS tests/jest/components/function/editor/FunctionEditorName.test.js
PASS tests/jest/components/default/ZArgumentReference.test.js
PASS tests/jest/store/stores/ztype.test.js
PASS tests/jest/store/stores/factory.test.js
PASS tests/jest/store/classes/ApiError.test.js
PASS tests/jest/utils/schemata.test.js
PASS tests/jest/components/default/wikidata/Property.test.js
PASS tests/jest/store/stores/testResults.test.js
PASS tests/jest/components/default/wikidata/Item.test.js
PASS tests/jest/components/base/TypeSelector.test.js
PASS tests/jest/utils/typeUtils.test.js
PASS tests/jest/components/default/wikidata/Lexeme.test.js
PASS tests/jest/store/stores/currentPage.test.js
node:internal/process/promises:288
            triggerUncaughtException(err, true /* fromPromise */);
            ^

[UnhandledPromiseRejection: This error originated either by throwing inside of an async function without a catch block, or by rejecting a promise which was not handled with .catch(). The promise rejected with the reason "Maximum recursive updates exceeded in component <CdxSelect>. This means you have a reactive effect that is mutating its own dependencies and thus recursively triggering itself. Possible sources include component template, render function, updated hook or watcher source function.".] {
  code: 'ERR_UNHANDLED_REJECTION'
}

Node.js v18.19.0
node:internal/process/promises:288
            triggerUncaughtException(err, true /* fromPromise */);
            ^

[UnhandledPromiseRejection: This error originated either by throwing inside of an async function without a catch block, or by rejecting a promise which was not handled with .catch(). The promise rejected with the reason "Maximum recursive updates exceeded in component <CdxSelect>. This means you have a reactive effect that is mutating its own dependencies and thus recursively triggering itself. Possible sources include component template, render function, updated hook or watcher source function.".] {
  code: 'ERR_UNHANDLED_REJECTION'
}

Node.js v18.19.0
node:internal/process/promises:288
            triggerUncaughtException(err, true /* fromPromise */);
            ^

[UnhandledPromiseRejection: This error originated either by throwing inside of an async function without a catch block, or by rejecting a promise which was not handled with .catch(). The promise rejected with the reason "Maximum recursive updates exceeded in component <CdxSelect>. This means you have a reactive effect that is mutating its own dependencies and thus recursively triggering itself. Possible sources include component template, render function, updated hook or watcher source function.".] {
  code: 'ERR_UNHANDLED_REJECTION'
}

Node.js v18.19.0
node:internal/process/promises:288
            triggerUncaughtException(err, true /* fromPromise */);
            ^

[UnhandledPromiseRejection: This error originated either by throwing inside of an async function without a catch block, or by rejecting a promise which was not handled with .catch(). The promise rejected with the reason "Maximum recursive updates exceeded in component <CdxSelect>. This means you have a reactive effect that is mutating its own dependencies and thus recursively triggering itself. Possible sources include component template, render function, updated hook or watcher source function.".] {
  code: 'ERR_UNHANDLED_REJECTION'
}

Node.js v18.19.0
FAIL tests/jest/components/widgets/function-evaluator/FunctionMetadataDialog.test.js
  ● Test suite failed to run

    Jest worker encountered 4 child process exceptions, exceeding retry limit

      at ChildProcessWorker.initialize (node_modules/jest-worker/build/workers/ChildProcessWorker.js:181:21)

node:internal/process/promises:288
            triggerUncaughtException(err, true /* fromPromise */);
            ^

[UnhandledPromiseRejection: This error originated either by throwing inside of an async function without a catch block, or by rejecting a promise which was not handled with .catch(). The promise rejected with the reason "Maximum recursive updates exceeded in component <CdxLookup>. This means you have a reactive effect that is mutating its own dependencies and thus recursively triggering itself. Possible sources include component template, render function, updated hook or watcher source function.".] {
  code: 'ERR_UNHANDLED_REJECTION'
}

Node.js v18.19.0
node:internal/process/promises:288
            triggerUncaughtException(err, true /* fromPromise */);
            ^

[UnhandledPromiseRejection: This error originated either by throwing inside of an async function without a catch block, or by rejecting a promise which was not handled with .catch(). The promise rejected with the reason "Maximum recursive updates exceeded in component <CdxLookup>. This means you have a reactive effect that is mutating its own dependencies and thus recursively triggering itself. Possible sources include component template, render function, updated hook or watcher source function.".] {
  code: 'ERR_UNHANDLED_REJECTION'
}

Node.js v18.19.0
node:internal/process/promises:288
            triggerUncaughtException(err, true /* fromPromise */);
            ^

[UnhandledPromiseRejection: This error originated either by throwing inside of an async function without a catch block, or by rejecting a promise which was not handled with .catch(). The promise rejected with the reason "Maximum recursive updates exceeded in component <CdxLookup>. This means you have a reactive effect that is mutating its own dependencies and thus recursively triggering itself. Possible sources include component template, render function, updated hook or watcher source function.".] {
  code: 'ERR_UNHANDLED_REJECTION'
}

Node.js v18.19.0
node:internal/process/promises:288
            triggerUncaughtException(err, true /* fromPromise */);
            ^

[UnhandledPromiseRejection: This error originated either by throwing inside of an async function without a catch block, or by rejecting a promise which was not handled with .catch(). The promise rejected with the reason "Maximum recursive updates exceeded in component <CdxLookup>. This means you have a reactive effect that is mutating its own dependencies and thus recursively triggering itself. Possible sources include component template, render function, updated hook or watcher source function.".] {
  code: 'ERR_UNHANDLED_REJECTION'
}

Node.js v18.19.0
node:internal/process/promises:288
            triggerUncaughtException(err, true /* fromPromise */);
            ^

[UnhandledPromiseRejection: This error originated either by throwing inside of an async function without a catch block, or by rejecting a promise which was not handled with .catch(). The promise rejected with the reason "Maximum recursive updates exceeded in component <CdxLookup>. This means you have a reactive effect that is mutating its own dependencies and thus recursively triggering itself. Possible sources include component template, render function, updated hook or watcher source function.".] {
  code: 'ERR_UNHANDLED_REJECTION'
}

Node.js v18.19.0
node:internal/process/promises:288
            triggerUncaughtException(err, true /* fromPromise */);
            ^

[UnhandledPromiseRejection: This error originated either by throwing inside of an async function without a catch block, or by rejecting a promise which was not handled with .catch(). The promise rejected with the reason "Maximum recursive updates exceeded in component <CdxLookup>. This means you have a reactive effect that is mutating its own dependencies and thus recursively triggering itself. Possible sources include component template, render function, updated hook or watcher source function.".] {
  code: 'ERR_UNHANDLED_REJECTION'
}

Node.js v18.19.0
node:internal/process/promises:288
            triggerUncaughtException(err, true /* fromPromise */);
            ^

[UnhandledPromiseRejection: This error originated either by throwing inside of an async function without a catch block, or by rejecting a promise which was not handled with .catch(). The promise rejected with the reason "Maximum recursive updates exceeded in component <CdxLookup>. This means you have a reactive effect that is mutating its own dependencies and thus recursively triggering itself. Possible sources include component template, render function, updated hook or watcher source function.".] {
  code: 'ERR_UNHANDLED_REJECTION'
}

Node.js v18.19.0
FAIL tests/jest/integration/CreateNewTester.test.js
  ● Test suite failed to run

    Jest worker encountered 4 child process exceptions, exceeding retry limit

      at ChildProcessWorker.initialize (node_modules/jest-worker/build/workers/ChildProcessWorker.js:181:21)

node:internal/process/promises:288
            triggerUncaughtException(err, true /* fromPromise */);
            ^

[UnhandledPromiseRejection: This error originated either by throwing inside of an async function without a catch block, or by rejecting a promise which was not handled with .catch(). The promise rejected with the reason "Maximum recursive updates exceeded in component <CdxLookup>. This means you have a reactive effect that is mutating its own dependencies and thus recursively triggering itself. Possible sources include component template, render function, updated hook or watcher source function.".] {
  code: 'ERR_UNHANDLED_REJECTION'
}

Node.js v18.19.0
node:internal/process/promises:288
            triggerUncaughtException(err, true /* fromPromise */);
            ^

[UnhandledPromiseRejection: This error originated either by throwing inside of an async function without a catch block, or by rejecting a promise which was not handled with .catch(). The promise rejected with the reason "Maximum recursive updates exceeded in component <CdxLookup>. This means you have a reactive effect that is mutating its own dependencies and thus recursively triggering itself. Possible sources include component template, render function, updated hook or watcher source function.".] {
  code: 'ERR_UNHANDLED_REJECTION'
}

Node.js v18.19.0
node:internal/process/promises:288
            triggerUncaughtException(err, true /* fromPromise */);
            ^

[UnhandledPromiseRejection: This error originated either by throwing inside of an async function without a catch block, or by rejecting a promise which was not handled with .catch(). The promise rejected with the reason "Maximum recursive updates exceeded in component <CdxLookup>. This means you have a reactive effect that is mutating its own dependencies and thus recursively triggering itself. Possible sources include component template, render function, updated hook or watcher source function.".] {
  code: 'ERR_UNHANDLED_REJECTION'
}

Node.js v18.19.0
FAIL tests/jest/integration/CreateNewCompositionImplementation.test.js
  ● Test suite failed to run

    Jest worker encountered 4 child process exceptions, exceeding retry limit

      at ChildProcessWorker.initialize (node_modules/jest-worker/build/workers/ChildProcessWorker.js:181:21)

node:internal/process/promises:288
            triggerUncaughtException(err, true /* fromPromise */);
            ^

[UnhandledPromiseRejection: This error originated either by throwing inside of an async function without a catch block, or by rejecting a promise which was not handled with .catch(). The promise rejected with the reason "Maximum recursive updates exceeded in component <CdxLookup>. This means you have a reactive effect that is mutating its own dependencies and thus recursively triggering itself. Possible sources include component template, render function, updated hook or watcher source function.".] {
  code: 'ERR_UNHANDLED_REJECTION'
}

Node.js v18.19.0
node:internal/process/promises:288
            triggerUncaughtException(err, true /* fromPromise */);
            ^

[UnhandledPromiseRejection: This error originated either by throwing inside of an async function without a catch block, or by rejecting a promise which was not handled with .catch(). The promise rejected with the reason "Maximum recursive updates exceeded in component <CdxLookup>. This means you have a reactive effect that is mutating its own dependencies and thus recursively triggering itself. Possible sources include component template, render function, updated hook or watcher source function.".] {
  code: 'ERR_UNHANDLED_REJECTION'
}

Node.js v18.19.0
node:internal/process/promises:288
            triggerUncaughtException(err, true /* fromPromise */);
            ^

[UnhandledPromiseRejection: This error originated either by throwing inside of an async function without a catch block, or by rejecting a promise which was not handled with .catch(). The promise rejected with the reason "Maximum recursive updates exceeded in component <CdxLookup>. This means you have a reactive effect that is mutating its own dependencies and thus recursively triggering itself. Possible sources include component template, render function, updated hook or watcher source function.".] {
  code: 'ERR_UNHANDLED_REJECTION'
}

Node.js v18.19.0
node:internal/process/promises:288
            triggerUncaughtException(err, true /* fromPromise */);
            ^

[UnhandledPromiseRejection: This error originated either by throwing inside of an async function without a catch block, or by rejecting a promise which was not handled with .catch(). The promise rejected with the reason "Maximum recursive updates exceeded in component <CdxLookup>. This means you have a reactive effect that is mutating its own dependencies and thus recursively triggering itself. Possible sources include component template, render function, updated hook or watcher source function.".] {
  code: 'ERR_UNHANDLED_REJECTION'
}

Node.js v18.19.0
FAIL tests/jest/integration/CreateNewWikidataEnum.test.js
  ● Test suite failed to run

    Jest worker encountered 4 child process exceptions, exceeding retry limit

      at ChildProcessWorker.initialize (node_modules/jest-worker/build/workers/ChildProcessWorker.js:181:21)

node:internal/process/promises:288
            triggerUncaughtException(err, true /* fromPromise */);
            ^

[UnhandledPromiseRejection: This error originated either by throwing inside of an async function without a catch block, or by rejecting a promise which was not handled with .catch(). The promise rejected with the reason "Maximum recursive updates exceeded in component <CdxLookup>. This means you have a reactive effect that is mutating its own dependencies and thus recursively triggering itself. Possible sources include component template, render function, updated hook or watcher source function.".] {
  code: 'ERR_UNHANDLED_REJECTION'
}

Node.js v18.19.0
node:internal/process/promises:288
            triggerUncaughtException(err, true /* fromPromise */);
            ^

[UnhandledPromiseRejection: This error originated either by throwing inside of an async function without a catch block, or by rejecting a promise which was not handled with .catch(). The promise rejected with the reason "Maximum recursive updates exceeded in component <CdxLookup>. This means you have a reactive effect that is mutating its own dependencies and thus recursively triggering itself. Possible sources include component template, render function, updated hook or watcher source function.".] {
  code: 'ERR_UNHANDLED_REJECTION'
}

Node.js v18.19.0
FAIL tests/jest/integration/CreateNewCodeImplementation.test.js
  ● Test suite failed to run

    Jest worker encountered 4 child process exceptions, exceeding retry limit

      at ChildProcessWorker.initialize (node_modules/jest-worker/build/workers/ChildProcessWorker.js:181:21)

Jest: "./resources/ext.wikilambda.app/" coverage threshold for functions (95%) not met: 93.62%
Summary of all failing tests
FAIL tests/jest/components/base/ModeSelector.test.js
  ● ModeSelector › basic rendering › opens the menu when button is clicked

    expect(received).toBe(expected) // Object.is equality

    Expected: true
    Received: false

    Ignored nodes: comments, script, style
    <html>
      <head />
      <body>
        
        
        
        
        
        
      </body>
    </html>

      85 | 			await wrapper.vm.$nextTick();
      86 |
    > 87 | 			await waitFor( () => expect( menu.isVisible() ).toBe( true ) );
         | 			                                                ^
      88 | 		} );
      89 | 	} );
      90 |

      at tests/jest/components/base/ModeSelector.test.js:87:52
      at runWithExpensiveErrorDiagnosticsDisabled (node_modules/@testing-library/dom/dist/config.js:47:12)
      at checkCallback (node_modules/@testing-library/dom/dist/wait-for.js:124:77)
      at checkRealTimersCallback (node_modules/@testing-library/dom/dist/wait-for.js:118:16)
      at Timeout.task [as _onTimeout] (node_modules/jsdom/lib/jsdom/browser/Window.js:520:19)

FAIL tests/jest/components/widgets/function-evaluator/FunctionMetadataDialog.test.js
  ● Test suite failed to run

    Jest worker encountered 4 child process exceptions, exceeding retry limit

      at ChildProcessWorker.initialize (node_modules/jest-worker/build/workers/ChildProcessWorker.js:181:21)

FAIL tests/jest/integration/CreateNewTester.test.js
  ● Test suite failed to run

    Jest worker encountered 4 child process exceptions, exceeding retry limit

      at ChildProcessWorker.initialize (node_modules/jest-worker/build/workers/ChildProcessWorker.js:181:21)

FAIL tests/jest/integration/CreateNewCompositionImplementation.test.js
  ● Test suite failed to run

    Jest worker encountered 4 child process exceptions, exceeding retry limit

      at ChildProcessWorker.initialize (node_modules/jest-worker/build/workers/ChildProcessWorker.js:181:21)

FAIL tests/jest/integration/CreateNewWikidataEnum.test.js
  ● Test suite failed to run

    Jest worker encountered 4 child process exceptions, exceeding retry limit

      at ChildProcessWorker.initialize (node_modules/jest-worker/build/workers/ChildProcessWorker.js:181:21)

FAIL tests/jest/integration/CreateNewCodeImplementation.test.js
  ● Test suite failed to run

    Jest worker encountered 4 child process exceptions, exceeding retry limit

      at ChildProcessWorker.initialize (node_modules/jest-worker/build/workers/ChildProcessWorker.js:181:21)


Test Suites: 6 failed, 112 passed, 118 total
Tests:       1 failed, 1 skipped, 1752 passed, 1754 total
Snapshots:   0 total
Time:        933.947 s
Ran all test suites.
--- stdout ---
----------------------------------------------------------|---------|----------|---------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
File                                                      | % Stmts | % Branch | % Funcs | % Lines | Uncovered Line #s                                                                                                                                                                           
----------------------------------------------------------|---------|----------|---------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
All files                                                 |   97.34 |    92.63 |   93.62 |   97.34 |                                                                                                                                                                                             
 ext.wikilambda.app/components                            |   97.74 |      100 |     100 |   97.74 |                                                                                                                                                                                             
  App.vue                                                 |   97.74 |      100 |     100 |   97.74 | 93,97,117                                                                                                                                                                                   
 ext.wikilambda.app/components/base                       |   97.83 |    90.57 |   94.62 |   97.83 |                                                                                                                                                                                             
  ClipboardManager.vue                                    |   97.77 |    85.71 |     100 |   97.77 | 70-71                                                                                                                                                                                       
  CodeEditor.vue                                          |   95.59 |       92 |    92.3 |   95.59 | 90-92,100,263-270,290-291                                                                                                                                                                   
  CustomDialogHeader.vue                                  |     100 |      100 |     100 |     100 |                                                                                                                                                                                             
  ExpandedToggle.vue                                      |     100 |      100 |     100 |     100 |                                                                                                                                                                                             
  KeyBlock.vue                                            |     100 |      100 |     100 |     100 |                                                                                                                                                                                             
  KeyValueBlock.vue                                       |   99.09 |      100 |   66.66 |   99.09 | 151-152                                                                                                                                                                                     
  LocalizedLabel.vue                                      |     100 |      100 |     100 |     100 |                                                                                                                                                                                             
  ModeSelector.vue                                        |     100 |    93.47 |     100 |     100 | 91,159,253                                                                                                                                                                                  
  Pagination.vue                                          |     100 |      100 |     100 |     100 |                                                                                                                                                                                             
  StatusIcon.vue                                          |     100 |      100 |     100 |     100 |                                                                                                                                                                                             
  TypeSelector.vue                                        |   94.71 |    78.57 |   85.71 |   94.71 | 163-167,179-181,185-188                                                                                                                                                                     
  TypeToString.vue                                        |   99.34 |    94.11 |     100 |   99.34 | 81                                                                                                                                                                                          
  WidgetBase.vue                                          |     100 |      100 |     100 |     100 |                                                                                                                                                                                             
  ZObjectSelector.vue                                     |   95.86 |    87.23 |    92.3 |   95.86 | 185-186,189-190,198-199,206-207,394,402-407,499-501,516-517,543-544,555-556,585-587,636-637                                                                                                 
 ext.wikilambda.app/components/function/editor            |   99.58 |    93.05 |     100 |   99.58 |                                                                                                                                                                                             
  FunctionEditor.vue                                      |   98.62 |    83.78 |     100 |   98.62 | 126,130-132                                                                                                                                                                                 
  FunctionEditorAliases.vue                               |     100 |      100 |     100 |     100 |                                                                                                                                                                                             
  FunctionEditorDescription.vue                           |   98.88 |    94.44 |     100 |   98.88 | 139-140                                                                                                                                                                                     
  FunctionEditorField.vue                                 |     100 |      100 |     100 |     100 |                                                                                                                                                                                             
  FunctionEditorInputs.vue                                |     100 |      100 |     100 |     100 |                                                                                                                                                                                             
  FunctionEditorInputsItem.vue                            |     100 |    84.61 |     100 |     100 | 222,231                                                                                                                                                                                     
  FunctionEditorLanguage.vue                              |     100 |      100 |     100 |     100 |                                                                                                                                                                                             
  FunctionEditorLanguageBlock.vue                         |     100 |      100 |     100 |     100 |                                                                                                                                                                                             
  FunctionEditorName.vue                                  |   98.94 |    94.44 |     100 |   98.94 | 147-148                                                                                                                                                                                     
  FunctionEditorOutput.vue                                |     100 |      100 |     100 |     100 |                                                                                                                                                                                             
 ext.wikilambda.app/components/function/viewer            |   98.73 |    96.06 |   97.95 |   98.73 |                                                                                                                                                                                             
  FunctionTesterTable.vue                                 |      95 |    85.71 |    87.5 |      95 | 91-92,109,159-164                                                                                                                                                                           
  FunctionViewerDetails.vue                               |   99.28 |    97.97 |     100 |   99.28 | 225-226,551,570,588                                                                                                                                                                         
  FunctionViewerDetailsTable.vue                          |     100 |      100 |     100 |     100 |                                                                                                                                                                                             
 ext.wikilambda.app/components/types                      |   97.16 |    86.69 |   93.71 |   97.16 |                                                                                                                                                                                             
  ZArgumentReference.vue                                  |     100 |    91.66 |     100 |     100 | 145                                                                                                                                                                                         
  ZBoolean.vue                                            |     100 |      100 |     100 |     100 |                                                                                                                                                                                             
  ZCode.vue                                               |   96.53 |    91.83 |   91.66 |   96.53 | 164,207,335,381-392,472-473                                                                                                                                                                 
  ZFunctionCall.vue                                       |     100 |       75 |     100 |     100 | 78                                                                                                                                                                                          
  ZHTMLFragment.vue                                       |     100 |       80 |     100 |     100 | 115                                                                                                                                                                                         
  ZImplementation.vue                                     |   97.45 |      100 |    90.9 |   97.45 | 192-198                                                                                                                                                                                     
  ZMonolingualString.vue                                  |     100 |     92.3 |     100 |     100 | 144                                                                                                                                                                                         
  ZObjectKeyValue.vue                                     |   93.01 |     80.7 |    91.3 |   93.01 | 218-219,247-248,268-269,481-482,530-532,555-556,561-564,576-578,593-594,621-626,662-667,681-682,701-706,784-788,790-791,793-794,796-797,799,801,811-812                                     
  ZObjectKeyValueSet.vue                                  |     100 |       60 |     100 |     100 | 70,78                                                                                                                                                                                       
  ZObjectStringRenderer.vue                               |   94.64 |    83.01 |   80.76 |   94.64 | 256,277-278,283-284,330-331,342-343,388-393,466,491-494,519-520,527-534                                                                                                                     
  ZObjectToString.vue                                     |   97.31 |    87.77 |   96.29 |   97.31 | 333-335,351-353,409-411,415-416,421-422,573-576                                                                                                                                             
  ZReference.vue                                          |     100 |    90.47 |     100 |     100 | 110,137                                                                                                                                                                                     
  ZString.vue                                             |     100 |      100 |     100 |     100 |                                                                                                                                                                                             
  ZTester.vue                                             |   99.25 |    95.65 |     100 |   99.25 | 197-198                                                                                                                                                                                     
  ZTypedList.vue                                          |     100 |    85.71 |     100 |     100 | 94                                                                                                                                                                                          
  ZTypedListItems.vue                                     |     100 |      100 |     100 |     100 |                                                                                                                                                                                             
  ZTypedListType.vue                                      |     100 |      100 |     100 |     100 |                                                                                                                                                                                             
 ext.wikilambda.app/components/types/wikidata             |   98.07 |    83.92 |   91.93 |   98.07 |                                                                                                                                                                                             
  EntitySelector.vue                                      |   94.84 |    78.78 |      90 |   94.84 | 89,93,182-188,198-199,225-226                                                                                                                                                               
  Enum.vue                                                |     100 |    88.88 |     100 |     100 | 131,143                                                                                                                                                                                     
  Item.vue                                                |   98.94 |    81.81 |    87.5 |   98.94 | 153-154                                                                                                                                                                                     
  Lexeme.vue                                              |    97.9 |    81.81 |    87.5 |    97.9 | 153-156                                                                                                                                                                                     
  LexemeForm.vue                                          |   97.43 |    81.81 |    87.5 |   97.43 | 155-159                                                                                                                                                                                     
  Property.vue                                            |   98.94 |    81.81 |    87.5 |   98.94 | 154-155                                                                                                                                                                                     
  ReferenceSelector.vue                                   |     100 |    93.33 |     100 |     100 | 119                                                                                                                                                                                         
  wikidataIconSvg.js                                      |     100 |      100 |     100 |     100 |                                                                                                                                                                                             
 ext.wikilambda.app/components/visualeditor               |   98.08 |    96.57 |    87.5 |   98.08 |                                                                                                                                                                                             
  ExpandableDescription.vue                               |   98.62 |      100 |   83.33 |   98.62 | 91-92                                                                                                                                                                                       
  FunctionCallSetup.vue                                   |   95.52 |      100 |   66.66 |   95.52 | 99,106,112-115                                                                                                                                                                              
  FunctionInputField.vue                                  |     100 |      100 |     100 |     100 |                                                                                                                                                                                             
  FunctionInputPreview.vue                                |   98.09 |    95.08 |   85.18 |   98.09 | 148-149,389-390,411,499-503                                                                                                                                                                 
  FunctionInputSetup.vue                                  |   98.88 |      100 |      95 |   98.88 | 116-119                                                                                                                                                                                     
  FunctionSelect.vue                                      |   95.89 |    88.88 |      90 |   95.89 | 186-187,197-198,213-215,232-235                                                                                                                                                             
  FunctionSelectItem.vue                                  |     100 |      100 |     100 |     100 |                                                                                                                                                                                             
  wikifunctionsIconSvg.js                                 |     100 |      100 |     100 |     100 |                                                                                                                                                                                             
 ext.wikilambda.app/components/visualeditor/fields        |   96.75 |    90.35 |   96.22 |   96.75 |                                                                                                                                                                                             
  FunctionInputEnum.vue                                   |   98.46 |    95.83 |    92.3 |   98.46 | 92,163-164                                                                                                                                                                                  
  FunctionInputLanguage.vue                               |   98.78 |     90.9 |     100 |   98.78 | 101-102                                                                                                                                                                                     
  FunctionInputParser.vue                                 |   93.09 |     87.8 |      95 |   93.09 | 105-107,184-189,200-201,241-242,321-327,339-343                                                                                                                                             
  FunctionInputString.vue                                 |     100 |      100 |     100 |     100 |                                                                                                                                                                                             
  FunctionInputWikidata.vue                               |   99.04 |       88 |     100 |   99.04 | 135-136                                                                                                                                                                                     
 ext.wikilambda.app/components/widgets/about              |   97.94 |    93.33 |      90 |   97.94 |                                                                                                                                                                                             
  About.vue                                               |    98.5 |    97.46 |   92.85 |    98.5 | 238,280-283,318-319,402-403                                                                                                                                                                 
  AboutLanguageBlock.vue                                  |   99.18 |    97.56 |   83.33 |   99.18 | 418,444,470,499-500                                                                                                                                                                         
  AboutLanguagesDialog.vue                                |   95.15 |    76.66 |   92.85 |   95.15 | 252-254,266-268,283-284,316-317,319-320,322-323,325-326,332-334                                                                                                                             
 ext.wikilambda.app/components/widgets/function-evaluator |   84.02 |    83.51 |   67.74 |   84.02 |                                                                                                                                                                                             
  EvaluationResult.vue                                    |   96.71 |    71.42 |   71.42 |   96.71 | 112,121-122,134-135                                                                                                                                                                         
  FunctionEvaluator.vue                                   |     100 |    91.66 |     100 |     100 | 440,469-471                                                                                                                                                                                 
  FunctionMetadataDialog.vue                              |   72.59 |       75 |   45.45 |   72.59 | 218-219,252-253,262,271-275,299-300,306-307,331-383,396-424,432,438-439,524-527,550-567,575-577,593-596,604-608,619-628,639-650,663-673,685-696,706-712,723-733,742,761-763,774-814,833-836 
 ext.wikilambda.app/components/widgets/function-explorer  |   99.43 |      100 |   91.66 |   99.43 |                                                                                                                                                                                             
  FunctionExplorer.vue                                    |   99.43 |      100 |   91.66 |   99.43 | 293-294                                                                                                                                                                                     
 ext.wikilambda.app/components/widgets/function-report    |   97.71 |    93.97 |   89.65 |   97.71 |                                                                                                                                                                                             
  FunctionReport.vue                                      |   97.61 |    90.74 |   90.47 |   97.61 | 228-230,288-290,296-298                                                                                                                                                                     
  FunctionReportItem.vue                                  |   97.88 |      100 |    87.5 |   97.88 | 182-186                                                                                                                                                                                     
 ext.wikilambda.app/components/widgets/publish            |   96.59 |    85.13 |   94.73 |   96.59 |                                                                                                                                                                                             
  LeaveEditorDialog.vue                                   |     100 |      100 |     100 |     100 |                                                                                                                                                                                             
  Publish.vue                                             |   90.96 |    82.35 |    87.5 |   90.96 | 105-112,196-205,208,210-214,232-234                                                                                                                                                         
  PublishDialog.vue                                       |     100 |    85.71 |     100 |     100 | 238,300,349-351                                                                                                                                                                             
 ext.wikilambda.app/composables                           |     100 |      100 |     100 |     100 |                                                                                                                                                                                             
  useBreakpoints.js                                       |     100 |      100 |     100 |     100 |                                                                                                                                                                                             
 ext.wikilambda.app/mixins                                |   99.36 |    94.11 |     100 |   99.36 |                                                                                                                                                                                             
  clipboardMixin.js                                       |     100 |      100 |     100 |     100 |                                                                                                                                                                                             
  errorMixin.js                                           |   98.13 |    89.47 |     100 |   98.13 | 61-62                                                                                                                                                                                       
  eventLogMixin.js                                        |   97.43 |    93.33 |     100 |   97.43 | 45-46                                                                                                                                                                                       
  metadataMixin.js                                        |     100 |      100 |     100 |     100 |                                                                                                                                                                                             
  pageTitleMixin.js                                       |     100 |    93.33 |     100 |     100 | 71                                                                                                                                                                                          
  typeMixin.js                                            |     100 |      100 |     100 |     100 |                                                                                                                                                                                             
  zobjectMixin.js                                         |     100 |    94.11 |     100 |     100 | 80                                                                                                                                                                                          
 ext.wikilambda.app/store                                 |     100 |      100 |     100 |     100 |                                                                                                                                                                                             
  index.js                                                |     100 |      100 |     100 |     100 |                                                                                                                                                                                             
 ext.wikilambda.app/store/classes                         |    97.2 |    88.67 |     100 |    97.2 |                                                                                                                                                                                             
  ApiError.js                                             |   95.73 |    82.35 |     100 |   95.73 | 151-153,159-160,200-203                                                                                                                                                                     
  LabelData.js                                            |     100 |      100 |     100 |     100 |                                                                                                                                                                                             
 ext.wikilambda.app/store/stores                          |   98.84 |    95.51 |   98.16 |   98.84 |                                                                                                                                                                                             
  errors.js                                               |    97.9 |       96 |    92.3 |    97.9 | 60,167-169                                                                                                                                                                                  
  functionCall.js                                         |   97.22 |     87.5 |     100 |   97.22 | 31-32                                                                                                                                                                                       
  languages.js                                            |   92.39 |    76.92 |     100 |   92.39 | 26-29,43-45                                                                                                                                                                                 
  library.js                                              |      98 |    95.32 |   98.24 |      98 | 138-139,514-515,540-541,552-555,559,650-655,683-685,890,1038-1039,1169                                                                                                                      
  listItems.js                                            |     100 |      100 |     100 |     100 |                                                                                                                                                                                             
  programmingLanguages.js                                 |     100 |      100 |     100 |     100 |                                                                                                                                                                                             
  router.js                                               |     100 |     97.5 |     100 |     100 | 21                                                                                                                                                                                          
  testResults.js                                          |     100 |    91.66 |     100 |     100 | 135,205,255-257                                                                                                                                                                             
  user.js                                                 |     100 |      100 |     100 |     100 |                                                                                                                                                                                             
  visualeditor.js                                         |   98.31 |    95.45 |   89.47 |   98.31 | 62,72,95-96                                                                                                                                                                                 
  zfunction.js                                            |     100 |    96.49 |     100 |     100 | 90                                                                                                                                                                                          
  zobject.js                                              |   99.28 |    96.29 |     100 |   99.28 | 539-540,579-580,716-717,1089-1090                                                                                                                                                           
  ztype.js                                                |   99.38 |      100 |     100 |   99.38 | 274-275                                                                                                                                                                                     
 ext.wikilambda.app/store/stores/wikidata                 |   99.88 |    95.37 |     100 |   99.88 |                                                                                                                                                                                             
  entities.js                                             |   99.49 |    98.03 |     100 |   99.49 | 83                                                                                                                                                                                          
  items.js                                                |     100 |    93.75 |     100 |     100 | 92,95,116                                                                                                                                                                                   
  lexemes.js                                              |     100 |    95.65 |     100 |     100 | 113,116,149                                                                                                                                                                                 
  properties.js                                           |     100 |    93.75 |     100 |     100 | 89,92,114                                                                                                                                                                                   
 ext.wikilambda.app/store/stores/zobject                  |   98.73 |     94.8 |     100 |   98.73 |                                                                                                                                                                                             
  currentPage.js                                          |     100 |       95 |     100 |     100 | 121                                                                                                                                                                                         
  factory.js                                              |   98.59 |    95.23 |     100 |   98.59 | 169-175,364-367,827                                                                                                                                                                         
  submission.js                                           |    98.5 |    94.23 |     100 |    98.5 | 198,373-374,505-506,511-512,543-544                                                                                                                                                         
 ext.wikilambda.app/utils                                 |   97.96 |    95.22 |    98.8 |   97.96 |                                                                                                                                                                                             
  apiUtils.js                                             |   98.64 |       78 |     100 |   98.64 | 263-265,329-330                                                                                                                                                                             
  miscUtils.js                                            |     100 |      100 |     100 |     100 |                                                                                                                                                                                             
  schemata.js                                             |   96.45 |    91.57 |    90.9 |   96.45 | 123,174-179,211-212,214-215                                                                                                                                                                 
  typeUtils.js                                            |   96.91 |    98.68 |     100 |   96.91 | 508-529                                                                                                                                                                                     
  urlUtils.js                                             |     100 |      100 |     100 |     100 |                                                                                                                                                                                             
  wikidataUtils.js                                        |     100 |      100 |     100 |     100 |                                                                                                                                                                                             
  zobjectUtils.js                                         |   98.67 |    99.03 |     100 |   98.67 | 612-616,658-662                                                                                                                                                                             
 ext.wikilambda.app/views                                 |   90.09 |    77.77 |   33.33 |   90.09 |                                                                                                                                                                                             
  Default.vue                                             |   85.41 |      100 |       0 |   85.41 | 99-101,120-121,131,140,150-153,160,167,174-175,188-200,210-213,216-218                                                                                                                      
  FunctionEditor.vue                                      |     100 |      100 |     100 |     100 |                                                                                                                                                                                             
  FunctionEvaluator.vue                                   |     100 |      100 |     100 |     100 |                                                                                                                                                                                             
  FunctionViewer.vue                                      |   93.54 |    71.42 |      80 |   93.54 | 87-94                                                                                                                                                                                       
 ext.wikilambda.languageselector/components               |   98.05 |    93.75 |   94.11 |   98.05 |                                                                                                                                                                                             
  LanguageSelector.vue                                    |   98.05 |    93.75 |   94.11 |   98.05 | 229-230,268-269,290-291                                                                                                                                                                     
----------------------------------------------------------|---------|----------|---------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

--- end ---
Traceback (most recent call last):
  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 63, 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.

During handling of the above exception, another exception occurred:

Traceback (most recent call last):
  File "/venv/lib/python3.11/site-packages/runner-0.1.0-py3.11.egg/runner/__init__.py", line 2031, 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 1967, in run
    self.npm_upgrade(plan)
  File "/venv/lib/python3.11/site-packages/runner-0.1.0-py3.11.egg/runner/__init__.py", line 1256, in npm_upgrade
    self.npm_test()
  File "/venv/lib/python3.11/site-packages/runner-0.1.0-py3.11.egg/runner/__init__.py", line 330, in npm_test
    self.check_call(["node_modules/.bin/jest", "-u"])
  File "/venv/lib/python3.11/site-packages/runner-0.1.0-py3.11.egg/runner/shell2.py", line 63, 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 '['node_modules/.bin/jest', '-u']' returned non-zero exit status 1.
Source code is licensed under the AGPL.