++ dirname ./run.sh
+ cd .
+ echo 1674
+ echo '2.0-SNAPSHOT BUILD'
2.0-SNAPSHOT BUILD
+ date
Mon Mar 30 04:08:34 UTC 2026
+ uptime
04:08:34 up 14 min, 0 users, load average: 0.07, 0.05, 0.05
+ ff=default
+ image=yegor256/ruby
+ rebase=false
+ head_branch=master
+ pull_title='Update codecov/codecov-action action to v6'
+ author=yegor256
+ directory=
+ head=git@github.com:yegor256/judges.git
+ pull_id=405
+ fork=git@github.com:yegor256/judges.git
+ fork_branch=renovate/codecov-codecov-action-6.x
+ squash=false
+ vars=('--env=head=git@github.com:yegor256/judges.git' '--env=pull_id=405' '--env=fork=git@github.com:yegor256/judges.git' '--env=fork_branch=renovate/codecov-codecov-action-6.x' '--env=head_branch=master' '--env=pull_title=Update codecov/codecov-action action to v6' '--env=author=yegor256' '--env=scripts=( '\''export '\''\'\'''\''head=git@github.com:yegor256/judges.git'\''\'\'''\'''\'' '\'';'\'' '\''export '\''\'\'''\''pull_id=405'\''\'\'''\'''\'' '\'';'\'' '\''export '\''\'\'''\''fork=git@github.com:yegor256/judges.git'\''\'\'''\'''\'' '\'';'\'' '\''export '\''\'\'''\''fork_branch=renovate/codecov-codecov-action-6.x'\''\'\'''\'''\'' '\'';'\'' '\''export '\''\'\'''\''head_branch=master'\''\'\'''\'''\'' '\'';'\'' '\''export '\''\'\'''\''pull_title=Update codecov/codecov-action action to v6'\''\'\'''\'''\'' '\'';'\'' '\''export '\''\'\'''\''author=yegor256'\''\'\'''\'''\'' '\'';'\'' '\''pdd -f /dev/null'\'' '\'';'\'' '\''bundle install --no-color'\'' '\'';'\'' '\''bundle exec rake'\'' '\'';'\'' )')
+ scripts=('export '\''head=git@github.com:yegor256/judges.git'\''' ';' 'export '\''pull_id=405'\''' ';' 'export '\''fork=git@github.com:yegor256/judges.git'\''' ';' 'export '\''fork_branch=renovate/codecov-codecov-action-6.x'\''' ';' 'export '\''head_branch=master'\''' ';' 'export '\''pull_title=Update codecov/codecov-action action to v6'\''' ';' 'export '\''author=yegor256'\''' ';' 'pdd -f /dev/null' ';' 'bundle install --no-color' ';' 'bundle exec rake' ';')
+ container=yegor256_judges_405
+ as_root=false
+ set -e -o pipefail
+ hostname
ip-172-31-26-221
+ pwd
/tmp/rultor-AL7E
+ git --version
git version 2.34.1
+ docker --version
Docker version 25.0.3, build 4debf41
+ mkdir -p /home/ubuntu/.ssh
+ echo -e 'Host github.com\n\tStrictHostKeyChecking no\n'
+ chmod 600 /home/ubuntu/.ssh/config
+ git clone --recurse-submodules git@github.com:yegor256/judges.git repo
Cloning into 'repo'...
Warning: Permanently added 'github.com' (ED25519) to the list of known hosts.
+ cd repo
+ git config user.email gpg@rultor.com
+ git config user.name Rultor.com
+ '[' -z 'export '\''head=git@github.com:yegor256/judges.git'\''' ']'
+ cd ..
+ cat
+ '[' false = true ']'
+ cat
+ chmod a+x entry.sh
+ cat
+ echo 'export '\''head=git@github.com:yegor256/judges.git'\''' ';' 'export '\''pull_id=405'\''' ';' 'export '\''fork=git@github.com:yegor256/judges.git'\''' ';' 'export '\''fork_branch=renovate/codecov-codecov-action-6.x'\''' ';' 'export '\''head_branch=master'\''' ';' 'export '\''pull_title=Update codecov/codecov-action action to v6'\''' ';' 'export '\''author=yegor256'\''' ';' 'pdd -f /dev/null' ';' 'bundle install --no-color' ';' 'bundle exec rake' ';'
+ sensitive=()
+ set -ex -o pipefail
+ cd repo
+ git remote add fork git@github.com:yegor256/judges.git
+ git remote update
Fetching origin
Fetching fork
From github.com:yegor256/judges
* [new branch] 136 -> fork/136
* [new branch] 94 -> fork/94
* [new branch] copilot/fix-196 -> fork/copilot/fix-196
* [new branch] copilot/fix-98 -> fork/copilot/fix-98
* [new branch] gh-pages -> fork/gh-pages
* [new branch] master -> fork/master
* [new branch] renovate/codecov-codecov-action-6.x -> fork/renovate/codecov-codecov-action-6.x
* [new branch] renovate/davidanson-markdownlint-cli2-action-23.x -> fork/renovate/davidanson-markdownlint-cli2-action-23.x
* [new branch] renovate/eslint-monorepo -> fork/renovate/eslint-monorepo
* [new branch] renovate/major-eslint-monorepo -> fork/renovate/major-eslint-monorepo
* [new branch] renovate/rubocop-1.x-lockfile -> fork/renovate/rubocop-1.x-lockfile
* [new branch] renovate/ruby-4.x -> fork/renovate/ruby-4.x
* [new branch] renovate/webmock-3.x-lockfile -> fork/renovate/webmock-3.x-lockfile
+ args=()
+ '[' default == default ']'
+ args+=(--ff)
+ '[' default == no ']'
+ '[' default == only ']'
+ '[' false == true ']'
+ BRANCH=__rultor
++ wc -l
++ git show-branch __rultor
+ '[' 0 -gt 0 ']'
+ export BRANCH
+ git status
On branch master
Your branch is up to date with 'origin/master'.
nothing to commit, working tree clean
+ git checkout -B __rultor fork/renovate/codecov-codecov-action-6.x
Switched to a new branch '__rultor'
Branch '__rultor' set up to track remote branch 'renovate/codecov-codecov-action-6.x' from 'fork'.
+ git checkout -B master origin/master
Switched to and reset branch 'master'
Branch 'master' set up to track remote branch 'master' from 'origin'.
Your branch is up to date with 'origin/master'.
+ '[' false == true ']'
+ KEY=3FD3FA7E9AF0FA4C
+ git merge --gpg-sign=3FD3FA7E9AF0FA4C --no-edit -m 'Update codecov/codecov-action action to v6' --ff __rultor
Updating 9cc7468..0346ba9
Fast-forward (no commit created; -m option ignored)
.github/workflows/codecov.yml | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
+ git log -1 --show-signature
commit 0346ba95f8fb405679a31de30d46f8808dd11e47
gpg: Signature made Thu Mar 26 16:43:51 2026 UTC
gpg: using RSA key B5690EEEBB952194
gpg: Can't check signature: No public key
Author: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
Date: Thu Mar 26 16:43:51 2026 +0000
Update codecov/codecov-action action to v6
+ docker_when_possible
+ true
++ tail -n 1
++ sed 's/ /\n/g'
++ uptime
+ load=0.05
++ bc
++ echo 0.05 '>' 30
+ '[' 0 -eq 1 ']'
+ echo 'load average is 0.05, low enough to run a new Docker container'
load average is 0.05, low enough to run a new Docker container
+ break
+ cd ..
+ '[' -n '' ']'
+ use_image=yegor256/ruby
+ docker pull yegor256/ruby
Using default tag: latest
latest: Pulling from yegor256/ruby
632ef5283d0f: Pulling fs layer
2be42d221bda: Pulling fs layer
54d1704eb717: Pulling fs layer
f0f51ee5c79e: Pulling fs layer
ec11ce133a4e: Pulling fs layer
71ab1586461a: Pulling fs layer
8e0e2fc3c108: Pulling fs layer
4f4fb700ef54: Pulling fs layer
72e45e6fed5c: Pulling fs layer
99e89f339e27: Pulling fs layer
3ae0cb47dc06: Pulling fs layer
529dcf5ecc54: Pulling fs layer
6d5a140d320e: Pulling fs layer
d9a7c5bf399b: Pulling fs layer
f0f51ee5c79e: Waiting
ec11ce133a4e: Waiting
71ab1586461a: Waiting
8e0e2fc3c108: Waiting
4f4fb700ef54: Waiting
72e45e6fed5c: Waiting
99e89f339e27: Waiting
3ae0cb47dc06: Waiting
529dcf5ecc54: Waiting
6d5a140d320e: Waiting
d9a7c5bf399b: Waiting
2be42d221bda: Verifying Checksum
2be42d221bda: Download complete
632ef5283d0f: Verifying Checksum
632ef5283d0f: Download complete
54d1704eb717: Verifying Checksum
54d1704eb717: Download complete
ec11ce133a4e: Verifying Checksum
ec11ce133a4e: Download complete
8e0e2fc3c108: Verifying Checksum
8e0e2fc3c108: Download complete
4f4fb700ef54: Verifying Checksum
4f4fb700ef54: Download complete
71ab1586461a: Verifying Checksum
71ab1586461a: Download complete
72e45e6fed5c: Verifying Checksum
72e45e6fed5c: Download complete
99e89f339e27: Verifying Checksum
99e89f339e27: Download complete
529dcf5ecc54: Verifying Checksum
529dcf5ecc54: Download complete
6d5a140d320e: Verifying Checksum
6d5a140d320e: Download complete
d9a7c5bf399b: Verifying Checksum
d9a7c5bf399b: Download complete
f0f51ee5c79e: Verifying Checksum
f0f51ee5c79e: Download complete
3ae0cb47dc06: Verifying Checksum
3ae0cb47dc06: Download complete
632ef5283d0f: Pull complete
2be42d221bda: Pull complete
54d1704eb717: Pull complete
f0f51ee5c79e: Pull complete
ec11ce133a4e: Pull complete
71ab1586461a: Pull complete
8e0e2fc3c108: Pull complete
4f4fb700ef54: Pull complete
72e45e6fed5c: Pull complete
99e89f339e27: Pull complete
3ae0cb47dc06: Pull complete
529dcf5ecc54: Pull complete
6d5a140d320e: Pull complete
d9a7c5bf399b: Pull complete
Digest: sha256:56b67a4ee30d4783351cc7a0dcef5e2d6e5cef599dd7f91913ebe4db2a19deff
Status: Downloaded newer image for yegor256/ruby:latest
docker.io/yegor256/ruby:latest
+ grep --quiet '\syegor256_judges_405\s*$'
+ docker ps --filter=status=exited
+ ls -al .
total 52
drwx------ 3 ubuntu ubuntu 4096 Mar 30 04:08 .
drwxrwxrwt 12 root root 4096 Mar 30 04:08 ..
-rwxrwxr-x 1 ubuntu ubuntu 666 Mar 30 04:08 end.sh
-rwxrwxr-x 1 ubuntu ubuntu 498 Mar 30 04:08 entry.sh
-rw-rw-r-- 1 ubuntu ubuntu 5 Mar 30 04:08 pid
drwxrwxr-x 11 ubuntu ubuntu 4096 Mar 30 04:08 repo
-rw-rw-r-- 1 ubuntu ubuntu 81 Mar 30 04:08 rubygems.yml
-rwxrwxr-x 1 ubuntu ubuntu 6537 Mar 30 04:08 run.sh
-rw-rw-r-- 1 ubuntu ubuntu 559 Mar 30 04:08 script.sh
-rw-rw-r-- 1 ubuntu ubuntu 8481 Mar 30 04:09 stdout
++ pwd
++ pwd
+ docker run -t --rm -v /tmp/rultor-AL7E:/main --env=head=git@github.com:yegor256/judges.git --env=pull_id=405 --env=fork=git@github.com:yegor256/judges.git --env=fork_branch=renovate/codecov-codecov-action-6.x --env=head_branch=master '--env=pull_title=Update codecov/codecov-action action to v6' --env=author=yegor256 '--env=scripts=( '\''export '\''\'\'''\''head=git@github.com:yegor256/judges.git'\''\'\'''\'''\'' '\'';'\'' '\''export '\''\'\'''\''pull_id=405'\''\'\'''\'''\'' '\'';'\'' '\''export '\''\'\'''\''fork=git@github.com:yegor256/judges.git'\''\'\'''\'''\'' '\'';'\'' '\''export '\''\'\'''\''fork_branch=renovate/codecov-codecov-action-6.x'\''\'\'''\'''\'' '\'';'\'' '\''export '\''\'\'''\''head_branch=master'\''\'\'''\'''\'' '\'';'\'' '\''export '\''\'\'''\''pull_title=Update codecov/codecov-action action to v6'\''\'\'''\'''\'' '\'';'\'' '\''export '\''\'\'''\''author=yegor256'\''\'\'''\'''\'' '\'';'\'' '\''pdd -f /dev/null'\'' '\'';'\'' '\''bundle install --no-color'\'' '\'';'\'' '\''bundle exec rake'\'' '\'';'\'' )' --hostname=docker --privileged --net=host --dns 8.8.8.8 --add-host docker:127.0.0.1 --memory=8g --memory-swap=16g --oom-kill-disable --cidfile=/tmp/rultor-AL7E/cid -w=/main -v /var/run/docker.sock:/var/run/docker.sock --name=yegor256_judges_405 yegor256/ruby /main/entry.sh
WARNING: Your kernel does not support OomKillDisable. OomKillDisable discarded.
+ set -e
+ set -o pipefail
+ shopt -s dotglob
+ useradd -m -G sudo r
++ awk -F : '$3 > 100 { print $1 }'
++ cat /etc/group
+ for g in $(cat /etc/group | awk -F ':' '$3 > 100 { print $1 }')
+ usermod -a -G nogroup r
+ for g in $(cat /etc/group | awk -F ':' '$3 > 100 { print $1 }')
+ usermod -a -G ssh r
+ for g in $(cat /etc/group | awk -F ':' '$3 > 100 { print $1 }')
+ usermod -a -G docker r
+ for g in $(cat /etc/group | awk -F ':' '$3 > 100 { print $1 }')
+ usermod -a -G r r
+ usermod -s /bin/bash r
+ echo '%sudo ALL=(ALL) NOPASSWD:ALL'
+ cp -R /root/.bashrc /root/.cache /root/.gemrc /root/.profile /home/r
+ cp -R ./cid ./end.sh ./entry.sh ./pid ./repo ./rubygems.yml ./run.sh ./script.sh ./stdout /home/r
+ rm -rf repo
+ chown -R r:r /home/r
+ chmod a+x /home/r/script.sh
+ cat /home/r/script.sh
#!/usr/bin/env bash
set -e
set -o pipefail
if [ -e /home/r/.profile ]; then source /home/r/.profile; fi
shopt -s expand_aliases
alias 'sudo=sudo -i'
export HOME=/home/r
cd "${HOME}/repo"
export 'head=git@github.com:yegor256/judges.git' ; export 'pull_id=405' ; export 'fork=git@github.com:yegor256/judges.git' ; export 'fork_branch=renovate/codecov-codecov-action-6.x' ; export 'head_branch=master' ; export 'pull_title=Update codecov/codecov-action action to v6' ; export 'author=yegor256' ; pdd -f /dev/null ; bundle install --no-color ; bundle exec rake ;
+ su --login r --command /home/r/script.sh
Found 7 lines in /home/r/repo/.pdd
My version is 0.23.1
Ruby version is 3.4.5 at x86_64-linux
Reading from root dir .
Excluding target/**/*
Excluding coverage/**/*
/usr/local/bundle/gems/pdd-0.23.1/lib/pdd/sources.rb:90: warning: undefining the allocator of T_DATA class FileMagic
/home/r/repo/package-lock.json is a binary file (38354 bytes)
/home/r/repo/package.json is a binary file (84 bytes)
/home/r/repo/renovate.json is a binary file (182 bytes)
Reading .0pdd.yml ...
Reading .gitattributes ...
Reading .github/workflows/actionlint.yml ...
Reading .github/workflows/codecov.yml ...
Reading .github/workflows/copyrights.yml ...
Reading .github/workflows/eslint.yml ...
Reading .github/workflows/markdown-lint.yml ...
Reading .github/workflows/pdd.yml ...
Reading .github/workflows/rake.yml ...
Reading .github/workflows/reuse.yml ...
Reading .github/workflows/typos.yml ...
Reading .github/workflows/xcop.yml ...
Reading .github/workflows/yamllint.yml ...
Reading .gitignore ...
Reading .pdd ...
Reading .rubocop.yml ...
Reading .rultor.yml ...
Reading Gemfile ...
Reading Gemfile.lock ...
Reading LICENSE.txt ...
Reading LICENSES/MIT.txt ...
Reading README.md ...
Reading REUSE.toml ...
Reading Rakefile ...
Reading assets/index.css ...
Reading assets/index.js ...
Reading assets/index.xsl ...
Reading bin/judges ...
Reading eslint.config.js ...
Reading features/echo.feature ...
Reading features/gem_package.feature ...
Reading features/import.feature ...
Reading features/inspect.feature ...
Reading features/join.feature ...
Reading features/misc.feature ...
Reading features/print.feature ...
Reading features/pull.feature ...
Reading features/push.feature ...
Reading features/step_definitions/steps.rb ...
Reading features/support/env.rb ...
Reading features/test.feature ...
Reading features/trim.feature ...
Reading features/update.feature ...
Reading features/version.feature ...
Reading fixtures/guess/guess.rb ...
Reading fixtures/guess/guess_made.yml ...
Reading fixtures/guess/skipped.yml ...
Reading fixtures/repeat/repeat.rb ...
Reading fixtures/repeat/repeated.yml ...
Reading fixtures/try/tried.yml ...
Reading fixtures/try/try.rb ...
Reading judges.gemspec ...
Reading lib/judges/ascii_loog.rb ...
Reading lib/judges/categories.rb ...
Reading lib/judges/commands/download.rb ...
Reading lib/judges/commands/eval.rb ...
Reading lib/judges/commands/import.rb ...
Reading lib/judges/commands/inspect.rb ...
Reading lib/judges/commands/join.rb ...
Reading lib/judges/commands/print.rb ...
Reading lib/judges/commands/pull.rb ...
Reading lib/judges/commands/push.rb ...
Reading lib/judges/commands/test.rb ...
Reading lib/judges/commands/trim.rb ...
Reading lib/judges/commands/update.rb ...
Reading lib/judges/commands/upload.rb ...
Reading lib/judges/impex.rb ...
Reading lib/judges/judge.rb ...
Reading lib/judges/judges.rb ...
Reading lib/judges/options.rb ...
Reading lib/judges/pretty_exception.rb ...
Reading lib/judges/statistics.rb ...
Reading lib/judges/to_rel.rb ...
Reading lib/judges.rb ...
Reading test/commands/test_download.rb ...
Reading test/commands/test_eval.rb ...
Reading test/commands/test_import.rb ...
Reading test/commands/test_inspect.rb ...
Reading test/commands/test_join.rb ...
Reading test/commands/test_print.rb ...
Reading test/commands/test_pull.rb ...
Reading test/commands/test_push.rb ...
Reading test/commands/test_test.rb ...
Reading test/commands/test_trim.rb ...
Reading test/commands/test_update.rb ...
Puzzle 341-1a6df420 30/DEV at test/commands/test_update.rb
Reading test/commands/test_upload.rb ...
Reading test/test__helper.rb ...
Reading test/test_ascii_loog.rb ...
Reading test/test_bin.rb ...
Reading test/test_categories.rb ...
Reading test/test_impex.rb ...
Reading test/test_judge.rb ...
Reading test/test_judges.rb ...
Reading test/test_options.rb ...
Reading test/test_pretty_exception.rb ...
Reading test/test_statistics.rb ...
Reading test/test_to_rel.rb ...
Bundler 2.6.9 is running, but your lockfile was generated with 2.6.8. Installing Bundler 2.6.8 and restarting using that version.
Fetching gem metadata from https://rubygems.org/.
Fetching bundler 2.6.8
Installing bundler 2.6.8
Fetching gem metadata from https://rubygems.org/........
Fetching rake 13.3.1
Installing rake 13.3.1
Fetching public_suffix 7.0.2
Installing public_suffix 7.0.2
Fetching addressable 2.8.9
Installing addressable 2.8.9
Fetching ansi 1.5.0
Installing ansi 1.5.0
Fetching ast 2.4.3
Installing ast 2.4.3
Fetching backtrace 0.4.1
Installing backtrace 0.4.1
Fetching base64 0.3.0
Installing base64 0.3.0
Fetching ellipsized 0.3.0
Installing ellipsized 0.3.0
Fetching logger 1.7.0
Installing logger 1.7.0
Fetching loog 0.8.0
Installing loog 0.8.0
Fetching tago 0.7.0
Installing tago 0.7.0
Fetching elapsed 0.3.1
Installing elapsed 0.3.1
Fetching uri 1.1.1
Installing uri 1.1.1
Fetching net-http 0.9.1
Installing net-http 0.9.1
Fetching faraday-net_http 3.4.2
Installing faraday-net_http 3.4.2
Fetching json 2.18.1
Installing json 2.18.1 with native extensions
Fetching faraday 2.14.1
Installing faraday 2.14.1
Fetching faraday-http-cache 2.6.1
Installing faraday-http-cache 2.6.1
Fetching multipart-post 2.4.1
Installing multipart-post 2.4.1
Fetching faraday-multipart 1.2.0
Installing faraday-multipart 1.2.0
Fetching faraday-retry 2.4.0
Installing faraday-retry 2.4.0
Fetching iri 0.11.8
Installing iri 0.11.8
Fetching retries 0.0.5
Installing retries 0.0.5
Fetching ffi 1.17.3 (x86_64-linux-gnu)
Installing ffi 1.17.3 (x86_64-linux-gnu)
Fetching ethon 0.18.0
Installing ethon 0.18.0
Fetching typhoeus 1.4.1
Installing typhoeus 1.4.1
Fetching baza.rb 0.14.3
Installing baza.rb 0.14.3
Fetching bigdecimal 4.0.1
Installing bigdecimal 4.0.1 with native extensions
Fetching builder 3.3.0
Installing builder 3.3.0
Fetching concurrent-ruby 1.3.6
Installing concurrent-ruby 1.3.6
Fetching rexml 3.4.4
Installing rexml 3.4.4
Fetching crack 1.0.1
Installing crack 1.0.1
Fetching cucumber-ci-environment 11.0.0
Installing cucumber-ci-environment 11.0.0
Fetching cucumber-messages 32.2.0
Installing cucumber-messages 32.2.0
Fetching cucumber-gherkin 39.0.0
Installing cucumber-gherkin 39.0.0
Fetching cucumber-tag-expressions 8.1.0
Installing cucumber-tag-expressions 8.1.0
Fetching cucumber-core 16.2.0
Installing cucumber-core 16.2.0
Fetching cucumber-cucumber-expressions 19.0.0
Installing cucumber-cucumber-expressions 19.0.0
Fetching cucumber-html-formatter 22.3.0
Installing cucumber-html-formatter 22.3.0
Fetching diff-lcs 1.6.2
Installing diff-lcs 1.6.2
Fetching mini_mime 1.1.5
Installing mini_mime 1.1.5
Fetching multi_test 1.1.0
Installing multi_test 1.1.0
Fetching memoist3 1.0.0
Installing memoist3 1.0.0
Fetching sys-uname 1.5.0
Installing sys-uname 1.5.0
Fetching cucumber 10.2.0
Installing cucumber 10.2.0
Fetching date 3.5.1
Installing date 3.5.1 with native extensions
Fetching decoor 0.1.0
Installing decoor 0.1.0
Fetching docile 1.4.1
Installing docile 1.4.1
Fetching drb 2.2.3
Installing drb 2.2.3
Fetching erb 6.0.2
Installing erb 6.0.2 with native extensions
Fetching nokogiri 1.19.1 (x86_64-linux-gnu)
Installing nokogiri 1.19.1 (x86_64-linux-gnu)
Fetching others 0.1.1
Installing others 0.1.1
Fetching yaml 0.4.0
Installing yaml 0.4.0
Fetching factbase 0.19.9
Installing factbase 0.19.9
Fetching ostruct 0.6.3
Installing ostruct 0.6.3
Fetching gli 2.22.2
Installing gli 2.22.2
Fetching hashdiff 1.2.1
Installing hashdiff 1.2.1
Fetching json-schema 6.1.0
Installing json-schema 6.1.0
Fetching moments 0.3.0
Installing moments 0.3.0
Fetching sawyer 0.9.3
Installing sawyer 0.9.3
Fetching octokit 10.0.0
Installing octokit 10.0.0
Fetching timeout 0.6.0
Installing timeout 0.6.0
Fetching total 0.4.2
Installing total 0.4.2
Fetching language_server-protocol 3.17.0.5
Installing language_server-protocol 3.17.0.5
Fetching lint_roller 1.1.0
Installing lint_roller 1.1.0
Fetching mcp 0.7.1
Installing mcp 0.7.1
Fetching prism 1.9.0
Installing prism 1.9.0 with native extensions
Fetching minitest 6.0.2
Installing minitest 6.0.2
Fetching minitest-mock 5.27.0
Installing minitest-mock 5.27.0
Fetching ruby-progressbar 1.13.0
Installing ruby-progressbar 1.13.0
Fetching minitest-reporters 1.7.1
Installing minitest-reporters 1.7.1
Fetching minitest-retry 0.3.1
Installing minitest-retry 0.3.1
Fetching openssl 4.0.1
Installing openssl 4.0.1 with native extensions
Fetching online 0.3.0
Installing online 0.3.0
Fetching os 1.1.4
Installing os 1.1.4
Fetching parallel 1.27.0
Installing parallel 1.27.0
Fetching parser 3.3.10.2
Installing parser 3.3.10.2
Fetching stringio 3.2.0
Installing stringio 3.2.0 with native extensions
Fetching psych 5.3.1
Installing psych 5.3.1 with native extensions
Fetching qbash 0.8.0
Installing qbash 0.8.0
Fetching random-port 0.8.2
Installing random-port 0.8.2
Fetching tsort 0.2.0
Installing tsort 0.2.0
Fetching rdoc 7.2.0
Installing rdoc 7.2.0
Fetching regexp_parser 2.11.3
Installing regexp_parser 2.11.3
Fetching rubocop-ast 1.49.0
Installing rubocop-ast 1.49.0
Fetching unicode-emoji 4.2.0
Installing unicode-emoji 4.2.0
Fetching unicode-display_width 3.2.0
Installing unicode-display_width 3.2.0
Fetching rubocop 1.85.0
Installing rubocop 1.85.0
Fetching rubocop-minitest 0.39.1
Installing rubocop-minitest 0.39.1
Fetching rubocop-performance 1.26.1
Installing rubocop-performance 1.26.1
Fetching rubocop-rake 0.7.1
Installing rubocop-rake 0.7.1
Fetching simplecov-html 0.13.2
Installing simplecov-html 0.13.2
Fetching simplecov_json_formatter 0.1.4
Installing simplecov_json_formatter 0.1.4
Fetching simplecov 0.22.0
Installing simplecov 0.22.0
Fetching simplecov-cobertura 3.1.0
Installing simplecov-cobertura 3.1.0
Fetching w3c_validators 1.3.7
Installing w3c_validators 1.3.7
Fetching webmock 3.26.1
Installing webmock 3.26.1
Fetching yard 0.9.38
Installing yard 0.9.38
Bundle complete! 23 Gemfile dependencies, 102 gems now installed.
Use `bundle info [gemname]` to see where a bundled gem is installed.
1 installed gem you directly depend on is looking for funding.
Run `bundle fund` for details
/usr/local/bundle/gems/minitest-6.0.2/lib/minitest.rb:1228: warning: /usr/local/bundle/gems/minitest-6.0.2/lib/minitest.rb:1228: warning: loading in progress, circular require considered harmful - /usr/local/bundle/gems/minitest-6.0.2/lib/minitest/test.rb
from /usr/local/bundle/gems/rake-13.3.1/lib/rake/rake_test_loader.rb:6:in '<main>'
from /usr/local/bundle/gems/rake-13.3.1/lib/rake/rake_test_loader.rb:6:in 'select'
from /usr/local/bundle/gems/rake-13.3.1/lib/rake/rake_test_loader.rb:21:in 'block in <main>'
from /usr/local/lib/ruby/3.4.0/bundled_gems.rb:82:in 'block (2 levels) in replace_require'
from /usr/local/lib/ruby/3.4.0/bundled_gems.rb:82:in 'require'
from /home/r/repo/test/commands/test_download.rb:7:in '<top (required)>'
from /usr/local/lib/ruby/3.4.0/bundled_gems.rb:82:in 'block (2 levels) in replace_require'
from /usr/local/lib/ruby/3.4.0/bundled_gems.rb:82:in 'require'
from /usr/local/bundle/gems/webmock-3.26.1/lib/webmock/minitest.rb:4:in '<top (required)>'
from /usr/local/lib/ruby/3.4.0/bundled_gems.rb:82:in 'block (2 levels) in replace_require'
from /usr/local/lib/ruby/3.4.0/bundled_gems.rb:82:in 'require'
from /usr/local/bundle/gems/minitest-6.0.2/lib/minitest/test.rb:1:in '<top (required)>'
from /usr/local/bundle/gems/minitest-6.0.2/lib/minitest/test.rb:1:in 'require_relative'
from /usr/local/bundle/gems/minitest-6.0.2/lib/minitest.rb:1228:in '<top (required)>'
from /usr/local/bundle/gems/minitest-6.0.2/lib/minitest.rb:1228:in 'require_relative'
Started with run options --seed 31614
TestUpdate
test_exports_fb_only_once 32m PASS0m (0.00s)
test_skipped_judge 32m PASS0m (0.00s)
test_cancels_slow_execution 32m PASS0m (0.14s)
test_appends_to_existing_summary 32m PASS0m (0.00s)
test_fails_when_no_judges_used 32m PASS0m (0.00s)
test_reports_changes_from_slow_judge 32m PASS0m (0.10s)
test_exports_all_judges_despite_lifetime_timeout 32m PASS0m (2.01s)
test_churn_file_creation 32m PASS0m (0.00s)
/tmp/d20260330-957-ftexko/foo/foo.rb:1: warning: possibly useless use of a variable in void context
/tmp/d20260330-957-ftexko/foo/foo.rb:1: warning: possibly useless use of a variable in void context
/tmp/d20260330-957-ftexko/foo/foo.rb:1: warning: possibly useless use of a variable in void context
/tmp/d20260330-957-ftexko/foo/foo.rb:1: warning: possibly useless use of a variable in void context
/tmp/d20260330-957-ftexko/foo/foo.rb:1: warning: possibly useless use of a variable in void context
/tmp/d20260330-957-ftexko/foo/foo.rb:1: warning: possibly useless use of a variable in void context
/tmp/d20260330-957-ftexko/foo/foo.rb:1: warning: possibly useless use of a variable in void context
/tmp/d20260330-957-ftexko/foo/foo.rb:1: warning: possibly useless use of a variable in void context
test_update_with_error_and_summary 32m PASS0m (0.01s)
test_cancels_slow_judge 32m PASS0m (0.10s)
test_fails_when_empty_directory 32m PASS0m (0.00s)
test_log_pretty_github_exception 32m PASS0m (0.02s)
test_exports_churn_to_file_despite_error 32m PASS0m (0.10s)
test_seed_parameter_is_passed_through 32m PASS0m (0.01s)
/tmp/d20260330-957-749qz8/bar/bar.rb:1: warning: possibly useless use of a variable in void context
/tmp/d20260330-957-749qz8/bar/bar.rb:1: warning: possibly useless use of a variable in void context
/tmp/d20260330-957-749qz8/bar/bar.rb:1: warning: possibly useless use of a variable in void context
/tmp/d20260330-957-749qz8/bar/bar.rb:1: warning: possibly useless use of a variable in void context
test_exports_fb_despite_judge_syntax_error 32m PASS0m (0.00s)
test_no_failure_when_expect_judges_false 32m PASS0m (0.00s)
/tmp/d20260330-957-mi0w4t/first/first.rb:1: warning: possibly useless use of + in void context
/tmp/d20260330-957-mi0w4t/first/first.rb:1: warning: possibly useless use of + in void context
/tmp/d20260330-957-mi0w4t/first/first.rb:1: warning: possibly useless use of + in void context
test_isolates_churns 32m PASS0m (0.01s)
/tmp/d20260330-957-3y4nq8/bar/bar.rb:1: warning: ambiguous first argument; put parentheses or a space even after `-` operator
/tmp/d20260330-957-3y4nq8/bar/bar.rb:1: warning: possibly useless use of -@ in void context
/tmp/d20260330-957-3y4nq8/bar/bar.rb:1: warning: possibly useless use of -@ in void context
/tmp/d20260330-957-3y4nq8/bar/bar.rb:1: warning: possibly useless use of -@ in void context
test_with_only_one_judge 32m PASS0m (0.01s)
test_passes_timeout_and_lifetime_through 32m PASS0m (0.00s)
test_update_with_options_in_file 32m PASS0m (0.00s)
test_no_failure_with_nonexistent_judge_when_expect_judges_false32m PASS0m (0.00s)
/tmp/d20260330-957-s9lzo4/error/error.rb:1: warning: possibly useless use of a variable in void context
test_fail_fast_stops_cycle 32m PASS0m (0.00s)
/tmp/d20260330-957-a138vz/foo/foo.rb:1: warning: possibly useless use of a variable in void context
/tmp/d20260330-957-a138vz/foo/foo.rb:1: warning: possibly useless use of a variable in void context
/tmp/d20260330-957-a138vz/foo/foo.rb:1: warning: possibly useless use of a variable in void context
/tmp/d20260330-957-a138vz/foo/foo.rb:1: warning: possibly useless use of a variable in void context
test_update_with_error 32m PASS0m (0.00s)
test_build_factbase_from_scratch 32m PASS0m (0.00s)
test_terminates_on_lifetime 32m PASS0m (0.10s)
/tmp/d20260330-957-bp52ci/foo/foo.rb:1: warning: possibly useless use of < in void context
test_update_with_error_no_quiet 32m PASS0m (0.00s)
test_accepts_changes_from_slow_judge 32m PASS0m (0.10s)
test_extend_existing_factbase 32m PASS0m (0.00s)
TestPush
test_push_simple_factbase 32m PASS0m (0.02s)
test_fails_on_http_error 32m PASS0m (0.01s)
TestEval
test_build_factbase_from_scratch 32m PASS0m (0.00s)
TestJoin
test_simple_join 32m PASS0m (0.00s)
TestJudge
test_sets_start_value_correctly 32m PASS0m (0.00s)
test_with_broken_ruby_syntax 32m PASS0m (0.00s)
test_sets_judge_value_correctly 32m PASS0m (0.00s)
test_with_standard_error 32m PASS0m (0.00s)
test_passes_local_vars_between_tests 32m PASS0m (0.00s)
test_basic_run 32m PASS0m (0.00s)
test_with_runtime_ruby_error 32m PASS0m (0.00s)
test_run_isolated 32m PASS0m (0.00s)
TestInspect
test_simple_inspect_with_summary 32m PASS0m (0.00s)
test_simple_inspect 32m PASS0m (0.00s)
TestOptions
test_merge_by_symbols 32m PASS0m (0.00s)
test_with_hash 32m PASS0m (0.00s)
test_with_string 32m PASS0m (0.00s)
test_stips_spaces 32m PASS0m (0.00s)
test_merge 32m PASS0m (0.00s)
test_case_insensitive 32m PASS0m (0.00s)
test_with_empty_strings 32m PASS0m (0.00s)
test_converts_to_string 32m PASS0m (0.00s)
test_with_empty_string 32m PASS0m (0.00s)
test_with_nil 32m PASS0m (0.00s)
test_basic 32m PASS0m (0.00s)
test_with_nil_values 32m PASS0m (0.00s)
TestImport
test_import_from_yaml 32m PASS0m (0.00s)
TestJudges
test_boost_with_wildcard_patterns 32m PASS0m (0.00s)
test_get_one 32m PASS0m (0.00s)
test_default_seed 32m PASS0m (0.00s)
test_demote_with_wildcard_patterns 32m PASS0m (0.00s)
test_different_seed_produces_different_order 32m PASS0m (0.00s)
test_list_with_empty_dir 32m PASS0m (0.00s)
test_same_seed_produces_same_order 32m PASS0m (0.00s)
test_shuffles_and_boosts 32m PASS0m (0.00s)
test_boost_and_demote_together 32m PASS0m (0.00s)
test_shuffles_them 32m PASS0m (0.00s)
test_boost_and_demote_with_wildcards_together 32m PASS0m (0.00s)
test_demotes_judges 32m PASS0m (0.00s)
test_keeps_them_all 32m PASS0m (0.00s)
test_basic 32m PASS0m (0.00s)
test_list_only_direct_subdirs 32m PASS0m (0.00s)
TestUpload
test_upload_simple_durable 32m PASS0m (0.01s)
test_fails_when_file_does_not_exist 32m PASS0m (0.00s)
test_fails_on_http_error 32m PASS0m (0.01s)
test_upload_with_custom_owner 32m PASS0m (0.01s)
test_fails_with_wrong_number_of_arguments 32m PASS0m (0.00s)
TestPrint
test_print_twice 32m PASS0m (0.01s)
test_print_all_formats 32m PASS0m (0.01s)
test_html_table_has_colgroup 32m PASS0m (0.01s)
test_simple_print 32m PASS0m (0.00s)
test_print_to_html 33m SKIP0m (0.01s)
TestCategories
test_basic 32m PASS0m (0.00s)
test_all_enabled 32m PASS0m (0.00s)
TestPull
test_pull_simple_factbase 32m PASS0m (0.01s)
test_fail_pull_when_job_is_broken 32m PASS0m (0.01s)
TestBin
/usr/local/bundle/gems/gli-2.22.2/lib/gli/commands/help_modules/text_wrapper.rb:48: warning: character class has duplicated range: /[\n\s]*\Z/
/usr/local/bundle/gems/gli-2.22.2/lib/gli/commands/help_modules/global_help_format.rb:30: warning: assigned but unused variable - global_option_descriptions
/usr/local/bundle/gems/gli-2.22.2/lib/gli/commands/help_modules/global_help_format.rb:28: warning: assigned but unused variable - commands
/usr/local/bundle/gems/gli-2.22.2/lib/gli/commands/help_modules/global_help_format.rb:14: warning: assigned but unused variable - program_desc
/usr/local/bundle/gems/gli-2.22.2/lib/gli/commands/help_modules/command_help_format.rb:17: warning: assigned but unused variable - wrapper
/usr/local/bundle/gems/gli-2.22.2/lib/gli/commands/help_modules/command_help_format.rb:21: warning: assigned but unused variable - command_examples
/usr/local/bundle/gems/gli-2.22.2/lib/gli/commands/help_modules/command_help_format.rb:16: warning: assigned but unused variable - command_wrapper
/usr/local/bundle/gems/gli-2.22.2/lib/gli/commands/help_modules/command_help_format.rb:20: warning: assigned but unused variable - commands_description
/usr/local/bundle/gems/gli-2.22.2/lib/gli/commands/help_modules/command_help_format.rb:23: warning: assigned but unused variable - synopses
/usr/local/bundle/gems/gli-2.22.2/lib/gli/commands/help_modules/command_help_format.rb:19: warning: assigned but unused variable - options_description
/usr/local/bundle/gems/gli-2.22.2/lib/gli/commands/help_modules/full_synopsis_formatter.rb:29: warning: assigned but unused variable - sub_options_doc
/usr/local/bundle/gems/gli-2.22.2/lib/gli/commands/help_modules/full_synopsis_formatter.rb:92: warning: assigned but unused variable - synopses
/usr/local/lib/ruby/3.4.0/bundled_gems.rb:82: warning: /usr/local/lib/ruby/3.4.0/bundled_gems.rb:82: warning: loading in progress, circular require considered harmful - /usr/local/bundle/gems/gli-2.22.2/lib/gli.rb
from /usr/local/bundle/gems/minitest-6.0.2/lib/minitest.rb:84:in 'block in autorun'
from /usr/local/bundle/gems/minitest-6.0.2/lib/minitest.rb:316:in 'run'
from /usr/local/bundle/gems/minitest-6.0.2/lib/minitest.rb:361:in 'run_all_suites'
from /usr/local/bundle/gems/minitest-6.0.2/lib/minitest.rb:361:in 'map'
from /usr/local/bundle/gems/minitest-6.0.2/lib/minitest.rb:361:in 'block in run_all_suites'
from /usr/local/bundle/gems/minitest-6.0.2/lib/minitest.rb:468:in 'run_suite'
from /usr/local/bundle/gems/minitest-6.0.2/lib/minitest.rb:498:in 'with_info_handler'
from /usr/local/bundle/gems/minitest-6.0.2/lib/minitest.rb:511:in 'on_signal'
from /usr/local/bundle/gems/minitest-6.0.2/lib/minitest.rb:469:in 'block in run_suite'
from /usr/local/bundle/gems/minitest-6.0.2/lib/minitest.rb:469:in 'each'
from /usr/local/bundle/gems/minitest-6.0.2/lib/minitest.rb:473:in 'block (2 levels) in run_suite'
from /usr/local/bundle/gems/minitest-6.0.2/lib/minitest.rb:486:in 'run'
from /usr/local/bundle/gems/minitest-reporters-1.7.1/lib/minitest/reporters.rb:48:in 'run_with_hooks'
from /usr/local/bundle/gems/minitest-6.0.2/lib/minitest/test.rb:85:in 'run'
from /usr/local/bundle/gems/minitest-6.0.2/lib/minitest.rb:397:in 'time_it'
from /usr/local/bundle/gems/minitest-6.0.2/lib/minitest/test.rb:86:in 'block in run'
from /usr/local/bundle/gems/minitest-6.0.2/lib/minitest/test.rb:187:in 'capture_exceptions'
from /usr/local/bundle/gems/minitest-6.0.2/lib/minitest/test.rb:91:in 'block (2 levels) in run'
from /home/r/repo/test/test_bin.rb:15:in 'test_simple_run'
from /home/r/repo/test/test_bin.rb:15:in 'load'
from /home/r/repo/bin/judges:10:in '<top (required)>'
from /usr/local/lib/ruby/3.4.0/bundled_gems.rb:82:in 'block (2 levels) in replace_require'
from /usr/local/lib/ruby/3.4.0/bundled_gems.rb:82:in 'require'
from /usr/local/bundle/gems/gli-2.22.2/lib/gli.rb:21:in '<top (required)>'
from /usr/local/lib/ruby/3.4.0/bundled_gems.rb:82:in 'block (2 levels) in replace_require'
from /usr/local/lib/ruby/3.4.0/bundled_gems.rb:82:in 'require'
from /usr/local/bundle/gems/gli-2.22.2/lib/gli/commands/initconfig.rb:1:in '<top (required)>'
from /usr/local/lib/ruby/3.4.0/bundled_gems.rb:82:in 'block (2 levels) in replace_require'
from /usr/local/lib/ruby/3.4.0/bundled_gems.rb:82:in 'require'
/usr/local/bundle/gems/gli-2.22.2/lib/gli/commands/doc.rb:145: warning: assigned but unused variable - ex
/home/r/repo/bin/judges:18: warning: setting Encoding.default_external
/home/r/repo/bin/judges:19: warning: setting Encoding.default_internal
test_simple_run 32m PASS0m (0.05s)
TestAsciiLoog
test_handles_empty_and_nil_messages 32m PASS0m (0.00s)
test_multiple_same_symbols 32m PASS0m (0.00s)
test_responds_to_original_logger_methods 32m PASS0m (0.01s)
test_handles_mixed_encodings 32m PASS0m (0.00s)
test_handles_binary_encoding 32m PASS0m (0.00s)
test_converts_unicode_symbols 32m PASS0m (0.00s)
test_mixed_unicode_and_ascii 32m PASS0m (0.00s)
test_delegates_unknown_methods 32m PASS0m (0.00s)
test_leaves_non_unicode_text_unchanged 32m PASS0m (0.00s)
test_converts_all_defined_symbols 32m PASS0m (0.00s)
TestTest
test_with_after_assertion 32m PASS0m (0.00s)
test_with_options 32m PASS0m (0.00s)
test_with_timeout_success 32m PASS0m (0.00s)
test_with_before 32m PASS0m (0.00s)
test_positive 32m PASS0m (0.00s)
test_negative 32m PASS0m (0.00s)
test_with_expected_failure_no_string 32m PASS0m (0.00s)
test_one_judge_negative 32m PASS0m (0.00s)
test_with_expected_failure 32m PASS0m (0.00s)
test_with_timeout_failure 32m PASS0m (1.00s)
test_ellipsized_long_script_name 32m PASS0m (0.00s)
test_with_timeout_in_after_script 32m PASS0m (1.00s)
TestToRel
test_simple_mapping 32m PASS0m (0.00s)
test_maps_dir_name 32m PASS0m (0.00s)
TestImpex
test_strict_import 32m PASS0m (0.00s)
test_basic 32m PASS0m (0.00s)
TestTrim
test_trims_factbase 32m PASS0m (0.00s)
TestPrettyException
test_long_message 32m PASS0m (0.00s)
test_hide_class 32m PASS0m (0.00s)
test_short_message 32m PASS0m (0.00s)
TestDownload
test_fails_with_wrong_number_of_arguments 32m PASS0m (0.00s)
test_download_with_custom_owner 32m PASS0m (0.01s)
test_download_simple_durable 32m PASS0m (0.01s)
test_handles_not_found_durable 32m PASS0m (0.00s)
test_fails_on_http_error 32m PASS0m (0.01s)
TestStatistics
test_judges_sorted_by_total_time 32m PASS0m (0.00s)
test_record_with_churn 32m PASS0m (0.00s)
test_not_empty_after_recording 32m PASS0m (0.00s)
test_record_basic_statistics 32m PASS0m (0.00s)
test_record_multiple_judges 32m PASS0m (0.00s)
test_result_summarization_mixed_results 32m PASS0m (0.00s)
test_result_summarization_single_result 32m PASS0m (0.00s)
test_skipped_results 32m PASS0m (0.00s)
test_empty_statistics 32m PASS0m (0.00s)
test_very_long_judge_names 32m PASS0m (0.00s)
test_fractional_seconds_formatting 32m PASS0m (0.00s)
test_record_multiple_cycles_same_judge 32m PASS0m (0.00s)
test_record_without_churn 32m PASS0m (0.00s)
test_empty_report 32m PASS0m (0.00s)
test_report_format_headers 32m PASS0m (0.00s)
Finished in 5.10636s
135 tests, 421 assertions, 32m0 failures, 0 errors, 0m33m1 skips0m
Coverage report generated for test to /home/r/repo/coverage.
Line Coverage: 92.95% (976 / 1050)
Coverage report generated for test to /home/r/repo/coverage/coverage.xml.
Line Coverage: 92.95% (976 / 1050)
/usr/local/bin/ruby -S bundle exec cucumber --no-color --retry=2 --fail-fast --backtrace --order=random
# SPDX-FileCopyrightText: Copyright (c) 2024-2026 Yegor Bugayenko
# SPDX-License-Identifier: MIT
Feature: Print
I want to print a factbase
Scenario: Simple print of a small factbase, to XML # features/print.feature:36
Given I make a temp directory # features/step_definitions/steps.rb:27
Then I run bin/judges with "--verbose eval simple.fb '$fb.insert.foo = 42'" # features/step_definitions/steps.rb:38
Then I run bin/judges with "print --format=xml --auto simple.fb" # features/step_definitions/steps.rb:38
Then Stdout contains "printed" # features/step_definitions/steps.rb:64
And Exit code is zero # features/step_definitions/steps.rb:72
Feature: Update
I want to run a few judges over a factbase
Scenario: Simple run of a few judges # features/update.feature:7
Given I make a temp directory # features/step_definitions/steps.rb:27
Then I have a "simple/simple.rb" file with content: # features/step_definitions/steps.rb:33
"""
n = $fb.insert
n.kind = 'yes!'
"""
Then I run bin/judges with "--verbose --hello update --quiet -o foo=1 -o bar=2 --max-cycles 3 . simple.fb" # features/step_definitions/steps.rb:38
Then Stdout contains "FOO → " # features/step_definitions/steps.rb:64
Then Stdout contains "BAR → " # features/step_definitions/steps.rb:64
Then Stdout contains "1 judge(s) processed" # features/step_definitions/steps.rb:64
Then Stdout contains "Update completed in 3 cycle(s), did 3i/0d/3a" # features/step_definitions/steps.rb:64
And Exit code is zero # features/step_definitions/steps.rb:72
Feature: Test
I want to test a few judges
Scenario: Simple test of no judges # features/test.feature:23
Given I run bin/judges with "test --judge absent_for_sure ./fixtures" # features/step_definitions/steps.rb:38
Then Exit code is zero # features/step_definitions/steps.rb:72
Feature: Trim
I want to trim a factbase
Scenario: Delete nothing by default # features/trim.feature:14
Given I make a temp directory # features/step_definitions/steps.rb:27
Then I run bin/judges with "--verbose eval simple.fb '$fb.insert.foo = 42'" # features/step_definitions/steps.rb:38
Given I run bin/judges with "trim simple.fb" # features/step_definitions/steps.rb:38
Then Stdout contains "No facts deleted" # features/step_definitions/steps.rb:64
And Exit code is zero # features/step_definitions/steps.rb:72
Scenario: Simple trimming of a factbase, with a query # features/trim.feature:7
Given I make a temp directory # features/step_definitions/steps.rb:27
Then I run bin/judges with "--verbose eval simple.fb '$fb.insert.foo = 42'" # features/step_definitions/steps.rb:38
Given I run bin/judges with "trim --query '(eq foo 42)' simple.fb" # features/step_definitions/steps.rb:38
Then Stdout contains "1 fact(s) deleted" # features/step_definitions/steps.rb:64
And Exit code is zero # features/step_definitions/steps.rb:72
Feature: Import
I want to import YAML into a factbase
Scenario: Simple import of a small YAML # features/import.feature:7
Given I make a temp directory # features/step_definitions/steps.rb:27
Then I have a "simple.yaml" file with content: # features/step_definitions/steps.rb:33
"""
-
foo: 42
bar: 2024-03-04T22:22:22Z
t: Hello, world!
-
z: 3.14
"""
Then I run bin/judges with "--verbose import simple.yaml simple.fb" # features/step_definitions/steps.rb:38
Then Stdout contains "Import of 2 facts completed" # features/step_definitions/steps.rb:64
And Exit code is zero # features/step_definitions/steps.rb:72
Feature: Inspect
I want to inspect a factbase
Scenario: Inspect with a summary # features/inspect.feature:14
Given I make a temp directory # features/step_definitions/steps.rb:27
Then I run bin/judges with "--verbose eval simple.fb '$fb.insert.what = "judges-summary"'" # features/inspect.feature:16
Then I run bin/judges with "inspect simple.fb" # features/step_definitions/steps.rb:38
Then Stdout contains "Facts: 1" # features/step_definitions/steps.rb:64
And Exit code is zero # features/step_definitions/steps.rb:72
Feature: Update
I want to run a few judges over a factbase
Scenario: The update fails when a broken Ruby syntax in a judge # features/update.feature:126
Given I make a temp directory # features/step_definitions/steps.rb:27
Then I have a "mine/broken/broken.rb" file with content: # features/step_definitions/steps.rb:33
"""
invalid$ruby$syntax$here
"""
Then I run bin/judges with "update mine simple.fb" # features/step_definitions/steps.rb:38
Then Stdout contains "Failed to update correctly" # features/step_definitions/steps.rb:64
And Exit code is not zero # features/step_definitions/steps.rb:76
Feature: Print
I want to print a factbase
Scenario: Simple print of a small factbase, to XML, with a query # features/print.feature:43
Given I make a temp directory # features/step_definitions/steps.rb:27
Then I run bin/judges with "--verbose eval simple.fb '$fb.insert.foo = 42'" # features/step_definitions/steps.rb:38
Then I run bin/judges with "--verbose eval simple.fb '$fb.insert.foo = 43'" # features/step_definitions/steps.rb:38
Then I run bin/judges with "print '--query=(eq foo 43)' --auto simple.fb" # features/step_definitions/steps.rb:38
Then Stdout contains "printed" # features/step_definitions/steps.rb:64
And Exit code is zero # features/step_definitions/steps.rb:72
Scenario: Simple print of a small factbase, to YAML # features/print.feature:7
Given I make a temp directory # features/step_definitions/steps.rb:27
Then I run bin/judges with "--verbose eval simple.fb '$fb.insert.foo = 42'" # features/step_definitions/steps.rb:38
Then I run bin/judges with "print --format=yaml simple.fb simple.yml" # features/step_definitions/steps.rb:38
Then Stdout contains "printed" # features/step_definitions/steps.rb:64
And Exit code is zero # features/step_definitions/steps.rb:72
Scenario: Simple print of a small factbase, to HTML, in offline mode # features/print.feature:21
Given I make a temp directory # features/step_definitions/steps.rb:27
Then I run bin/judges with "--verbose eval simple.fb '$fb.insert.foo = 42'" # features/step_definitions/steps.rb:38
Then I run bin/judges with "--offline print --format=html simple.fb simple.html" # features/step_definitions/steps.rb:38
Then Stdout contains "printed" # features/step_definitions/steps.rb:64
Then simple.html contains "sha256-offline" # features/step_definitions/steps.rb:59
And Exit code is zero # features/step_definitions/steps.rb:72
Scenario: Simple print of a small factbase, to JSON # features/print.feature:29
Given I make a temp directory # features/step_definitions/steps.rb:27
Then I run bin/judges with "--verbose eval simple.fb '$fb.insert.foo = 42'" # features/step_definitions/steps.rb:38
Then I run bin/judges with "print --format=json simple.fb simple.json" # features/step_definitions/steps.rb:38
Then Stdout contains "printed" # features/step_definitions/steps.rb:64
And Exit code is zero # features/step_definitions/steps.rb:72
Feature: Update
I want to run a few judges over a factbase
Scenario: Simple run of a few judges, with a lib # features/update.feature:100
Given I make a temp directory # features/step_definitions/steps.rb:27
Then I have a "mine/judge1/judge1.rb" file with content: # features/step_definitions/steps.rb:33
"""
n = $fb.insert
n.foo = $foo
"""
Then I have a "mylib/foo.rb" file with content: # features/step_definitions/steps.rb:33
"""
$foo = 42
"""
Then I run bin/judges with "update --lib mylib --max-cycles 1 mine simple.fb" # features/step_definitions/steps.rb:38
Then Stdout contains "1 judge(s) processed" # features/step_definitions/steps.rb:64
Then Stdout contains "Update completed in 1 cycle(s)" # features/step_definitions/steps.rb:64
And Exit code is zero # features/step_definitions/steps.rb:72
Feature: Test
I want to test a few judges
Scenario: Simple test of just one judge # features/test.feature:13
Given I run bin/judges with "test --judge guess ./fixtures" # features/step_definitions/steps.rb:38
Then Stdout contains "All 1 judge(s) and 1 tests passed" # features/step_definitions/steps.rb:64
And Exit code is zero # features/step_definitions/steps.rb:72
Scenario: Factbase version can be set # features/test.feature:18
When I run bin/judges with "--factbase 0.19.9 --verbose test --judge guess ./fixtures" # features/step_definitions/steps.rb:38
Then Exit code is zero # features/step_definitions/steps.rb:72
And Stdout contains "Factbase version to be used: '0.19.9'" # features/step_definitions/steps.rb:64
Feature: Update
I want to run a few judges over a factbase
Scenario: Show statistics for judge execution # features/update.feature:218
Given I make a temp directory # features/step_definitions/steps.rb:27
Then I have a "alpha/alpha.rb" file with content: # features/step_definitions/steps.rb:33
"""
$fb.insert.name = 'alpha'
"""
Then I have a "beta/beta.rb" file with content: # features/step_definitions/steps.rb:33
"""
$fb.insert.name = 'beta'
"""
Then I run bin/judges with "update --statistics --quiet --max-cycles 1 . stats.fb" # features/step_definitions/steps.rb:38
Then Stdout contains "Judge execution summary:" # features/step_definitions/steps.rb:64
Then Stdout contains "Judge" # features/step_definitions/steps.rb:64
Then Stdout contains "Seconds" # features/step_definitions/steps.rb:64
Then Stdout contains "Changes" # features/step_definitions/steps.rb:64
Then Stdout contains "Cycles" # features/step_definitions/steps.rb:64
Then Stdout contains "Result" # features/step_definitions/steps.rb:64
Then Stdout contains "alpha" # features/step_definitions/steps.rb:64
Then Stdout contains "beta" # features/step_definitions/steps.rb:64
Then Stdout contains "OK" # features/step_definitions/steps.rb:64
And Exit code is zero # features/step_definitions/steps.rb:72
Feature: Pull
I want to pull a factbase
Scenario: Pull a small factbase, which is absent on the server # features/pull.feature:7
Given We are online # features/step_definitions/steps.rb:21
Given I make a temp directory # features/step_definitions/steps.rb:27
Then I run bin/judges with "--verbose pull --token ZRCY-00000000-0000-0000-0000-000000000000 --wait=15 fake04642fff881be561 simple.fb # features/step_definitions/steps.rb:38
Then Stdout contains "doesn't exist at api.zerocracy.com" # features/step_definitions/steps.rb:64
And Exit code is zero # features/step_definitions/steps.rb:72
Feature: Update
I want to run a few judges over a factbase
Scenario: Simple demote of a single judge # features/update.feature:150
Given I make a temp directory # features/step_definitions/steps.rb:27
Then I have a "alpha/alpha.rb" file with content: # features/step_definitions/steps.rb:33
"""
$fb.insert.name = 'alpha'
"""
Then I have a "beta/beta.rb" file with content: # features/step_definitions/steps.rb:33
"""
$fb.insert.name = 'beta'
"""
Then I have a "gamma/gamma.rb" file with content: # features/step_definitions/steps.rb:33
"""
$fb.insert.name = 'gamma'
"""
Then I run bin/judges with "--verbose update --quiet --max-cycles 1 --demote beta . demote.fb" # features/step_definitions/steps.rb:38
Then Stdout contains "Running alpha" # features/step_definitions/steps.rb:64
Then Stdout contains "Running gamma" # features/step_definitions/steps.rb:64
Then Stdout contains "Running beta" # features/step_definitions/steps.rb:64
Then Stdout contains "3 judge(s) processed" # features/step_definitions/steps.rb:64
And Exit code is zero # features/step_definitions/steps.rb:72
Feature: Test
I want to test a few judges
Scenario: Test with a pre-condition # features/test.feature:128
Given I make a temp directory # features/step_definitions/steps.rb:27
Then I have a "mine/first/first.rb" file with content: # features/step_definitions/steps.rb:33
"""
n = $fb.insert
n.foo = 42
"""
Then I have a "mine/second/second.rb" file with content: # features/step_definitions/steps.rb:33
"""
n = $fb.insert
n.foo = 55
"""
Then I have a "mine/second/second.yml" file with content: # features/step_definitions/steps.rb:33
"""
---
before:
- first
expected:
- /fb[count(f)=2]
"""
Then I run bin/judges with "test mine" # features/step_definitions/steps.rb:38
And Exit code is zero # features/step_definitions/steps.rb:72
Scenario: Test with a post-assert # features/test.feature:151
Given I make a temp directory # features/step_definitions/steps.rb:27
Then I have a "mine/foo/foo.rb" file with content: # features/step_definitions/steps.rb:33
"""
n = $fb.insert
n.foo = 42
"""
Then I have a "mine/foo/assert.rb" file with content: # features/step_definitions/steps.rb:33
"""
raise unless $fb.size == 1
"""
Then I have a "mine/foo/simple.yml" file with content: # features/step_definitions/steps.rb:33
"""
---
expected:
- /fb[count(f)=1]
after:
- assert.rb
"""
Then I run bin/judges with "test mine" # features/step_definitions/steps.rb:38
And Exit code is zero # features/step_definitions/steps.rb:72
Scenario: Simple test with many runs # features/test.feature:58
Given I make a temp directory # features/step_definitions/steps.rb:27
Then I have a "foo/foo.rb" file with content: # features/step_definitions/steps.rb:33
"""
n = $fb.insert
n.foo = $fb.size
"""
Then I have a "foo/good.yml" file with content: # features/step_definitions/steps.rb:33
"""
---
runs: 5
input: []
expected:
- /fb[count(f)=5]
"""
Then I run bin/judges with "test ." # features/step_definitions/steps.rb:38
Then Stdout contains "All 1 judge(s) and 1 tests passed" # features/step_definitions/steps.rb:64
And Exit code is zero # features/step_definitions/steps.rb:72
Feature: Inspect
I want to inspect a factbase
Scenario: Simple inspect of a small factbase # features/inspect.feature:7
Given I make a temp directory # features/step_definitions/steps.rb:27
Then I run bin/judges with "--verbose eval simple.fb '$fb.insert.foo = 42'" # features/step_definitions/steps.rb:38
Then I run bin/judges with "inspect simple.fb" # features/step_definitions/steps.rb:38
Then Stdout contains "Facts: 1" # features/step_definitions/steps.rb:64
And Exit code is zero # features/step_definitions/steps.rb:72
Feature: Test
I want to test a few judges
Scenario: Simple test of a few judges, with a lib # features/test.feature:37
Given I make a temp directory # features/step_definitions/steps.rb:27
Then I have a "myjudges/good/good.rb" file with content: # features/step_definitions/steps.rb:33
"""
n = $fb.insert
n.foo = $foo
"""
Then I have a "myjudges/good/good.yml" file with content: # features/step_definitions/steps.rb:33
"""
---
category: good
input: []
"""
Then I have a "mylib/foo.rb" file with content: # features/step_definitions/steps.rb:33
"""
$foo = 42
"""
Then I run bin/judges with "test --lib mylib myjudges" # features/step_definitions/steps.rb:38
Then Stdout contains "All 1 judge(s) and 1 tests passed" # features/step_definitions/steps.rb:64
And Exit code is zero # features/step_definitions/steps.rb:72
Feature: Update
I want to run a few judges over a factbase
Scenario: Delete a previous summary fact and create new one # features/update.feature:42
Given I make a temp directory # features/step_definitions/steps.rb:27
Then I have a "buggy/buggy.rb" file with content: "this is an intentional bug" # features/update.feature:44
Then I run bin/judges with "update --quiet --summary=add --max-cycles 1 . simple.fb" # features/step_definitions/steps.rb:38
Then Exit code is zero # features/step_definitions/steps.rb:72
Then Stdout contains "Summary fact added" # features/step_definitions/steps.rb:64
Then I run bin/judges with "update --quiet --summary=add --max-cycles 1 . simple.fb" # features/step_definitions/steps.rb:38
Then Exit code is zero # features/step_definitions/steps.rb:72
And Stdout contains "Summary fact deleted" # features/step_definitions/steps.rb:64
Feature: Push
I want to push a factbase
Scenario: Push a small factbase # features/push.feature:7
Given We are online # features/step_definitions/steps.rb:21
Given I make a temp directory # features/step_definitions/steps.rb:27
Then I run bin/judges with "--verbose eval simple.fb '(0..1000).each { $fb.insert.foo = 42 }'" # features/step_definitions/steps.rb:38
And Exit code is zero # features/step_definitions/steps.rb:72
Then I run bin/judges with "push --token ZRCY-00000000-0000-0000-0000-000000000000 --meta a:b --meta foo:bar --meta=pages_url:https://zerocracy.github.io/zerocracy.html --meta=duration:1055 fakec5aaff2cf7440082 simple.fb # features/step_definitions/steps.rb:38
Then Stdout contains "Pushed" # features/step_definitions/steps.rb:64
And Exit code is zero # features/step_definitions/steps.rb:72
Feature: Misc
I want to get some meta info
Scenario: Help can be printed # features/misc.feature:7
When I run bin/judges with "--help --hello" # features/step_definitions/steps.rb:38
Then Exit code is zero # features/step_definitions/steps.rb:72
And Stdout contains "--help" # features/step_definitions/steps.rb:64
Feature: Test
I want to test a few judges
Scenario: Simple test of no judges at all # features/test.feature:32
Given I make a temp directory # features/step_definitions/steps.rb:27
Given I run bin/judges with "test --judge some ." # features/step_definitions/steps.rb:38
Then Exit code is not zero # features/step_definitions/steps.rb:76
Feature: Update
I want to run a few judges over a factbase
Scenario: The update fails when a bug in a judge # features/update.feature:116
Given I make a temp directory # features/step_definitions/steps.rb:27
Then I have a "mine/broken/broken.rb" file with content: # features/step_definitions/steps.rb:33
"""
a < 1
"""
Then I run bin/judges with "update mine simple.fb" # features/step_definitions/steps.rb:38
Then Stdout contains "Failed to update correctly" # features/step_definitions/steps.rb:64
And Exit code is not zero # features/step_definitions/steps.rb:76
Feature: Version
I want to know the version of the gem
Scenario: Print the version # features/version.feature:7
Given I make a temp directory # features/step_definitions/steps.rb:27
Then I run bin/judges with "version" # features/step_definitions/steps.rb:38
And Exit code is zero # features/step_definitions/steps.rb:72
Feature: Print
I want to print a factbase
Scenario: Print twice, without --force # features/print.feature:51
Given I make a temp directory # features/step_definitions/steps.rb:27
Then I run bin/judges with "--verbose eval simple.fb '$fb.insert.foo = 42'" # features/step_definitions/steps.rb:38
Then I run bin/judges with "print --auto simple.fb" # features/step_definitions/steps.rb:38
Then Stdout contains "printed" # features/step_definitions/steps.rb:64
Then I run bin/judges with "print --auto simple.fb" # features/step_definitions/steps.rb:38
Then Stdout contains "No need to print" # features/step_definitions/steps.rb:64
And Exit code is zero # features/step_definitions/steps.rb:72
Feature: Echo
I want to see the full command line when using --echo flag
Scenario: Echo flag prints command line # features/echo.feature:7
When I run bin/judges with "--echo version" # features/step_definitions/steps.rb:38
Then Exit code is zero # features/step_definitions/steps.rb:72
And Stdout contains "bin/judges --echo version" # features/step_definitions/steps.rb:64
Feature: Test
I want to test a few judges
Scenario: Test with exception # features/test.feature:173
Given I make a temp directory # features/step_definitions/steps.rb:27
Then I have a "mine/foo/foo.rb" file with content: # features/step_definitions/steps.rb:33
"""
raise 'this is a joke'
"""
Then I have a "mine/foo/simple.yml" file with content: # features/step_definitions/steps.rb:33
"""
---
expected_failure:
- a joke
"""
Then I run bin/judges with "test mine" # features/step_definitions/steps.rb:38
And Exit code is zero # features/step_definitions/steps.rb:72
Scenario: Simple test of a few judges # features/test.feature:7
Given I run bin/judges with "test ./fixtures" # features/step_definitions/steps.rb:38
Then Stdout contains "π Testing" # features/step_definitions/steps.rb:64
Then Stdout contains "All 3 judge(s) and 3 tests passed" # features/step_definitions/steps.rb:64
And Exit code is zero # features/step_definitions/steps.rb:72
Feature: Update
I want to run a few judges over a factbase
Scenario: Append to existing summary fact, with errors # features/update.feature:30
Given I make a temp directory # features/step_definitions/steps.rb:27
Then I have a "buggy/buggy.rb" file with content: "this is an intentional bug" # features/update.feature:32
Then I run bin/judges with "update --quiet --summary=append --max-cycles 1 . simple.fb" # features/step_definitions/steps.rb:38
Then Exit code is zero # features/step_definitions/steps.rb:72
Then Stdout contains "Summary fact not found" # features/step_definitions/steps.rb:64
Then I run bin/judges with "update --quiet --summary=append --max-cycles 1 . simple.fb" # features/step_definitions/steps.rb:38
Then I run bin/judges with "inspect simple.fb" # features/step_definitions/steps.rb:38
Then Stdout contains "Summary fact found" # features/step_definitions/steps.rb:64
Then Stdout contains "errors:" # features/step_definitions/steps.rb:64
And Exit code is zero # features/step_definitions/steps.rb:72
Feature: Gem Package
As a source code writer I want to be able to
judgeage the Gem into .gem file
Scenario: Gem can be packaged # features/gem_package.feature:8
Given I make a temp directory # features/step_definitions/steps.rb:27
Then I have a "execs.rb" file with content: # features/step_definitions/steps.rb:33
"""
#!/usr/bin/env ruby
require 'rubygems'
spec = Gem::Specification::load('./spec.rb')
if spec.executables.empty?
fail 'no executables: ' + File.read('./spec.rb')
end
"""
When I run bash with: # features/step_definitions/steps.rb:53
"""
cd judges
gem build judges.gemspec
gem specification --ruby judges-*.gem > ../spec.rb
cd ..
ruby execs.rb
"""
Then Exit code is zero # features/step_definitions/steps.rb:72
Feature: Misc
I want to get some meta info
Scenario: Version can be printed # features/misc.feature:12
When I run bin/judges with "--version" # features/step_definitions/steps.rb:38
Then Exit code is zero # features/step_definitions/steps.rb:72
Feature: Update
I want to run a few judges over a factbase
Scenario: Avoid duplicate insert on error in the middle # features/update.feature:136
Given I make a temp directory # features/step_definitions/steps.rb:27
Then I have a "mine/foo/foo.rb" file with content: # features/step_definitions/steps.rb:33
"""
return unless $fb.query('(eq foo 42)').each.to_a.empty?
f = $fb.insert
f.foo = 42
raise 'intentional'
"""
Then I run bin/judges with "update --quiet --max-cycles=3 mine simple.fb" # features/step_definitions/steps.rb:38
And Exit code is zero # features/step_definitions/steps.rb:72
Then I run bin/judges with "inspect simple.fb" # features/step_definitions/steps.rb:38
Then Stdout contains "Facts: 1" # features/step_definitions/steps.rb:64
Scenario: Combine boost and demote # features/update.feature:197
Given I make a temp directory # features/step_definitions/steps.rb:27
Then I have a "priority/priority.rb" file with content: # features/step_definitions/steps.rb:33
"""
$fb.insert.type = 'priority'
"""
Then I have a "normal/normal.rb" file with content: # features/step_definitions/steps.rb:33
"""
$fb.insert.type = 'normal'
"""
Then I have a "delayed/delayed.rb" file with content: # features/step_definitions/steps.rb:33
"""
$fb.insert.type = 'delayed'
"""
Then I run bin/judges with "--verbose update --quiet --max-cycles 1 --boost priority --demote delayed . combined.fb" # features/step_definitions/steps.rb:38
Then Stdout contains "Running priority" # features/step_definitions/steps.rb:64
Then Stdout contains "Running normal" # features/step_definitions/steps.rb:64
Then Stdout contains "Running delayed" # features/step_definitions/steps.rb:64
Then Stdout contains "3 judge(s) processed" # features/step_definitions/steps.rb:64
And Exit code is zero # features/step_definitions/steps.rb:72
Feature: Test
I want to test a few judges
Scenario: Simple test of no judges at all # features/test.feature:27
Given I make a temp directory # features/step_definitions/steps.rb:27
Given I run bin/judges with "test ." # features/step_definitions/steps.rb:38
Then Exit code is not zero # features/step_definitions/steps.rb:76
Feature: Update
I want to run a few judges over a factbase
Scenario: Summarize results in statistics # features/update.feature:240
Given I make a temp directory # features/step_definitions/steps.rb:27
Then I have a "alpha/alpha.rb" file with content: # features/step_definitions/steps.rb:33
"""
$fb.insert.name = 'alpha'
sleep 1.91
"""
Then I have a "beta/beta.rb" file with content: # features/step_definitions/steps.rb:33
"""
$fb.insert.name = 'beta'
"""
Then I run bin/judges with "update --statistics --quiet --max-cycles 2 --lifetime 4 --timeout 3 --shuffle 'alpha' . stats.fb" # features/step_definitions/steps.rb:38
Then Stdout contains "Judge execution summary:" # features/step_definitions/steps.rb:64
Then Stdout contains "alpha" # features/step_definitions/steps.rb:64
Then Stdout contains "beta" # features/step_definitions/steps.rb:64
Then Stdout contains "1xOK" # features/step_definitions/steps.rb:64
Then Stdout contains "1xSKIPPED (timeout)" # features/step_definitions/steps.rb:64
And Exit code is zero # features/step_definitions/steps.rb:72
Feature: Test
I want to test a few judges
Scenario: Simple test with many runs and many asserts # features/test.feature:77
Given I make a temp directory # features/step_definitions/steps.rb:27
Then I have a "foo/foo.rb" file with content: # features/step_definitions/steps.rb:33
"""
n = $fb.insert
n.foo = $fb.size
"""
Then I have a "foo/good.yml" file with content: # features/step_definitions/steps.rb:33
"""
---
runs: 5
input: []
assert_once: false
expected:
- /fb/f[foo = 1]
"""
Then I run bin/judges with "test ." # features/step_definitions/steps.rb:38
Then Stdout contains "All 1 judge(s) and 1 tests passed" # features/step_definitions/steps.rb:64
And Exit code is zero # features/step_definitions/steps.rb:72
Feature: Print
I want to print a factbase
Scenario: Simple print of a small factbase, to HTML # features/print.feature:14
Given I make a temp directory # features/step_definitions/steps.rb:27
Then I run bin/judges with "--verbose eval simple.fb '$fb.insert.foo = 42'" # features/step_definitions/steps.rb:38
Then I run bin/judges with "print --format=html simple.fb simple.html" # features/step_definitions/steps.rb:38
Then Stdout contains "printed" # features/step_definitions/steps.rb:64
And Exit code is zero # features/step_definitions/steps.rb:72
Feature: Join
I want to join two factbases
Scenario: Simple join of two small factbases # features/join.feature:7
Given I make a temp directory # features/step_definitions/steps.rb:27
Then I run bin/judges with "--verbose eval first.fb '$fb.insert.foo = 42'" # features/step_definitions/steps.rb:38
Then I run bin/judges with "--verbose eval second.fb '$fb.insert.foo = 42'" # features/step_definitions/steps.rb:38
Then I run bin/judges with "update . first.fb" # features/step_definitions/steps.rb:38
Then I run bin/judges with "update . second.fb" # features/step_definitions/steps.rb:38
Then I run bin/judges with "join first.fb second.fb" # features/step_definitions/steps.rb:38
Then Exit code is zero # features/step_definitions/steps.rb:72
And Stdout contains "joined" # features/step_definitions/steps.rb:64
Feature: Test
I want to test a few judges
Scenario: Enable only one category # features/test.feature:97
Given I make a temp directory # features/step_definitions/steps.rb:27
Then I have a "mine/good/good.rb" file with content: # features/step_definitions/steps.rb:33
"""
n = $fb.insert
"""
Then I have a "mine/good/good.yml" file with content: # features/step_definitions/steps.rb:33
"""
---
category: good
input: []
"""
Then I have a "mine/bad/bad.rb" file with content: # features/step_definitions/steps.rb:33
"""
broken$ruby$syntax
"""
Then I have a "mine/bad/bad.yml" file with content: # features/step_definitions/steps.rb:33
"""
---
category: bad
"""
Then I run bin/judges with "test --enable good mine" # features/step_definitions/steps.rb:38
Then Stdout contains "All 2 judge(s) and 1 tests passed" # features/step_definitions/steps.rb:64
And Exit code is zero # features/step_definitions/steps.rb:72
Then I run bin/judges with "test --disable bad mine" # features/step_definitions/steps.rb:38
Then Stdout contains "All 2 judge(s) and 1 tests passed" # features/step_definitions/steps.rb:64
And Exit code is zero # features/step_definitions/steps.rb:72
Then I run bin/judges with "test --enable bad mine" # features/step_definitions/steps.rb:38
Then Stdout contains "Testing mine/bad/bad.yml" # features/step_definitions/steps.rb:64
And Exit code is not zero # features/step_definitions/steps.rb:76
Feature: Update
I want to run a few judges over a factbase
Scenario: Demote multiple judges # features/update.feature:171
Given I make a temp directory # features/step_definitions/steps.rb:27
Then I have a "first/first.rb" file with content: # features/step_definitions/steps.rb:33
"""
$fb.insert.order = 'first'
"""
Then I have a "second/second.rb" file with content: # features/step_definitions/steps.rb:33
"""
$fb.insert.order = 'second'
"""
Then I have a "third/third.rb" file with content: # features/step_definitions/steps.rb:33
"""
$fb.insert.order = 'third'
"""
Then I have a "fourth/fourth.rb" file with content: # features/step_definitions/steps.rb:33
"""
$fb.insert.order = 'fourth'
"""
Then I run bin/judges with "--verbose update --quiet --max-cycles 1 --demote second --demote fourth . multi.fb" # features/step_definitions/steps.rb:38
Then Stdout contains "Running first" # features/step_definitions/steps.rb:64
Then Stdout contains "Running third" # features/step_definitions/steps.rb:64
Then Stdout contains "Running second" # features/step_definitions/steps.rb:64
Then Stdout contains "Running fourth" # features/step_definitions/steps.rb:64
Then Stdout contains "4 judge(s) processed" # features/step_definitions/steps.rb:64
And Exit code is zero # features/step_definitions/steps.rb:72
Scenario: Generate a summary fact, with errors # features/update.feature:21
Given I make a temp directory # features/step_definitions/steps.rb:27
Then I have a "buggy/buggy.rb" file with content: "this is an intentional bug" # features/update.feature:23
Then I run bin/judges with "update --quiet --summary=append --max-cycles 1 . simple.fb" # features/step_definitions/steps.rb:38
Then Exit code is zero # features/step_definitions/steps.rb:72
Then I run bin/judges with "inspect simple.fb" # features/step_definitions/steps.rb:38
Then Stdout contains "Facts: 1" # features/step_definitions/steps.rb:64
And Exit code is zero # features/step_definitions/steps.rb:72
Scenario: Skips the judge on lifetime running out # features/update.feature:52
Given I make a temp directory # features/step_definitions/steps.rb:27
Then I have a "first/first.rb" file with content: # features/step_definitions/steps.rb:33
"""
n = $fb.insert
n.type = 'first'
sleep 1.91
"""
Then I have a "second/second.rb" file with content: # features/step_definitions/steps.rb:33
"""
n = $fb.insert
n.type = 'second'
"""
Then I run bin/judges with "--verbose update --quiet --lifetime 4 --timeout 3 --max-cycles 5 --shuffle 'first' . simple.fb" # features/step_definitions/steps.rb:38
Then Stdout contains "Update completed in 2 cycle(s), did 3i/0d/3a" # features/step_definitions/steps.rb:64
And Exit code is zero # features/step_definitions/steps.rb:72
Scenario: Simple run with a timeout for a judge # features/update.feature:87
Given I make a temp directory # features/step_definitions/steps.rb:27
Then I have a "slow/slow.rb" file with content: # features/step_definitions/steps.rb:33
"""
sleep(10)
$fb.insert.foo = 1
"""
Then I run bin/judges with "--verbose update --timeout 1 --quiet . foo.fb" # features/step_definitions/steps.rb:38
Then Stdout contains "execution expired" # features/step_definitions/steps.rb:64
Then Stdout contains "1 judge(s) processed" # features/step_definitions/steps.rb:64
Then Stdout contains "Update completed in 1 cycle(s), did nothing" # features/step_definitions/steps.rb:64
And Exit code is zero # features/step_definitions/steps.rb:72
Scenario: Use options from a file # features/update.feature:69
Given I make a temp directory # features/step_definitions/steps.rb:27
Then I have a "simple/simple.rb" file with content: # features/step_definitions/steps.rb:33
"""
n.kind.foo = $options.a1
"""
Then I have a "opts.txt" file with content: # features/step_definitions/steps.rb:33
"""
a1 = test
a2 = another test
"""
Then I run bin/judges with "--verbose update --quiet --options-file opts.txt . simple.fb" # features/step_definitions/steps.rb:38
Then Stdout contains "A1 → " # features/step_definitions/steps.rb:64
Then Stdout contains "A2 → " # features/step_definitions/steps.rb:64
Then Stdout contains "1 judge(s) processed" # features/step_definitions/steps.rb:64
Then Stdout contains "Update completed" # features/step_definitions/steps.rb:64
And Exit code is zero # features/step_definitions/steps.rb:72
49 scenarios (4 undefined, 45 passed)
301 steps (22 skipped, 4 undefined, 275 passed)
0m41.431s
Randomized with seed 16028
You can implement step definitions for undefined steps with these snippets:
Then('I run bin\/judges with "--verbose eval simple.fb {string}"') do |string|
pending # Write code here that turns the phrase above into concrete actions
end
Then('I have a {string} file with content: {string}') do |string, string2|
pending # Write code here that turns the phrase above into concrete actions
end
ββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ
β Share your Cucumber Report with your team at https://reports.cucumber.io β
β β
β Command line option: --publish β
β Environment variable: CUCUMBER_PUBLISH_ENABLED=true β
β cucumber.yml: default: --publish β
β β
β More information at https://cucumber.io/docs/cucumber/environment-variables/ β
β β
β To disable this message, specify CUCUMBER_PUBLISH_QUIET=true or use the β
β --publish-quiet option. You can also add this to your cucumber.yml: β
β default: --publish-quiet β
ββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ
+ bundle exec ruby test/commands/test_download.rb /#1403
#1403: Started with run options --seed 53147
#1403:
#1403: TestDownload
#1403: test_fails_with_wrong_number_of_arguments PASS (0.00s)
#1403: test_download_simple_durable PASS (0.05s)
#1403: test_fails_on_http_error PASS (0.01s)
#1403: test_download_with_custom_owner PASS (0.01s)
#1403: test_handles_not_found_durable PASS (0.00s)
#1403:
#1403: Finished in 0.07022s
#1403: 5 tests, 6 assertions, 0 failures, 0 errors, 0 skips
+ bundle exec ruby test/commands/test_eval.rb /#1415
#1415: Started with run options --seed 19066
#1415:
#1415: TestEval
#1415: test_build_factbase_from_scratch PASS (0.00s)
#1415:
#1415: Finished in 0.00471s
#1415: 1 tests, 2 assertions, 0 failures, 0 errors, 0 skips
+ bundle exec ruby test/commands/test_import.rb /#1426
#1426: Started with run options --seed 7991
#1426:
#1426: TestImport
#1426: test_import_from_yaml PASS (0.01s)
#1426:
#1426: Finished in 0.01213s
#1426: 1 tests, 2 assertions, 0 failures, 0 errors, 0 skips
+ bundle exec ruby test/commands/test_inspect.rb /#1437
#1437: Started with run options --seed 52382
#1437:
#1437: TestInspect
#1437: test_simple_inspect_with_summary PASS (0.01s)
#1437: test_simple_inspect PASS (0.00s)
#1437:
#1437: Finished in 0.01749s
#1437: 2 tests, 4 assertions, 0 failures, 0 errors, 0 skips
+ bundle exec ruby test/commands/test_join.rb /#1448
#1448: Started with run options --seed 613
#1448:
#1448: TestJoin
#1448: test_simple_join PASS (0.00s)
#1448:
#1448: Finished in 0.00453s
#1448: 1 tests, 6 assertions, 0 failures, 0 errors, 0 skips
+ bundle exec ruby test/commands/test_print.rb /#1459
#1459: Started with run options --seed 58453
#1459:
#1459: TestPrint
#1459: test_html_table_has_colgroup PASS (0.02s)
#1459: test_simple_print PASS (0.00s)
#1459: test_print_to_html SKIP (0.01s)
#1459: test_print_twice PASS (0.00s)
#1459: test_print_all_formats PASS (0.01s)
#1459:
#1459: Finished in 0.04746s
#1459: 5 tests, 16 assertions, 0 failures, 0 errors, 1 skips
+ bundle exec ruby test/commands/test_pull.rb /#1474
#1474: Started with run options --seed 18499
#1474:
#1474: TestPull
#1474: test_fail_pull_when_job_is_broken PASS (0.04s)
#1474: test_pull_simple_factbase PASS (0.01s)
#1474:
#1474: Finished in 0.04746s
#1474: 2 tests, 3 assertions, 0 failures, 0 errors, 0 skips
+ bundle exec ruby test/commands/test_push.rb /#1486
#1486: Started with run options --seed 636
#1486:
#1486: TestPush
#1486: test_push_simple_factbase PASS (0.06s)
#1486: test_fails_on_http_error PASS (0.01s)
#1486:
#1486: Finished in 0.06644s
#1486: 2 tests, 1 assertions, 0 failures, 0 errors, 0 skips
+ bundle exec ruby test/commands/test_test.rb /#1498
#1498: Started with run options --seed 662
#1498:
#1498: TestTest
#1498: test_positive PASS (0.01s)
#1498: test_with_before PASS (0.00s)
#1498: test_negative PASS (0.00s)
#1498: test_with_expected_failure_no_string PASS (0.00s)
#1498: test_with_options PASS (0.00s)
#1498: test_with_timeout_failure PASS (1.00s)
#1498: test_one_judge_negative PASS (0.00s)
#1498: test_ellipsized_long_script_name PASS (0.00s)
#1498: test_with_after_assertion PASS (0.00s)
#1498: test_with_expected_failure PASS (0.00s)
#1498: test_with_timeout_success PASS (0.00s)
#1498: test_with_timeout_in_after_script PASS (1.00s)
#1498:
#1498: Finished in 2.03918s
#1498: 12 tests, 15 assertions, 0 failures, 0 errors, 0 skips
+ bundle exec ruby test/commands/test_trim.rb /#1510
#1510: Started with run options --seed 37236
#1510:
#1510: TestTrim
#1510: test_trims_factbase PASS (0.02s)
#1510:
#1510: Finished in 0.02408s
#1510: 1 tests, 1 assertions, 0 failures, 0 errors, 0 skips
+ bundle exec ruby test/commands/test_update.rb /#1521
#1521: Started with run options --seed 23019
#1521:
#1521: TestUpdate
#1521: test_update_with_error PASS (0.00s)
#1521: test_extend_existing_factbase PASS (0.00s)
#1521: test_seed_parameter_is_passed_through PASS (0.00s)
#1521: test_update_with_options_in_file PASS (0.00s)
#1521: test_accepts_changes_from_slow_judge PASS (0.10s)
#1521: test_fails_when_no_judges_used PASS (0.00s)
#1521: test_log_pretty_github_exception PASS (0.03s)
#1521: test_terminates_on_lifetime PASS (0.10s)
#1521: test_exports_fb_only_once PASS (0.00s)
#1521: test_appends_to_existing_summary PASS (0.00s)
#1521: test_exports_churn_to_file_despite_error PASS (0.10s)
#1521: test_fail_fast_stops_cycle PASS (0.00s)
#1521: test_build_factbase_from_scratch PASS (0.00s)
#1521: test_cancels_slow_judge PASS (0.10s)
#1521: test_update_with_error_no_quiet PASS (0.00s)
#1521: test_passes_timeout_and_lifetime_through PASS (0.00s)
#1521: test_skipped_judge PASS (0.00s)
#1521: test_cancels_slow_execution PASS (0.14s)
#1521: test_update_with_error_and_summary PASS (0.00s)
#1521: test_exports_all_judges_despite_lifetime_timeout PASS (2.00s)
#1521: test_exports_fb_despite_judge_syntax_error PASS (0.00s)
#1521: test_isolates_churns PASS (0.00s)
#1521: test_no_failure_with_nonexistent_judge_when_expect_judges_false PASS (0.00s)
#1521: test_no_failure_when_expect_judges_false PASS (0.00s)
#1521: test_with_only_one_judge PASS (0.00s)
#1521: test_fails_when_empty_directory PASS (0.00s)
#1521: test_churn_file_creation PASS (0.00s)
#1521: test_reports_changes_from_slow_judge PASS (0.10s)
#1521:
#1521: Finished in 2.74156s
#1521: 28 tests, 65 assertions, 0 failures, 0 errors, 0 skips
+ bundle exec ruby test/commands/test_upload.rb /#1533
#1533: Started with run options --seed 16133
#1533:
#1533: TestUpload
#1533: test_fails_when_file_does_not_exist PASS (0.00s)
#1533: test_fails_with_wrong_number_of_arguments PASS (0.00s)
#1533: test_upload_with_custom_owner PASS (0.05s)
#1533: test_fails_on_http_error PASS (0.01s)
#1533: test_upload_simple_durable PASS (0.01s)
#1533:
#1533: Finished in 0.07329s
#1533: 5 tests, 4 assertions, 0 failures, 0 errors, 0 skips
+ bundle exec ruby test/test__helper.rb /#1545
#1545: Started with run options --seed 20708
#1545:
#1545: Finished in 0.00059s
#1545: 0 tests, 0 assertions, 0 failures, 0 errors, 0 skips
+ bundle exec ruby test/test_ascii_loog.rb /#1556
#1556: Started with run options --seed 43683
#1556:
#1556: TestAsciiLoog
#1556: test_handles_mixed_encodings PASS (0.00s)
#1556: test_converts_all_defined_symbols PASS (0.00s)
#1556: test_mixed_unicode_and_ascii PASS (0.00s)
#1556: test_multiple_same_symbols PASS (0.00s)
#1556: test_handles_binary_encoding PASS (0.00s)
#1556: test_delegates_unknown_methods PASS (0.00s)
#1556: test_handles_empty_and_nil_messages PASS (0.00s)
#1556: test_responds_to_original_logger_methods PASS (0.00s)
#1556: test_converts_unicode_symbols PASS (0.00s)
#1556: test_leaves_non_unicode_text_unchanged PASS (0.00s)
#1556:
#1556: Finished in 0.00448s
#1556: 10 tests, 44 assertions, 0 failures, 0 errors, 0 skips
+ bundle exec ruby test/test_bin.rb /#1567
#1567: Started with run options --seed 53529
#1567:
#1567: TestBin
#1567: test_simple_run PASS (0.05s)
#1567:
#1567: Finished in 0.05123s
#1567: 1 tests, 2 assertions, 0 failures, 0 errors, 0 skips
+ bundle exec ruby test/test_categories.rb /#1578
#1578: Started with run options --seed 23486
#1578:
#1578: TestCategories
#1578: test_basic PASS (0.00s)
#1578: test_all_enabled PASS (0.00s)
#1578:
#1578: Finished in 0.00209s
#1578: 2 tests, 11 assertions, 0 failures, 0 errors, 0 skips
+ bundle exec ruby test/test_impex.rb /#1589
#1589: Started with run options --seed 38058
#1589:
#1589: TestImpex
#1589: test_strict_import PASS (0.00s)
#1589: test_basic PASS (0.00s)
#1589:
#1589: Finished in 0.00219s
#1589: 2 tests, 0 assertions, 0 failures, 0 errors, 0 skips
+ bundle exec ruby test/test_judge.rb /#1600
#1600: Started with run options --seed 4733
#1600:
#1600: TestJudge
#1600: test_with_standard_error PASS (0.00s)
#1600: test_passes_local_vars_between_tests PASS (0.00s)
#1600: test_sets_start_value_correctly PASS (0.00s)
#1600: test_sets_judge_value_correctly PASS (0.00s)
#1600: test_run_isolated PASS (0.00s)
#1600: test_with_runtime_ruby_error PASS (0.00s)
#1600: test_basic_run PASS (0.00s)
#1600: test_with_broken_ruby_syntax PASS (0.00s)
#1600:
#1600: Finished in 0.00771s
#1600: 8 tests, 11 assertions, 0 failures, 0 errors, 0 skips
+ bundle exec ruby test/test_judges.rb /#1611
#1611: Started with run options --seed 4951
#1611:
#1611: TestJudges
#1611: test_boost_and_demote_together PASS (0.00s)
#1611: test_shuffles_and_boosts PASS (0.00s)
#1611: test_get_one PASS (0.00s)
#1611: test_basic PASS (0.00s)
#1611: test_demote_with_wildcard_patterns PASS (0.00s)
#1611: test_list_only_direct_subdirs PASS (0.00s)
#1611: test_default_seed PASS (0.00s)
#1611: test_boost_with_wildcard_patterns PASS (0.00s)
#1611: test_same_seed_produces_same_order PASS (0.00s)
#1611: test_shuffles_them PASS (0.00s)
#1611: test_list_with_empty_dir PASS (0.00s)
#1611: test_keeps_them_all PASS (0.00s)
#1611: test_demotes_judges PASS (0.00s)
#1611: test_different_seed_produces_different_order PASS (0.00s)
#1611: test_boost_and_demote_with_wildcards_together PASS (0.00s)
#1611:
#1611: Finished in 0.02827s
#1611: 15 tests, 131 assertions, 0 failures, 0 errors, 0 skips
+ bundle exec ruby test/test_options.rb /#1622
#1622: Started with run options --seed 19181
#1622:
#1622: TestOptions
#1622: test_with_empty_string PASS (0.00s)
#1622: test_with_hash PASS (0.00s)
#1622: test_with_nil PASS (0.00s)
#1622: test_stips_spaces PASS (0.00s)
#1622: test_case_insensitive PASS (0.00s)
#1622: test_with_empty_strings PASS (0.00s)
#1622: test_with_string PASS (0.00s)
#1622: test_merge_by_symbols PASS (0.00s)
#1622: test_merge PASS (0.00s)
#1622: test_basic PASS (0.00s)
#1622: test_converts_to_string PASS (0.00s)
#1622: test_with_nil_values PASS (0.00s)
#1622:
#1622: Finished in 0.00275s
#1622: 12 tests, 28 assertions, 0 failures, 0 errors, 0 skips
+ bundle exec ruby test/test_pretty_exception.rb /#1633
#1633: Started with run options --seed 8660
#1633:
#1633: TestPrettyException
#1633: test_hide_class PASS (0.00s)
#1633: test_short_message PASS (0.00s)
#1633: test_long_message PASS (0.00s)
#1633:
#1633: Finished in 0.00091s
#1633: 3 tests, 6 assertions, 0 failures, 0 errors, 0 skips
+ bundle exec ruby test/test_statistics.rb /#1644
#1644: Started with run options --seed 50174
#1644:
#1644: TestStatistics
#1644: test_record_multiple_judges PASS (0.00s)
#1644: test_skipped_results PASS (0.00s)
#1644: test_result_summarization_mixed_results PASS (0.00s)
#1644: test_empty_statistics PASS (0.00s)
#1644: test_record_without_churn PASS (0.00s)
#1644: test_record_multiple_cycles_same_judge PASS (0.00s)
#1644: test_record_with_churn PASS (0.00s)
#1644: test_record_basic_statistics PASS (0.00s)
#1644: test_empty_report PASS (0.00s)
#1644: test_fractional_seconds_formatting PASS (0.00s)
#1644: test_result_summarization_single_result PASS (0.00s)
#1644: test_not_empty_after_recording PASS (0.00s)
#1644: test_report_format_headers PASS (0.00s)
#1644: test_judges_sorted_by_total_time PASS (0.00s)
#1644: test_very_long_judge_names PASS (0.00s)
#1644:
#1644: Finished in 0.00196s
#1644: 15 tests, 61 assertions, 0 failures, 0 errors, 0 skips
+ bundle exec ruby test/test_to_rel.rb /#1655
#1655: Started with run options --seed 54185
#1655:
#1655: TestToRel
#1655: test_maps_dir_name PASS (0.00s)
#1655: test_simple_mapping PASS (0.00s)
#1655:
#1655: Finished in 0.00094s
#1655: 2 tests, 2 assertions, 0 failures, 0 errors, 0 skips
+ bundle exec ruby lib/judges/ascii_loog.rb /#1666
+ bundle exec ruby lib/judges/categories.rb /#1677
+ bundle exec ruby lib/judges/commands/download.rb /#1688
+ bundle exec ruby lib/judges/commands/eval.rb /#1699
+ bundle exec ruby lib/judges/commands/import.rb /#1710
+ bundle exec ruby lib/judges/commands/inspect.rb /#1721
+ bundle exec ruby lib/judges/commands/join.rb /#1732
+ bundle exec ruby lib/judges/commands/print.rb /#1743
+ bundle exec ruby lib/judges/commands/pull.rb /#1754
+ bundle exec ruby lib/judges/commands/push.rb /#1765
+ bundle exec ruby lib/judges/commands/test.rb /#1776
+ bundle exec ruby lib/judges/commands/trim.rb /#1787
+ bundle exec ruby lib/judges/commands/update.rb /#1798
+ bundle exec ruby lib/judges/commands/upload.rb /#1809
+ bundle exec ruby lib/judges/impex.rb /#1820
+ bundle exec ruby lib/judges/judge.rb /#1831
+ bundle exec ruby lib/judges/judges.rb /#1842
+ bundle exec ruby lib/judges/options.rb /#1853
+ bundle exec ruby lib/judges/pretty_exception.rb /#1864
+ bundle exec ruby lib/judges/statistics.rb /#1875
+ bundle exec ruby lib/judges/to_rel.rb /#1886
+ bundle exec ruby lib/judges.rb /#1897
Running RuboCop...
Inspecting 53 files
32m.0m32m.0m32m.0m32m.0m32m.0m32m.0m32m.0m32m.0m32m.0m32m.0m32m.0m32m.0m32m.0m32m.0m32m.0m32m.0m32m.0m32m.0m32m.0m32m.0m32m.0m32m.0m32m.0m32m.0m32m.0m32m.0m32m.0m32m.0m32m.0m32m.0m32m.0m32m.0m32m.0m32m.0m32m.0m32m.0m32m.0m32m.0m32m.0m32m.0m32m.0m32m.0m32m.0m32m.0m32m.0m32m.0m32m.0m32m.0m32m.0m32m.0m32m.0m32m.0m32m.0m
53 files inspected, 32mno offenses0m detected
?25h2KFiles:1mβ£½aGenera22ngudoc/Judges/Download.html0m.html0m
Modules: 1 ( 0 undocumented)
Classes: 21 ( 0 undocumented)
Constants: 2 ( 1 undocumented)
Attributes: 1 ( 0 undocumented)
Methods: 61 ( 1 undocumented)
97.67% documented
+ mv /home/r/repo .
++ whoami
+ chown -R root repo
+ '[' -n '' ']'
++ whoami
+ sudo chown -R ubuntu repo
+ cd repo
+ git push origin master
remote:
remote: GitHub found 5 vulnerabilities on yegor256/judges's default branch (4 high, 1 moderate). To find out more, visit:
remote: https://github.com/yegor256/judges/security/dependabot
remote:
To github.com:yegor256/judges.git
9cc7468..0346ba9 master -> master
container 9e45dda17e990d357ee50f59dddb3e4cced1bee3dc7d7cc58a97ec55ec66bb0d is dead
Mon Mar 30 04:41:35 UTC 2026