wikipeg: main (log #1707431)

sourcepatches

This run took 26 seconds.

$ date
--- stdout ---
Fri Jan 17 06:10:48 UTC 2025

--- end ---
$ git clone file:///srv/git/wikipeg.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
--- stdout ---

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

--- end ---
$ git show-ref refs/heads/master
--- stdout ---
04c77af81f9eb9131058d98c9bd13ff4d389c993 refs/heads/master

--- end ---
$ /usr/bin/npm audit --json
--- stdout ---
{
  "auditReportVersion": 2,
  "vulnerabilities": {
    "jasmine-node": {
      "name": "jasmine-node",
      "severity": "critical",
      "isDirect": true,
      "via": [
        "underscore"
      ],
      "effects": [],
      "range": ">=1.16.1",
      "nodes": [
        "node_modules/jasmine-node"
      ],
      "fixAvailable": {
        "name": "jasmine-node",
        "version": "1.16.0",
        "isSemVerMajor": true
      }
    },
    "underscore": {
      "name": "underscore",
      "severity": "critical",
      "isDirect": false,
      "via": [
        {
          "source": 1095097,
          "name": "underscore",
          "dependency": "underscore",
          "title": "Arbitrary Code Execution in underscore",
          "url": "https://github.com/advisories/GHSA-cf4h-3jhx-xvhq",
          "severity": "critical",
          "cwe": [
            "CWE-94"
          ],
          "cvss": {
            "score": 9.8,
            "vectorString": "CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:H/I:H/A:H"
          },
          "range": ">=1.3.2 <1.12.1"
        }
      ],
      "effects": [
        "jasmine-node"
      ],
      "range": "1.3.2 - 1.12.0",
      "nodes": [
        "node_modules/underscore"
      ],
      "fixAvailable": {
        "name": "jasmine-node",
        "version": "1.16.0",
        "isSemVerMajor": true
      }
    }
  },
  "metadata": {
    "vulnerabilities": {
      "info": 0,
      "low": 0,
      "moderate": 0,
      "high": 0,
      "critical": 2,
      "total": 2
    },
    "dependencies": {
      "prod": 1,
      "dev": 112,
      "optional": 0,
      "peer": 0,
      "peerOptional": 0,
      "total": 112
    }
  }
}

--- 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: 68 installs, 0 updates, 0 removals
  - Locking composer/pcre (3.3.2)
  - Locking composer/semver (3.4.3)
  - Locking composer/spdx-licenses (1.5.8)
  - Locking composer/xdebug-handler (3.0.5)
  - Locking dealerdirect/phpcodesniffer-composer-installer (v1.0.0)
  - Locking doctrine/deprecations (1.1.4)
  - Locking doctrine/instantiator (2.0.0)
  - Locking felixfbecker/advanced-json-rpc (v3.2.1)
  - Locking mediawiki/mediawiki-codesniffer (v45.0.0)
  - Locking mediawiki/mediawiki-phan-config (0.15.1)
  - Locking mediawiki/minus-x (1.1.3)
  - Locking mediawiki/phan-taint-check-plugin (6.1.0)
  - Locking microsoft/tolerant-php-parser (v0.1.2)
  - Locking myclabs/deep-copy (1.12.1)
  - Locking netresearch/jsonmapper (v4.5.0)
  - Locking nikic/php-parser (v5.4.0)
  - Locking ockcyp/covers-validator (v1.6.0)
  - Locking phan/phan (5.4.5)
  - Locking phar-io/manifest (2.0.4)
  - Locking phar-io/version (3.2.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.1)
  - Locking phpdocumentor/type-resolver (1.10.0)
  - Locking phpstan/phpdoc-parser (2.0.0)
  - Locking phpunit/php-code-coverage (9.2.32)
  - Locking phpunit/php-file-iterator (3.0.6)
  - Locking phpunit/php-invoker (3.1.1)
  - Locking phpunit/php-text-template (2.0.4)
  - Locking phpunit/php-timer (5.0.3)
  - Locking phpunit/phpunit (9.6.21)
  - Locking psr/container (2.0.2)
  - Locking psr/log (3.0.2)
  - Locking sabre/event (5.1.7)
  - Locking sebastian/cli-parser (1.0.2)
  - Locking sebastian/code-unit (1.0.8)
  - Locking sebastian/code-unit-reverse-lookup (2.0.3)
  - Locking sebastian/comparator (4.0.8)
  - Locking sebastian/complexity (2.0.3)
  - Locking sebastian/diff (4.0.6)
  - Locking sebastian/environment (5.1.5)
  - Locking sebastian/exporter (4.0.6)
  - Locking sebastian/global-state (5.0.7)
  - Locking sebastian/lines-of-code (1.0.4)
  - Locking sebastian/object-enumerator (4.0.4)
  - Locking sebastian/object-reflector (2.0.4)
  - Locking sebastian/recursion-context (4.0.5)
  - Locking sebastian/resource-operations (3.0.4)
  - Locking sebastian/type (3.2.1)
  - Locking sebastian/version (3.0.2)
  - Locking squizlabs/php_codesniffer (3.10.3)
  - Locking symfony/console (v6.4.17)
  - Locking symfony/deprecation-contracts (v3.5.1)
  - Locking symfony/polyfill-ctype (v1.31.0)
  - Locking symfony/polyfill-intl-grapheme (v1.31.0)
  - Locking symfony/polyfill-intl-normalizer (v1.31.0)
  - Locking symfony/polyfill-mbstring (v1.31.0)
  - Locking symfony/polyfill-php80 (v1.31.0)
  - Locking symfony/service-contracts (v3.5.1)
  - Locking symfony/string (v7.2.0)
  - Locking theseer/tokenizer (1.2.3)
  - Locking tysonandre/var_representation_polyfill (0.1.3)
  - Locking webmozart/assert (1.11.0)
  - Locking wikimedia/update-history (1.0.1)
Writing lock file
Installing dependencies from lock file (including require-dev)
Package operations: 68 installs, 0 updates, 0 removals
    0 [>---------------------------]    0 [->--------------------------]
  - Installing squizlabs/php_codesniffer (3.10.3): Extracting archive
  - Installing dealerdirect/phpcodesniffer-composer-installer (v1.0.0): Extracting archive
  - Installing composer/pcre (3.3.2): Extracting archive
  - Installing symfony/polyfill-php80 (v1.31.0): Extracting archive
  - Installing phpcsstandards/phpcsutils (1.0.12): Extracting archive
  - Installing phpcsstandards/phpcsextra (1.2.1): Extracting archive
  - Installing symfony/polyfill-mbstring (v1.31.0): Extracting archive
  - Installing composer/spdx-licenses (1.5.8): Extracting archive
  - Installing composer/semver (3.4.3): Extracting archive
  - Installing mediawiki/mediawiki-codesniffer (v45.0.0): Extracting archive
  - Installing tysonandre/var_representation_polyfill (0.1.3): Extracting archive
  - Installing symfony/polyfill-intl-normalizer (v1.31.0): Extracting archive
  - Installing symfony/polyfill-intl-grapheme (v1.31.0): Extracting archive
  - Installing symfony/polyfill-ctype (v1.31.0): Extracting archive
  - Installing symfony/string (v7.2.0): Extracting archive
  - Installing symfony/deprecation-contracts (v3.5.1): Extracting archive
  - Installing psr/container (2.0.2): Extracting archive
  - Installing symfony/service-contracts (v3.5.1): Extracting archive
  - Installing symfony/console (v6.4.17): 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.0.0): Extracting archive
  - Installing phpdocumentor/reflection-common (2.2.0): Extracting archive
  - Installing doctrine/deprecations (1.1.4): Extracting archive
  - Installing phpdocumentor/type-resolver (1.10.0): Extracting archive
  - Installing phpdocumentor/reflection-docblock (5.6.1): Extracting archive
  - Installing felixfbecker/advanced-json-rpc (v3.2.1): Extracting archive
  - Installing psr/log (3.0.2): Extracting archive
  - Installing composer/xdebug-handler (3.0.5): Extracting archive
  - Installing phan/phan (5.4.5): Extracting archive
  - Installing mediawiki/phan-taint-check-plugin (6.1.0): Extracting archive
  - Installing mediawiki/mediawiki-phan-config (0.15.1): Extracting archive
  - Installing mediawiki/minus-x (1.1.3): Extracting archive
  - Installing sebastian/version (3.0.2): Extracting archive
  - Installing sebastian/type (3.2.1): Extracting archive
  - Installing sebastian/resource-operations (3.0.4): Extracting archive
  - Installing sebastian/recursion-context (4.0.5): Extracting archive
  - Installing sebastian/object-reflector (2.0.4): Extracting archive
  - Installing sebastian/object-enumerator (4.0.4): Extracting archive
  - Installing sebastian/global-state (5.0.7): Extracting archive
  - Installing sebastian/exporter (4.0.6): Extracting archive
  - Installing sebastian/environment (5.1.5): Extracting archive
  - Installing sebastian/diff (4.0.6): Extracting archive
  - Installing sebastian/comparator (4.0.8): Extracting archive
  - Installing sebastian/code-unit (1.0.8): Extracting archive
  - Installing sebastian/cli-parser (1.0.2): Extracting archive
  - Installing phpunit/php-timer (5.0.3): Extracting archive
  - Installing phpunit/php-text-template (2.0.4): Extracting archive
  - Installing phpunit/php-invoker (3.1.1): Extracting archive
  - Installing phpunit/php-file-iterator (3.0.6): Extracting archive
  - Installing theseer/tokenizer (1.2.3): Extracting archive
  - Installing nikic/php-parser (v5.4.0): Extracting archive
  - Installing sebastian/lines-of-code (1.0.4): Extracting archive
  - Installing sebastian/complexity (2.0.3): Extracting archive
  - Installing sebastian/code-unit-reverse-lookup (2.0.3): Extracting archive
  - Installing phpunit/php-code-coverage (9.2.32): Extracting archive
  - Installing phar-io/version (3.2.1): Extracting archive
  - Installing phar-io/manifest (2.0.4): Extracting archive
  - Installing myclabs/deep-copy (1.12.1): Extracting archive
  - Installing doctrine/instantiator (2.0.0): Extracting archive
  - Installing phpunit/phpunit (9.6.21): Extracting archive
  - Installing ockcyp/covers-validator (v1.6.0): 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/update-history (1.0.1): Extracting archive
  0/66 [>---------------------------]   0%
 20/66 [========>-------------------]  30%
 33/66 [==============>-------------]  50%
 47/66 [===================>--------]  71%
 58/66 [========================>---]  87%
 66/66 [============================] 100%
5 package suggestions were added by new dependencies, use `composer suggest` to see details.
Generating autoload files
42 packages you are using are looking for funding.
Use the `composer fund` command to find out more!
--- stdout ---
PHP CodeSniffer Config installed_paths set to ../../mediawiki/mediawiki-codesniffer,../../phpcsstandards/phpcsextra,../../phpcsstandards/phpcsutils

--- end ---
$ /usr/bin/npm audit --json
--- stdout ---
{
  "auditReportVersion": 2,
  "vulnerabilities": {
    "jasmine-node": {
      "name": "jasmine-node",
      "severity": "critical",
      "isDirect": true,
      "via": [
        "underscore"
      ],
      "effects": [],
      "range": ">=1.16.1",
      "nodes": [
        "node_modules/jasmine-node"
      ],
      "fixAvailable": {
        "name": "jasmine-node",
        "version": "1.16.0",
        "isSemVerMajor": true
      }
    },
    "underscore": {
      "name": "underscore",
      "severity": "critical",
      "isDirect": false,
      "via": [
        {
          "source": 1095097,
          "name": "underscore",
          "dependency": "underscore",
          "title": "Arbitrary Code Execution in underscore",
          "url": "https://github.com/advisories/GHSA-cf4h-3jhx-xvhq",
          "severity": "critical",
          "cwe": [
            "CWE-94"
          ],
          "cvss": {
            "score": 9.8,
            "vectorString": "CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:H/I:H/A:H"
          },
          "range": ">=1.3.2 <1.12.1"
        }
      ],
      "effects": [
        "jasmine-node"
      ],
      "range": "1.3.2 - 1.12.0",
      "nodes": [
        "node_modules/underscore"
      ],
      "fixAvailable": {
        "name": "jasmine-node",
        "version": "1.16.0",
        "isSemVerMajor": true
      }
    }
  },
  "metadata": {
    "vulnerabilities": {
      "info": 0,
      "low": 0,
      "moderate": 0,
      "high": 0,
      "critical": 2,
      "total": 2
    },
    "dependencies": {
      "prod": 1,
      "dev": 112,
      "optional": 0,
      "peer": 0,
      "peerOptional": 0,
      "total": 112
    }
  }
}

--- end ---
Attempting to npm audit fix
$ /usr/bin/npm audit fix --dry-run --only=dev --json
--- stderr ---
npm WARN invalid config only="dev" set in command line options
npm WARN invalid config Must be one of: null, prod, production
--- stdout ---
{
  "added": 112,
  "removed": 0,
  "changed": 0,
  "audited": 113,
  "funding": 20,
  "audit": {
    "auditReportVersion": 2,
    "vulnerabilities": {
      "jasmine-node": {
        "name": "jasmine-node",
        "severity": "critical",
        "isDirect": true,
        "via": [
          "underscore"
        ],
        "effects": [],
        "range": ">=1.16.1",
        "nodes": [
          "node_modules/jasmine-node"
        ],
        "fixAvailable": {
          "name": "jasmine-node",
          "version": "1.16.0",
          "isSemVerMajor": true
        }
      },
      "underscore": {
        "name": "underscore",
        "severity": "critical",
        "isDirect": false,
        "via": [
          {
            "source": 1095097,
            "name": "underscore",
            "dependency": "underscore",
            "title": "Arbitrary Code Execution in underscore",
            "url": "https://github.com/advisories/GHSA-cf4h-3jhx-xvhq",
            "severity": "critical",
            "cwe": [
              "CWE-94"
            ],
            "cvss": {
              "score": 9.8,
              "vectorString": "CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:H/I:H/A:H"
            },
            "range": ">=1.3.2 <1.12.1"
          }
        ],
        "effects": [
          "jasmine-node"
        ],
        "range": "1.3.2 - 1.12.0",
        "nodes": [
          "node_modules/underscore"
        ],
        "fixAvailable": {
          "name": "jasmine-node",
          "version": "1.16.0",
          "isSemVerMajor": true
        }
      }
    },
    "metadata": {
      "vulnerabilities": {
        "info": 0,
        "low": 0,
        "moderate": 0,
        "high": 0,
        "critical": 2,
        "total": 2
      },
      "dependencies": {
        "prod": 1,
        "dev": 112,
        "optional": 0,
        "peer": 0,
        "peerOptional": 0,
        "total": 112
      }
    }
  }
}

--- end ---
{"added": 112, "removed": 0, "changed": 0, "audited": 113, "funding": 20, "audit": {"auditReportVersion": 2, "vulnerabilities": {"jasmine-node": {"name": "jasmine-node", "severity": "critical", "isDirect": true, "via": ["underscore"], "effects": [], "range": ">=1.16.1", "nodes": ["node_modules/jasmine-node"], "fixAvailable": {"name": "jasmine-node", "version": "1.16.0", "isSemVerMajor": true}}, "underscore": {"name": "underscore", "severity": "critical", "isDirect": false, "via": [{"source": 1095097, "name": "underscore", "dependency": "underscore", "title": "Arbitrary Code Execution in underscore", "url": "https://github.com/advisories/GHSA-cf4h-3jhx-xvhq", "severity": "critical", "cwe": ["CWE-94"], "cvss": {"score": 9.8, "vectorString": "CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:H/I:H/A:H"}, "range": ">=1.3.2 <1.12.1"}], "effects": ["jasmine-node"], "range": "1.3.2 - 1.12.0", "nodes": ["node_modules/underscore"], "fixAvailable": {"name": "jasmine-node", "version": "1.16.0", "isSemVerMajor": true}}}, "metadata": {"vulnerabilities": {"info": 0, "low": 0, "moderate": 0, "high": 0, "critical": 2, "total": 2}, "dependencies": {"prod": 1, "dev": 112, "optional": 0, "peer": 0, "peerOptional": 0, "total": 112}}}}
$ /usr/bin/npm audit fix --only=dev
--- stderr ---
npm WARN invalid config only="dev" set in command line options
npm WARN invalid config Must be one of: null, prod, production
--- stdout ---

added 112 packages, and audited 113 packages in 2s

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

# npm audit report

underscore  1.3.2 - 1.12.0
Severity: critical
Arbitrary Code Execution in underscore - https://github.com/advisories/GHSA-cf4h-3jhx-xvhq
fix available via `npm audit fix --force`
Will install jasmine-node@1.16.0, which is a breaking change
node_modules/underscore
  jasmine-node  >=1.16.1
  Depends on vulnerable versions of underscore
  node_modules/jasmine-node

2 critical severity vulnerabilities

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

--- end ---
Verifying that tests still pass
$ /usr/bin/npm ci
--- stdout ---

added 112 packages, and audited 113 packages in 2s

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

2 critical severity vulnerabilities

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

Run `npm audit` for details.

--- end ---
$ /usr/bin/npm test
--- stdout ---

> wikipeg@4.0.0-git test
> make eslint && make test


generated parser API - 19 ms

    parse - 19 ms
        parses input - 5 ms
        throws an exception on syntax error - 6 ms

        start rule - 1 ms

            when |startRule| is not set - 1 ms
                starts parsing from the first allowed rule - 0 ms

            when |startRule| is set to an allowed rule - 0 ms
                starts parsing from specified rule - 0 ms

            when |startRule| is set to a disallowed start rule - 0 ms
                throws an exception - 0 ms

        tracing - 4 ms

            default tracer - 3 ms
                traces using console.log - 3 ms

            custom tracers - 1 ms

                trace - 1 ms
                    receives tracing events - 1 ms
        accepts custom options - 3 ms

PEG.js API - 51 ms

    buildParser - 51 ms
        builds a parser - 2 ms
        throws an exception on syntax error - 1 ms
        throws an exception on semantic error - 0 ms

        allowed start rules - 14 ms

            when optimizing for parsing speed - 6 ms

                when |allowedStartRules| is not set - 3 ms
                    generated parser can start only from the first rule - 3 ms

                when |allowedStartRules| is set - 3 ms
                    generated parser can start only from specified rules - 3 ms

            when optimizing for code size - 8 ms

                when |allowedStartRules| is not set - 5 ms
                    generated parser can start only from the first rule - 5 ms

                when |allowedStartRules| is set - 3 ms
                    generated parser can start only from specified rules - 3 ms

        intermediate results caching - 14 ms

            when |cache| is not set - 5 ms
                generated parser doesn't cache intermediate parse results - 5 ms

            when |cache| is set to |false| - 4 ms
                generated parser doesn't cache intermediate parse results - 4 ms

            when |cache| is set to |true| - 5 ms
                generated parser caches intermediate parse results - 5 ms

        tracing - 7 ms

            when |trace| is not set - 2 ms
                generated parser doesn't trace - 2 ms

            when |trace| is set to |false| - 2 ms
                generated parser doesn't trace - 2 ms

            when |trace| is set to |true| - 3 ms
                generated parser traces - 3 ms

        output - 10 ms

            when |output| is not set - 2 ms
                returns generated parser object - 2 ms

            when |output| is set to |"parser"| - 2 ms
                returns generated parser object - 2 ms

            when |output| is set to |"source"| - 2 ms
                returns generated parser source code - 2 ms

            when |headerComment| is set to |/*
 * some comment
 */| - 2 ms
                returns generated parser source code with that comment - 2 ms

            when |headerComment| is set to |/*
 * some comment
 */| and |language| is set to |php| - 2 ms
                returns generated php parser source code with that comment - 2 ms
        accepts custom options - 2 ms

plugin API - 16 ms

    use - 16 ms
        is called for each plugin - 2 ms
        receives configuration - 4 ms
        receives options - 2 ms
        can replace parser - 5 ms
        can change compiler passes - 0 ms
        can change options - 3 ms

generated parser behavior - 264 ms

    with options { cache : false } - 136 ms

        initializer - 7 ms
            executes the code before parsing starts - 2 ms

            available variables and functions - 5 ms
                |parser| contains the parser object - 3 ms
                |options| contains options - 2 ms

        rule - 15 ms
            doesn't cache rule match results - 5 ms

            when the expression matches - 2 ms
                returns its match result - 2 ms

            when the expression doesn't match - 8 ms

                without display name - 2 ms
                    reports match failure and doesn't record any expectation - 2 ms

                with display name - 6 ms
                    reports match failure and records an expectation of type "other" - 3 ms
                    discards any expectations recorded when matching the expression - 3 ms

        positive semantic predicate - 37 ms

            initializer variables & functions - 13 ms
                can access variables defined in the initializer - 3 ms
                can access functions defined in the initializer - 10 ms

            available variables & functions - 24 ms
                |parser| contains the parser object - 8 ms
                |options| contains options - 5 ms
                |location| returns current location info - 11 ms

        negative semantic predicate - 15 ms

            initializer variables & functions - 5 ms
                can access variables defined in the initializer - 3 ms
                can access functions defined in the initializer - 2 ms

            available variables & functions - 10 ms
                |parser| contains the parser object - 2 ms
                |options| contains options - 3 ms
                |location| returns current location info - 5 ms

        action - 22 ms

            initializer variables & functions - 5 ms
                can access variables defined in the initializer - 2 ms
                can access functions defined in the initializer - 3 ms

            available variables & functions - 17 ms
                |parser| contains the parser object - 2 ms
                |options| contains options - 3 ms
                |text| returns text matched by the expression - 2 ms
                |location| returns location info of the expression - 6 ms
                |expected| terminates parsing and throws an exception - 2 ms
                |error| terminates parsing and throws an exception - 2 ms

        error reporting - 24 ms

            found string reporting - 4 ms
                reports found string correctly at the end of input - 2 ms
                reports found string correctly in the middle of input - 2 ms

            message building - 9 ms
                builds message correctly with no alternative - 1 ms
                builds message correctly with one alternative - 2 ms
                builds message correctly with multiple alternatives - 3 ms
                builds message correctly at the end of input - 1 ms
                builds message correctly in the middle of input - 2 ms

            position reporting - 11 ms
                reports position correctly at the end of input - 2 ms
                reports position correctly in the middle of input - 1 ms
                reports position correctly with trailing input - 3 ms
                reports position correctly in complex cases - 5 ms

        complex examples - 16 ms
            handles arithmetics example correctly - 6 ms
            handles non-context-free language correctly - 6 ms
            handles nested comments example correctly - 4 ms

    with options { cache : true } - 127 ms

        initializer - 8 ms
            executes the code before parsing starts - 2 ms

            available variables and functions - 6 ms
                |parser| contains the parser object - 2 ms
                |options| contains options - 4 ms

        rule - 9 ms
            caches rule match results - 3 ms

            when the expression matches - 2 ms
                returns its match result - 2 ms

            when the expression doesn't match - 4 ms

                without display name - 1 ms
                    reports match failure and doesn't record any expectation - 1 ms

                with display name - 3 ms
                    reports match failure and records an expectation of type "other" - 2 ms
                    discards any expectations recorded when matching the expression - 1 ms

        positive semantic predicate - 25 ms

            initializer variables & functions - 5 ms
                can access variables defined in the initializer - 3 ms
                can access functions defined in the initializer - 2 ms

            available variables & functions - 20 ms
                |parser| contains the parser object - 2 ms
                |options| contains options - 2 ms
                |location| returns current location info - 16 ms

        negative semantic predicate - 18 ms

            initializer variables & functions - 8 ms
                can access variables defined in the initializer - 5 ms
                can access functions defined in the initializer - 3 ms

            available variables & functions - 10 ms
                |parser| contains the parser object - 2 ms
                |options| contains options - 2 ms
                |location| returns current location info - 6 ms

        action - 22 ms

            initializer variables & functions - 4 ms
                can access variables defined in the initializer - 2 ms
                can access functions defined in the initializer - 2 ms

            available variables & functions - 18 ms
                |parser| contains the parser object - 3 ms
                |options| contains options - 2 ms
                |text| returns text matched by the expression - 2 ms
                |location| returns location info of the expression - 6 ms
                |expected| terminates parsing and throws an exception - 3 ms
                |error| terminates parsing and throws an exception - 2 ms

        error reporting - 25 ms

            found string reporting - 5 ms
                reports found string correctly at the end of input - 3 ms
                reports found string correctly in the middle of input - 2 ms

            message building - 10 ms
                builds message correctly with no alternative - 2 ms
                builds message correctly with one alternative - 2 ms
                builds message correctly with multiple alternatives - 3 ms
                builds message correctly at the end of input - 1 ms
                builds message correctly in the middle of input - 2 ms

            position reporting - 10 ms
                reports position correctly at the end of input - 2 ms
                reports position correctly in the middle of input - 1 ms
                reports position correctly with trailing input - 2 ms
                reports position correctly in complex cases - 5 ms

        complex examples - 20 ms
            handles arithmetics example correctly - 7 ms
            handles non-context-free language correctly - 8 ms
            handles nested comments example correctly - 5 ms

compiler pass |removeProxyRules| - 1 ms

    when a proxy rule isn't listed in |allowedStartRules| - 1 ms
        updates references and removes it - 1 ms

    when a proxy rule is listed in |allowedStartRules| - 0 ms
        updates references but doesn't remove it - 0 ms

compiler pass |reportLeftRecursion| - 5 ms
    reports infinite loops for zero_or_more - 1 ms
    reports infinite loops for one_or_more - 0 ms
    computes empty string matching correctly - 4 ms

compiler pass |reportLeftRecursion| - 10 ms
    reports direct left recursion - 1 ms
    reports indirect left recursion - 0 ms

    in sequences - 9 ms
        reports left recursion if all preceding elements match empty string - 0 ms
        doesn't report left recursion if some preceding element doesn't match empty string - 1 ms
        computes empty string matching correctly - 8 ms

compiler pass |reportMissingRules| - 0 ms
    reports missing rules - 0 ms

PEG.js grammar parser - 31 ms
    parses Grammar - 1 ms
    parses Initializer - 0 ms
    parses Rule - 1 ms
    parses Expression - 0 ms
    parses ChoiceExpression - 1 ms
    parses ActionExpression - 1 ms
    parses SequenceExpression - 1 ms
    parses LabeledExpression - 0 ms
    parses PrefixedExpression - 1 ms
    parses PrefixedOperator - 1 ms
    parses SuffixedExpression - 0 ms
    parses SuffixedOperator - 1 ms
    parses PrimaryExpression - 1 ms
    parses RuleReferenceExpression - 1 ms
    parses SemanticPredicateExpression - 0 ms
    parses SemanticPredicateOperator - 0 ms
    parses WhiteSpace - 1 ms
    parses LineTerminator - 0 ms
    parses LineTerminatorSequence - 1 ms
    parses Comment - 0 ms
    parses MultiLineComment - 1 ms
    parses MultiLineCommentNoLineTerminator - 1 ms
    parses SingleLineComment - 1 ms
    parses Identifier - 0 ms
    parses IdentifierName - 0 ms
    parses IdentifierStart - 1 ms
    parses IdentifierPart - 1 ms
    parses LiteralMatcher - 1 ms
    parses StringLiteral - 1 ms
    parses DoubleStringCharacter - 0 ms
    parses SingleStringCharacter - 1 ms
    parses CharacterClassMatcher - 1 ms
    parses ClassCharacterRange - 1 ms
    parses ClassCharacter - 1 ms
    parses LineContinuation - 0 ms
    parses EscapeSequence - 0 ms
    parses CharacterEscapeSequence - 1 ms
    parses SingleEscapeCharacter - 1 ms
    parses NonEscapeCharacter - 0 ms
    parses HexEscapeSequence - 0 ms
    parses UnicodeEscapeSequence - 1 ms
    parses AnyMatcher - 0 ms
    parses CodeBlock - 0 ms
    parses Code - 1 ms
    parses __ - 1 ms
    parses _ - 0 ms
    parses EOS - 1 ms
    parses EOF - 0 ms

Finished in 0.408 seconds
172 tests, 477 assertions, 0 failures, 0 skipped


Running language-independent tests against PHP
SUCCESS: 608 / 608 assertions were successful
node tests/javascript/runCommonTests.js
Running language-independent tests against JavaScript
SUCCESS: 608 / 608 assertions were successful

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

--- end ---
[DNM] there are no updates
$ git add .
--- stdout ---

--- end ---
$ git commit -F /tmp/tmptu0mlmy_
--- stdout ---
On branch master
Your branch is up to date with 'origin/master'.

nothing to commit, working tree clean

--- end ---
Source code is licensed under the AGPL.