rultor.com logo This build log was produced by rultor.com for zold-io/zold#804
+ set -e
+ set -o pipefail
++ dirname ./run.sh
+ cd .
+ echo 2524123
+ echo '2.0-SNAPSHOT BUILD'
2.0-SNAPSHOT BUILD
+ date
Mon 05 Dec 2022 06:11:49 PM CET
+ uptime
 18:11:49 up 11 days, 23:49,  0 users,  load average: 6.01, 6.06, 6.22
+ head=git@github.com:zold-io/zold.git
+ ff=default
+ image=yegor256/rultor-image:1.9.1
+ rebase=false
+ squash=false
+ head_branch=master
+ author=davvd
+ tag=0.31.3
+ vars=('--env=head=git@github.com:zold-io/zold.git' '--env=tag=0.31.3' '--env=scripts=( '\''export '\''\'\'''\''head=git@github.com:zold-io/zold.git'\''\'\'''\'''\'' '\'';'\'' '\''export '\''\'\'''\''tag=0.31.3'\''\'\'''\'''\'' '\'';'\'' '\''export '\''\'\'''\''head_branch=master'\''\'\'''\'''\'' '\'';'\'' '\''export '\''\'\'''\''author=davvd'\''\'\'''\'''\'' '\'';'\'' '\''sudo apt-get -y update'\'' '\'';'\'' '\''sudo apt-get -y install libcurl4-openssl-dev'\'' '\'';'\'' '\''sudo bundle install --no-color "--gemfile=$(pwd)/Gemfile"'\'' '\'';'\'' '\''sudo rm -rf "$(pwd)/Gemfile.lock"'\'' '\'';'\'' '\''[[ "${tag}" =~ ^[0-9]+\.[0-9]+\.[0-9]+$ ]] || exit -1'\'' '\'';'\'' '\''export RUBYOPT="-W0"'\'' '\'';'\'' '\''sed -i "s/0\.0\.0/${tag}/g" lib/zold/version.rb'\'' '\'';'\'' '\''bundle exec rake --quiet'\'' '\'';'\'' '\''git add lib/zold/version.rb'\'' '\'';'\'' '\''git commit -m "version set to ${tag}"'\'' '\'';'\'' '\''gem build zold.gemspec'\'' '\'';'\'' '\''chmod 0600 ../rubygems.yml'\'' '\'';'\'' '\''gem push *.gem --config-file ../rubygems.yml'\'' '\'';'\'' )' '--env=head_branch=master' '--env=author=davvd')
+ scripts=('export '\''head=git@github.com:zold-io/zold.git'\''' ';' 'export '\''tag=0.31.3'\''' ';' 'export '\''head_branch=master'\''' ';' 'export '\''author=davvd'\''' ';' 'sudo apt-get -y update' ';' 'sudo apt-get -y install libcurl4-openssl-dev' ';' 'sudo bundle install --no-color "--gemfile=$(pwd)/Gemfile"' ';' 'sudo rm -rf "$(pwd)/Gemfile.lock"' ';' '[[ "${tag}" =~ ^[0-9]+\.[0-9]+\.[0-9]+$ ]] || exit -1' ';' 'export RUBYOPT="-W0"' ';' 'sed -i "s/0\.0\.0/${tag}/g" lib/zold/version.rb' ';' 'bundle exec rake --quiet' ';' 'git add lib/zold/version.rb' ';' 'git commit -m "version set to ${tag}"' ';' 'gem build zold.gemspec' ';' 'chmod 0600 ../rubygems.yml' ';' 'gem push *.gem --config-file ../rubygems.yml' ';')
+ directory=
+ container=zold-io_zold_804
+ as_root=false
+ hostname
m2262.contaboserver.net
+ git --version
git version 2.25.1
+ docker --version
Docker version 20.10.21, build baeda1f
+ mkdir -p /home/rultor/.ssh
+ echo -e 'Host github.com\n\tStrictHostKeyChecking no\n'
+ chmod 600 /home/rultor/.ssh/config
+ git clone git@github.com:zold-io/zold.git repo
Cloning into 'repo'...
+ cd repo
+ git config user.email me@rultor.com
+ git config user.name rultor
+ '[' -z 'export '\''head=git@github.com:zold-io/zold.git'\''' ']'
+ cd ..
+ cat
+ '[' false = true ']'
+ cat
+ chmod a+x entry.sh
+ cat
+ echo 'export '\''head=git@github.com:zold-io/zold.git'\''' ';' 'export '\''tag=0.31.3'\''' ';' 'export '\''head_branch=master'\''' ';' 'export '\''author=davvd'\''' ';' 'sudo apt-get -y update' ';' 'sudo apt-get -y install libcurl4-openssl-dev' ';' 'sudo bundle install --no-color "--gemfile=$(pwd)/Gemfile"' ';' 'sudo rm -rf "$(pwd)/Gemfile.lock"' ';' '[[ "${tag}" =~ ^[0-9]+\.[0-9]+\.[0-9]+$ ]] || exit -1' ';' 'export RUBYOPT="-W0"' ';' 'sed -i "s/0\.0\.0/${tag}/g" lib/zold/version.rb' ';' 'bundle exec rake --quiet' ';' 'git add lib/zold/version.rb' ';' 'git commit -m "version set to ${tag}"' ';' 'gem build zold.gemspec' ';' 'chmod 0600 ../rubygems.yml' ';' 'gem push *.gem --config-file ../rubygems.yml' ';'
+ sensitive=()
+ rm -rf .gnupg
+ '[' -z 0.31.3 ']'
+ [[ 0.31.3 =~ ^[a-zA-Z0-9\.\-]+$ ]]
+ echo 'tag name is valid: "0.31.3"'
tag name is valid: "0.31.3"
+ cd repo
++ git tag -l 0.31.3
+ '[' ']'
+ export BRANCH_NAME=__rultor
+ BRANCH_NAME=__rultor
++ git show-branch __rultor
++ wc -l
+ '[' 0 -gt 0 ']'
+ git checkout -b __rultor
Switched to a new branch '__rultor'
+ docker_when_possible
+ true
++ uptime
++ sed 's/ /\n/g'
++ tail -n 1
+ load=6.22
++ echo 6.22 '>' 30
++ bc
+ '[' 0 -eq 1 ']'
+ echo 'load average is 6.22, low enough to run a new Docker container'
load average is 6.22, low enough to run a new Docker container
+ break
+ cd ..
+ '[' -n '' ']'
+ use_image=yegor256/rultor-image:1.9.1
+ docker pull yegor256/rultor-image:1.9.1
1.9.1: Pulling from yegor256/rultor-image
Digest: sha256:61885a12aa213b79fd79e2b4ade12645535717267474cb0d1067a3323514589e
Status: Image is up to date for yegor256/rultor-image:1.9.1
docker.io/yegor256/rultor-image:1.9.1
+ docker ps --filter=status=exited
+ grep --quiet '\szold-io_zold_804\s*$'
+ ls -al .
total 48
drwx------  3 rultor rultor 4096 Dec  5 18:11 .
drwxrwxrwt 11 root   root   4096 Dec  5 18:11 ..
-rwxrwxr-x  1 rultor rultor  556 Dec  5 18:11 end.sh
-rwxrwxr-x  1 rultor rultor  363 Dec  5 18:11 entry.sh
-rw-rw-r--  1 rultor rultor    8 Dec  5 18:11 pid
drwxrwxr-x 12 rultor rultor 4096 Dec  5 18:11 repo
-rw-rw-r--  1 rultor rultor   56 Dec  5 18:11 rubygems.yml
-rwxrwxr-x  1 rultor rultor 6240 Dec  5 18:11 run.sh
-rw-rw-r--  1 rultor rultor  801 Dec  5 18:11 script.sh
-rw-rw-r--  1 rultor rultor 4615 Dec  5 18:11 stdout
++ pwd
++ pwd
+ docker run -t --rm -v /tmp/rultor-pUXu:/main --env=head=git@github.com:zold-io/zold.git --env=tag=0.31.3 '--env=scripts=( '\''export '\''\'\'''\''head=git@github.com:zold-io/zold.git'\''\'\'''\'''\'' '\'';'\'' '\''export '\''\'\'''\''tag=0.31.3'\''\'\'''\'''\'' '\'';'\'' '\''export '\''\'\'''\''head_branch=master'\''\'\'''\'''\'' '\'';'\'' '\''export '\''\'\'''\''author=davvd'\''\'\'''\'''\'' '\'';'\'' '\''sudo apt-get -y update'\'' '\'';'\'' '\''sudo apt-get -y install libcurl4-openssl-dev'\'' '\'';'\'' '\''sudo bundle install --no-color "--gemfile=$(pwd)/Gemfile"'\'' '\'';'\'' '\''sudo rm -rf "$(pwd)/Gemfile.lock"'\'' '\'';'\'' '\''[[ "${tag}" =~ ^[0-9]+\.[0-9]+\.[0-9]+$ ]] || exit -1'\'' '\'';'\'' '\''export RUBYOPT="-W0"'\'' '\'';'\'' '\''sed -i "s/0\.0\.0/${tag}/g" lib/zold/version.rb'\'' '\'';'\'' '\''bundle exec rake --quiet'\'' '\'';'\'' '\''git add lib/zold/version.rb'\'' '\'';'\'' '\''git commit -m "version set to ${tag}"'\'' '\'';'\'' '\''gem build zold.gemspec'\'' '\'';'\'' '\''chmod 0600 ../rubygems.yml'\'' '\'';'\'' '\''gem push *.gem --config-file ../rubygems.yml'\'' '\'';'\'' )' --env=head_branch=master --env=author=davvd --hostname=docker --privileged --memory=8g --memory-swap=16g --oom-kill-disable --cidfile=/tmp/rultor-pUXu/cid -w=/main -v /var/run/docker.sock:/var/run/docker.sock --name=zold-io_zold_804 yegor256/rultor-image:1.9.1 /main/entry.sh
WARNING: Your kernel does not support swap limit capabilities or the cgroup is not mounted. Memory limited without swap.
+ set -e
+ set -o pipefail
+ shopt -s dotglob
+ useradd -m -G sudo r
+ usermod -s /bin/bash r
+ echo '%sudo ALL=(ALL) NOPASSWD:ALL'
+ cp -R /root/.bashrc /root/.cache /root/.config /root/.gem /root/.gnupg /root/.m2 /root/.npm /root/.profile /root/texmf /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
+ su --login r --command /home/r/script.sh
+ set -e
+ set -o pipefail
+ '[' -e /home/r/.profile ']'
+ source /home/r/.profile
++ '[' /bin/bash ']'
++ '[' -f /home/r/.bashrc ']'
++ . /home/r/.bashrc
+++ '[' -z '' ']'
+++ return
++ mesg n
++ true
+ shopt -s expand_aliases
+ alias 'sudo=sudo -i'
+ export HOME=/home/r
+ HOME=/home/r
+ cd /home/r/repo
+ export head=git@github.com:zold-io/zold.git
+ head=git@github.com:zold-io/zold.git
+ export tag=0.31.3
+ tag=0.31.3
+ export head_branch=master
+ head_branch=master
+ export author=davvd
+ author=davvd
+ sudo -i apt-get -y update
Hit:1ohttps://deb.nodesource.com/node_17.x focal InRelease
Get:2ohttp://ppa.launchpad.net/deadsnakes/ppa/ubuntu focaleInReleases[18.1tkB]b
Get:3ohttp://ppa.launchpad.net/git-core/ppa/ubuntu)focalnInReleaseo[23.8rkB].ub
Get:4ahttp://ppa.launchpad.net/ondrej/php/ubuntu3focallInRelease2[23.9.kB]B 59%
Hit:5ahttp://archive.ubuntu.com/ubuntuhfocalsInReleaselease 1,124 B/23.9 kB 5%]
Get:6ahttp://security.ubuntu.com/ubuntu focal-security InRelease [114 kB]
Get:7ahttp://ppa.launchpad.net/deadsnakes/ppa/ubuntu focal/main amd64 Packages [29.5 kB]
Get:8ahttp://archive.ubuntu.com/ubuntu1focal-updatesnInRelease4[114BkB]42kB 12%
Get:9 http://ppa.launchpad.net/git-core/ppa/ubuntu2focal/mainkamd64]Packages [4,571 B]
Get:10Ihttp://ppa.launchpad.net/ondrej/php/ubuntu6focal/main6amd64%Packages2[177 kB]
Get:11ihttp://archive.ubuntu.com/ubuntuIfocal-backports7InRelease%[1081kB]ackag
Get:12ihttp://security.ubuntu.com/ubuntutfocal-security/multiverse amd64 Packages [27.7 kB]
Get:13ihttp://archive.ubuntu.com/ubuntuefocal-updates/restrictedaamd64 Packages [1,887 kB]
Get:14 http://security.ubuntu.com/ubuntuifocal-security/main amd64 Packages [2,350 kB]
Get:153http://security.ubuntu.com/ubuntu[focal-security/restricted0amd643Packages [1,772 kB]
Get:164http://security.ubuntu.com/ubuntu focal-security/universe7amd64aPackages [972 kB]
Get:174http://archive.ubuntu.com/ubuntusfocal-updates/universe%amd64 Packages [1,273 kB]
Get:185http://archive.ubuntu.com/ubuntusfocal-updates/multiverse6amd64aPackages [30.4 kB]
Get:195http://archive.ubuntu.com/ubuntusfocal-updates/main]amd646Packagess[2,820 kB]
Get:206http://archive.ubuntu.com/ubuntusfocal-backports/universe6amd64aPackages [28.6 kB]
Get:216http://archive.ubuntu.com/ubuntusfocal-backports/main%amd64 Packages [55.2 kB]
Fetchedo11.8gMBeins2sr(5,071[kB/s)ckages 26.2 kB/55.2 kB 47%]
Reading package lists... Done
+ sudo -i apt-get -y install libcurl4-openssl-dev
Reading package lists... Done
Building dependency tree... 50%
Reading state information... Done
The following additional packages will be installed:
  curl libcurl4
Suggested packages:
  libcurl4-doc libidn11-dev libkrb5-dev libldap2-dev librtmp-dev libssh2-1-dev
The following NEW packages will be installed:
  libcurl4-openssl-dev
The following packages will be upgraded:
  curl libcurl4
2 upgraded, 1 newly installed, 0 to remove and 182 not upgraded.
Need to get 718 kB of archives.
After this operation, 1,546 kB of additional disk space will be used.
Get:1ohttp://archive.ubuntu.com/ubuntu focal-updates/main amd64 curl amd64 7.68.0-1ubuntu2.14 [161 kB]
Get:2Whttp://archive.ubuntu.com/ubuntu focal-updates/main amd64 libcurl4 amd64 7.68.0-1ubuntu2.14 [235 kB]
Get:3Whttp://archive.ubuntu.com/ubuntu focal-updates/main amd64 libcurl4-openssl-dev amd64 7.68.0-1ubuntu2.14 [322 kB]
Fetchedo718nkB4inp1ss(829ekB/s) B/322 kB 0%]
debconf: delaying package configuration, since apt-utils is not installed
(Reading database ... 88783 files and directories currently installed.)
Preparing to unpack .../curl_7.68.0-1ubuntu2.14_amd64.deb ...
Unpacking curl (7.68.0-1ubuntu2.14) over (7.68.0-1ubuntu2.11) ...
Preparing to unpack .../libcurl4_7.68.0-1ubuntu2.14_amd64.deb ...
Unpacking libcurl4:amd64 (7.68.0-1ubuntu2.14) over (7.68.0-1ubuntu2.11) ...
Selecting previously unselected package libcurl4-openssl-dev:amd64.
Preparing to unpack .../libcurl4-openssl-dev_7.68.0-1ubuntu2.14_amd64.deb ...
Unpacking libcurl4-openssl-dev:amd64 (7.68.0-1ubuntu2.14) ...
Setting up libcurl4:amd64 (7.68.0-1ubuntu2.14) ...
Setting up curl (7.68.0-1ubuntu2.14) ...
Setting up libcurl4-openssl-dev:amd64 (7.68.0-1ubuntu2.14) ...
Processing triggers for man-db (2.9.1-1) ...
Processing triggers for libc-bin (2.31-0ubuntu9.9) ...
++ pwd
+ sudo -i bundle install --no-color --gemfile=/home/r/repo/Gemfile
Don't run Bundler as root. Bundler can ask for sudo if it is needed, and
installing your bundle as root will break this application for all non-root
users on this machine.
fatal: unsafe repository ('/home/r/repo' is owned by someone else)
To add an exception for this directory, call:

        git config --global --add safe.directory /home/r/repo
Fetching gem metadata from https://rubygems.org/..........
Resolving dependencies.......
Fetching rake 12.3.2
Installing rake 12.3.2
Fetching concurrent-ruby 1.1.10
Fetching minitest 5.11.3
Fetching erubi 1.11.0
Fetching ansi 1.5.0
Fetching crass 1.0.6
Fetching ast 2.4.2
Fetching backtrace 0.3.0
Fetching racc 1.6.1
Fetching public_suffix 5.0.0
Fetching backports 3.23.0
Fetching builder 3.2.4
Fetching rack 2.2.4
Installing ansi 1.5.0
Installing ast 2.4.2
Installing backtrace 0.3.0
Installing builder 3.2.4
Installing crass 1.0.6
Installing public_suffix 5.0.0
Installing erubi 1.11.0
Installing racc 1.6.1 with native extensions
Installing backports 3.23.0
Installing rack 2.2.4
Installing concurrent-ruby 1.1.10
Installing minitest 5.11.3
Using bundler 2.3.16
Fetching docile 1.4.0
Fetching simplecov-html 0.12.3
Fetching simplecov_json_formatter 0.1.4
Fetching coderay 1.1.3
Fetching rexml 3.2.5
Fetching cucumber-tag_expressions 1.1.1
Installing docile 1.4.0
Installing simplecov_json_formatter 0.1.4
Fetching gherkin 5.1.0
Installing rexml 3.2.5
Fetching cucumber-expressions 6.0.1
Installing cucumber-tag_expressions 1.1.1
Installing simplecov-html 0.12.3
Installing coderay 1.1.3
Fetching cucumber-wire 0.0.1
Fetching diff-lcs 1.5.0
Fetching multi_json 1.15.0
Installing cucumber-expressions 6.0.1
Fetching multi_test 1.1.0
Installing gherkin 5.1.0
Fetching daemons 1.4.1
Installing multi_json 1.15.0
Installing cucumber-wire 0.0.1
Installing daemons 1.4.1
Installing diff-lcs 1.5.0
Installing multi_test 1.1.0
Using differ 0.1.2
Fetching diffy 3.4.2
Fetching ffi 1.15.5
Fetching eventmachine 1.2.7
Fetching formatador 1.1.0
Fetching futex 0.8.6
Fetching rb-fsevent 0.11.2
Fetching lumberjack 1.2.8
Installing formatador 1.1.0
Installing lumberjack 1.2.8
Installing rb-fsevent 0.11.2
Installing diffy 3.4.2
Fetching nenv 0.3.0
Fetching shellany 0.0.1
Installing eventmachine 1.2.7 with native extensions
Installing futex 0.8.6
Installing nenv 0.3.0
Installing ffi 1.15.5 with native extensions
Fetching method_source 1.0.0
Fetching thor 1.2.1
Installing method_source 1.0.0
Fetching guard-compat 1.2.1
Fetching temple 0.9.1
Fetching tilt 2.0.11
Fetching hashdiff 1.0.1
Installing shellany 0.0.1
Installing guard-compat 1.2.1
Installing thor 1.2.1
Fetching ipaddr 1.2.5
Fetching jaro_winkler 1.5.4
Fetching json 2.6.3
Installing temple 0.9.1
Installing hashdiff 1.0.1
Installing tilt 2.0.11
Fetching memory_profiler 0.9.14
Installing ipaddr 1.2.5
Installing json 2.6.3 with native extensions
Fetching plist 3.1.0
Fetching ruby2_keywords 0.0.5
Installing memory_profiler 0.9.14
Installing jaro_winkler 1.5.4 with native extensions
Fetching ruby-progressbar 1.11.0
Fetching parallel 1.22.1
Fetching zeitwerk 2.6.6
Installing plist 3.1.0
Installing ruby2_keywords 0.0.5
Using rainbow 3.1.1
Fetching random-port 0.3.1
Installing parallel 1.22.1
Installing ruby-progressbar 1.11.0
Fetching rdoc 6.1.1
Installing random-port 0.3.1
Fetching rspec-support 3.8.3
Installing zeitwerk 2.6.6
Fetching unicode-display_width 1.6.1
Fetching semantic 1.6.1
Installing unicode-display_width 1.6.1
Installing rspec-support 3.8.3
Installing rdoc 6.1.1
Installing semantic 1.6.1
Fetching slop 4.9.3
Fetching total 0.3.0
Fetching usagewatch 0.0.7
Fetching zache 0.12.0
Fetching zold-score 0.4.6
Fetching parser 3.1.3.0
Installing usagewatch 0.0.7
Installing zold-score 0.4.6 with native extensions
Installing slop 4.9.3
Installing zache 0.12.0
Installing total 0.3.0
Fetching minitest-fail-fast 0.1.0
Fetching minitest-hooks 1.5.0
Installing parser 3.1.3.0
Fetching addressable 2.8.1
Fetching rack-test 2.0.2
Fetching rack-protection 2.2.3
Installing minitest-fail-fast 0.1.0
Installing minitest-hooks 1.5.0
Installing addressable 2.8.1
Installing rack-protection 2.2.3
Installing rack-test 2.0.2
Fetching i18n 1.12.0
Fetching tzinfo 2.0.5
Installing i18n 1.12.0
Fetching threads 0.3.0
Fetching simplecov 0.21.2
Installing threads 0.3.0
Installing tzinfo 2.0.5
Fetching crack 0.4.5
Installing simplecov 0.21.2
Fetching cucumber-core 3.2.1
Fetching nokogiri 1.13.9 (x86_64-linux)
Fetching notiffany 0.1.3
Installing crack 0.4.5
Installing notiffany 0.1.3
Fetching guard-minitest 2.4.6
Installing cucumber-core 3.2.1
Fetching openssl 2.2.2
Fetching pry 0.14.1
Fetching mustermann 2.0.2
Installing guard-minitest 2.4.6
Fetching haml 5.2.2
Installing openssl 2.2.2 with native extensions
Fetching minitest-reporters 1.3.6
Fetching rspec-core 3.8.2
Installing mustermann 2.0.2
Installing pry 0.14.1
Installing haml 5.2.2
Installing rspec-core 3.8.2
Installing minitest-reporters 1.3.6
Fetching rspec-expectations 3.8.6
Fetching rspec-mocks 3.8.2
Installing rspec-expectations 3.8.6
Installing rspec-mocks 3.8.2
Fetching usagewatch_ext 0.2.1
Fetching activesupport 7.0.4
Installing usagewatch_ext 0.2.1
Fetching codecov 0.6.0
Fetching webmock 3.5.1
Fetching cucumber 3.1.2
Installing activesupport 7.0.4
Installing nokogiri 1.13.9 (x86_64-linux)
Installing codecov 0.6.0
Installing webmock 3.5.1
Installing cucumber 3.1.2
Fetching sinatra 2.2.3
Installing sinatra 2.2.3
Using xcop 0.7.1
Fetching rails-dom-testing 2.0.3
Fetching loofah 2.19.0
Installing rails-dom-testing 2.0.3
Installing loofah 2.19.0
Fetching rails-html-sanitizer 1.4.3
Installing rails-html-sanitizer 1.4.3
Fetching actionview 7.0.4
Installing actionview 7.0.4
Fetching actionpack 7.0.4
Installing actionpack 7.0.4
Fetching railties 7.0.4
Installing railties 7.0.4
Fetching rspec-rails 3.8.2
Installing rspec-rails 3.8.2
Fetching rubocop 0.69.0
Installing rubocop 0.69.0
Fetching rubocop-rspec 1.33.0
Installing rubocop-rspec 1.33.0
Fetching get_process_mem 0.2.7
Fetching sys-proctable 1.2.7
Fetching rb-inotify 0.10.1
Fetching ethon 0.16.0
Installing get_process_mem 0.2.7
Installing ethon 0.16.0
Installing rb-inotify 0.10.1
Installing sys-proctable 1.2.7
Fetching listen 3.7.1
Installing listen 3.7.1
Fetching typhoeus 1.4.0
Fetching guard 2.15.0
Installing typhoeus 1.4.0
Installing guard 2.15.0
Fetching thin 1.8.1
Installing thin 1.8.1 with native extensions
Fetching mimic 0.4.4
Installing mimic 0.4.4
Using zold 0.0.0 from source at `.`
Bundle complete! 17 Gemfile dependencies, 112 gems now installed.
Use `bundle info [gemname]` to see where a bundled gem is installed.
Post-install message from rubocop:
Performance cops have been removed from RuboCop 0.68. Use the `rubocop-performance` gem instead.

Put this in your `Gemfile`.

```rb
gem 'rubocop-performance'
```

And then execute:

```sh
$ bundle install
```

Put this into your `.rubocop.yml`.

```yaml
require: rubocop-performance
```

More information: https://github.com/rubocop-hq/rubocop-performance
Post-install message from usagewatch:
* Linux version are covered for our test.
Thanks for installing!
Post-install message from usagewatch_ext:
* Usagewatch Gem for linux are covered for our test.
* Mac OS version is in development
Thanks for installing!
++ pwd
+ sudo -i rm -rf /home/r/repo/Gemfile.lock
+ [[ 0.31.3 =~ ^[0-9]+\.[0-9]+\.[0-9]+$ ]]
+ export RUBYOPT=-W0
+ RUBYOPT=-W0
+ sed -i 's/0\.0\.0/0.31.3/g' lib/zold/version.rb
+ bundle exec rake --quiet
/usr/local/rvm/rubies/ruby-2.7.0/bin/ruby -I"lib:lib:test" -I"/usr/local/rvm/gems/ruby-2.7.0/gems/rake-12.3.2/lib" "/usr/local/rvm/gems/ruby-2.7.0/gems/rake-12.3.2/lib/rake/rake_test_loader.rb" "test/commands/routines/test_audit.rb" "test/commands/routines/test_gc.rb" "test/commands/routines/test_reconcile.rb" "test/commands/routines/test_reconnect.rb" "test/commands/routines/test_retire.rb" "test/commands/test_alias.rb" "test/commands/test_calculate.rb" "test/commands/test_clean.rb" "test/commands/test_create.rb" "test/commands/test_diff.rb" "test/commands/test_fetch.rb" "test/commands/test_invoice.rb" "test/commands/test_list.rb" "test/commands/test_merge.rb" "test/commands/test_node.rb" "test/commands/test_pay.rb" "test/commands/test_propagate.rb" "test/commands/test_pull.rb" "test/commands/test_push.rb" "test/commands/test_remote.rb" "test/commands/test_remove.rb" "test/commands/test_show.rb" "test/commands/test_taxes.rb" "test/node/test_async_entrance.rb" "test/node/test_entrance.rb" "test/node/test_farm.rb" "test/node/test_farmers.rb" "test/node/test_front.rb" "test/node/test_nodup_entrance.rb" "test/node/test_nospam_entrance.rb" "test/node/test_safe_entrance.rb" "test/node/test_spread_entrance.rb" "test/node/test_sync_entrance.rb" "test/node/test_trace.rb" "test/test__helper.rb" "test/test_age.rb" "test/test_amount.rb" "test/test_cached_wallets.rb" "test/test_copies.rb" "test/test_dir_items.rb" "test/test_gem.rb" "test/test_hands.rb" "test/test_hexnum.rb" "test/test_http.rb" "test/test_hungry_wallets.rb" "test/test_id.rb" "test/test_json_page.rb" "test/test_key.rb" "test/test_log.rb" "test/test_metronome.rb" "test/test_patch.rb" "test/test_prefixes.rb" "test/test_remotes.rb" "test/test_signature.rb" "test/test_size.rb" "test/test_sync_wallets.rb" "test/test_tax.rb" "test/test_thread_pool.rb" "test/test_tree_wallets.rb" "test/test_txn.rb" "test/test_upgrades.rb" "test/test_verbose_thread.rb" "test/test_version.rb" "test/test_wallet.rb" "test/test_wallets.rb" "test/test_zold.rb" "test/upgrades/test_delete_banned_wallets.rb" "test/upgrades/test_protocol_up.rb"
Coverage report generated for Unit Tests to /home/r/repo/coverage. 1291 / 3851 LOC (33.52%) covered.
Started with run options --seed 16193

TestDirItems
  test_lists_recursively                                         32m PASS0m (0.00s)
  test_intensive_write_in_threads                                32m PASS0m (1.08s)
  test_lists_empty_dir                                           32m PASS0m (0.01s)
  test_log                                                       32m PASS0m (0.00s)
  test_lists_non_recursively                                     32m PASS0m (0.00s)

TestMerge
  test_negatives_in_between                                      32m PASS0m (0.02s)
  test_random_expenses                                           32m PASS0m (0.02s)
  test_rejects_fake_positives_in_new_wallet                      32m PASS0m (0.03s)
  test_unconfirmed_income                                        32m PASS0m (0.02s)
  test_log                                                       32m PASS0m (0.00s)
  test_missed_wallets                                            32m PASS0m (0.02s)
  test_simple_case                                               32m PASS0m (0.01s)
  test_merges_with_a_broken_copy                                 32m PASS0m (0.02s)
  test_merges_wallet                                             32m PASS0m (0.06s)
  test_into_no_wallet                                            32m PASS0m (0.01s)
  test_merges_a_copy_on_top                                      32m PASS0m (0.04s)
  test_legacy_negatives_stay                                     32m PASS0m (0.01s)
  test_negative_overwriting                                      32m PASS0m (0.01s)

TestUpgrades
  test_pending_scripts_run                                       33m SKIP0m (0.00s)
  test_already_ran_scripts_dont_run                              32m PASS0m (0.01s)
  test_log                                                       32m PASS0m (0.00s)
  test_no_version_file_is_ok                                     33m SKIP0m (0.00s)

FarmTest
  test_drops_expired_scores_from_history                         32m PASS0m (11.22s)
  test_log                                                       32m PASS0m (0.00s)
  test_reads_scores_at_high_speed                                32m PASS0m (7.33s)
  test_makes_best_score_in_background                            32m PASS0m (2.12s)
  test_terminates_farm_entirely                                  32m PASS0m (6.81s)
  test_correct_score_from_empty_farm                             32m PASS0m (0.00s)
  test_garbage_farm_file                                         32m PASS0m (0.00s)
  test_pre_loads_history                                         32m PASS0m (0.00s)
  test_renders_in_text                                           32m PASS0m (6.12s)
  test_renders_in_json                                           32m PASS0m (7.05s)
  test_makes_many_scores                                         32m PASS0m (9.75s)

TestReconcile
  test_reconciles                                                32m PASS0m (0.04s)
  test_log                                                       32m PASS0m (0.00s)

TestList
  test_lists_wallets_with_balances                               32m PASS0m (0.01s)
  test_log                                                       32m PASS0m (0.00s)

TestCopies
  test_cleans_broken_copies                                      32m PASS0m (0.01s)
  test_master_first                                              32m PASS0m (0.10s)
  test_cleans_copies                                             32m PASS0m (0.05s)
  test_ignores_too_old_scores                                    32m PASS0m (0.03s)
  test_lists_empty_dir                                           32m PASS0m (0.00s)
  test_sorts_them_by_score                                       32m PASS0m (0.09s)
  test_ignores_garbage                                           32m PASS0m (0.02s)
  test_overwrites_host                                           32m PASS0m (0.06s)
  test_adds_and_removes_copies                                   32m PASS0m (0.11s)
  test_log                                                       32m PASS0m (0.00s)

TestSize
  test_log                                                       32m PASS0m (0.00s)
  test_prints_size                                               32m PASS0m (0.00s)

TestSpreadEntrance
2022-12-05 17:14:44 +0000 Thin web server (v1.8.1 codename Infinite Smoothie)
2022-12-05 17:14:44 +0000 Maximum connections set to 1024
2022-12-05 17:14:44 +0000 Listening on 0.0.0.0:33813, CTRL+C to stop
2022-12-05 17:14:44 +0000 Stopping ...
  test_ignores_duplicates                                        32m PASS0m (7.90s)
  test_log                                                       32m PASS0m (0.00s)
  test_renders_json                                              32m PASS0m (0.11s)

TestAge
  test_prints_age                                                32m PASS0m (0.00s)
  test_prints_all_ages                                           32m PASS0m (0.00s)
  test_log                                                       32m PASS0m (0.00s)

FrontTest
2022-12-05 17:14:47 +0000 Thin web server (v1.8.1 codename Infinite Smoothie)
2022-12-05 17:14:47 +0000 Maximum connections set to 1024
2022-12-05 17:14:47 +0000 Listening on 0.0.0.0:35407, CTRL+C to stop
2022-12-05 17:14:47 +0000 Stopping ...
  test_alias_parameter                                           32m PASS0m (2.27s)
2022-12-05 17:14:49 +0000 Thin web server (v1.8.1 codename Infinite Smoothie)
2022-12-05 17:14:49 +0000 Maximum connections set to 1024
2022-12-05 17:14:49 +0000 Listening on 0.0.0.0:32921, CTRL+C to stop
2022-12-05 17:14:51 +0000 Stopping ...
  test_pushes_many_wallets                                       32m PASS0m (3.41s)
2022-12-05 17:14:52 +0000 Thin web server (v1.8.1 codename Infinite Smoothie)
2022-12-05 17:14:52 +0000 Maximum connections set to 1024
2022-12-05 17:14:52 +0000 Listening on 0.0.0.0:46245, CTRL+C to stop
2022-12-05 17:14:54 +0000 Stopping ...
  test_wallet_page__html                                         32m PASS0m (3.40s)
2022-12-05 17:15:00 +0000 Thin web server (v1.8.1 codename Infinite Smoothie)
2022-12-05 17:15:00 +0000 Maximum connections set to 1024
2022-12-05 17:15:00 +0000 Listening on 0.0.0.0:39951, CTRL+C to stop
2022-12-05 17:15:02 +0000 Stopping ...
  test_performance                                               32m PASS0m (8.70s)
2022-12-05 17:15:05 +0000 Thin web server (v1.8.1 codename Infinite Smoothie)
2022-12-05 17:15:05 +0000 Maximum connections set to 1024
2022-12-05 17:15:05 +0000 Listening on 0.0.0.0:35899, CTRL+C to stop
2022-12-05 17:15:05 +0000 Stopping ...
  test_renders_front_json                                        32m PASS0m (2.26s)
2022-12-05 17:15:07 +0000 Thin web server (v1.8.1 codename Infinite Smoothie)
2022-12-05 17:15:07 +0000 Maximum connections set to 1024
2022-12-05 17:15:07 +0000 Listening on 0.0.0.0:41683, CTRL+C to stop
2022-12-05 17:15:09 +0000 Stopping ...
  test_wallet_page__digest                                       32m PASS0m (3.34s)
2022-12-05 17:15:10 +0000 Thin web server (v1.8.1 codename Infinite Smoothie)
2022-12-05 17:15:10 +0000 Maximum connections set to 1024
2022-12-05 17:15:10 +0000 Listening on 0.0.0.0:42309, CTRL+C to stop
2022-12-05 17:15:12 +0000 Stopping ...
  test_wallet_page__mnemo                                        32m PASS0m (3.30s)
2022-12-05 17:15:13 +0000 Thin web server (v1.8.1 codename Infinite Smoothie)
2022-12-05 17:15:13 +0000 Maximum connections set to 1024
2022-12-05 17:15:13 +0000 Listening on 0.0.0.0:39869, CTRL+C to stop
2022-12-05 17:15:22 +0000 Stopping ...
  test_push_fetch_in_multiple_threads                            32m PASS0m (9.96s)
2022-12-05 17:15:29 +0000 Thin web server (v1.8.1 codename Infinite Smoothie)
2022-12-05 17:15:29 +0000 Maximum connections set to 1024
2022-12-05 17:15:29 +0000 Listening on 0.0.0.0:39417, CTRL+C to stop
2022-12-05 17:15:30 +0000 Stopping ...
  test_updates_list_of_remotes                                   32m PASS0m (8.46s)
2022-12-05 17:15:32 +0000 Thin web server (v1.8.1 codename Infinite Smoothie)
2022-12-05 17:15:32 +0000 Maximum connections set to 1024
2022-12-05 17:15:32 +0000 Listening on 0.0.0.0:38931, CTRL+C to stop
2022-12-05 17:15:34 +0000 Stopping ...
  test_wallet_page__bin                                          32m PASS0m (3.31s)
2022-12-05 17:15:35 +0000 Thin web server (v1.8.1 codename Infinite Smoothie)
2022-12-05 17:15:35 +0000 Maximum connections set to 1024
2022-12-05 17:15:35 +0000 Listening on 0.0.0.0:46555, CTRL+C to stop
2022-12-05 17:15:36 +0000 Stopping ...
  test_default_alias_parameter                                   32m PASS0m (2.30s)
2022-12-05 17:15:38 +0000 Thin web server (v1.8.1 codename Infinite Smoothie)
2022-12-05 17:15:38 +0000 Maximum connections set to 1024
2022-12-05 17:15:38 +0000 Listening on 0.0.0.0:33273, CTRL+C to stop
2022-12-05 17:15:39 +0000 Stopping ...
  test_pushes_twice                                              32m PASS0m (3.32s)
2022-12-05 17:15:41 +0000 Thin web server (v1.8.1 codename Infinite Smoothie)
2022-12-05 17:15:41 +0000 Maximum connections set to 1024
2022-12-05 17:15:41 +0000 Listening on 0.0.0.0:42531, CTRL+C to stop
2022-12-05 17:15:42 +0000 Stopping ...
  test_wallet_page__txns_json                                    32m PASS0m (3.31s)
2022-12-05 17:15:44 +0000 Thin web server (v1.8.1 codename Infinite Smoothie)
2022-12-05 17:15:44 +0000 Maximum connections set to 1024
2022-12-05 17:15:44 +0000 Listening on 0.0.0.0:34499, CTRL+C to stop
2022-12-05 17:15:45 +0000 Stopping ...
  test_checksum_in_json                                          32m PASS0m (2.28s)
2022-12-05 17:15:46 +0000 Thin web server (v1.8.1 codename Infinite Smoothie)
2022-12-05 17:15:46 +0000 Maximum connections set to 1024
2022-12-05 17:15:46 +0000 Listening on 0.0.0.0:40917, CTRL+C to stop
2022-12-05 17:15:48 +0000 Stopping ...
  test_wallet_page__size                                         32m PASS0m (3.31s)
2022-12-05 17:15:50 +0000 Thin web server (v1.8.1 codename Infinite Smoothie)
2022-12-05 17:15:50 +0000 Maximum connections set to 1024
2022-12-05 17:15:50 +0000 Listening on 0.0.0.0:37507, CTRL+C to stop
2022-12-05 17:15:51 +0000 Stopping ...
  test_wallet_page__age                                          32m PASS0m (3.30s)
2022-12-05 17:15:53 +0000 Thin web server (v1.8.1 codename Infinite Smoothie)
2022-12-05 17:15:53 +0000 Maximum connections set to 1024
2022-12-05 17:15:53 +0000 Listening on 0.0.0.0:45821, CTRL+C to stop
2022-12-05 17:15:55 +0000 Stopping ...
  test_wallet_page__txt                                          32m PASS0m (3.31s)
  test_memory_leakage                                            33m SKIP0m (0.00s)
2022-12-05 17:15:56 +0000 Thin web server (v1.8.1 codename Infinite Smoothie)
2022-12-05 17:15:56 +0000 Maximum connections set to 1024
2022-12-05 17:15:56 +0000 Listening on 0.0.0.0:40493, CTRL+C to stop
2022-12-05 17:15:57 +0000 Stopping ...
  test_renders_public_pages                                      32m PASS0m (2.44s)
2022-12-05 17:15:59 +0000 Thin web server (v1.8.1 codename Infinite Smoothie)
2022-12-05 17:15:59 +0000 Maximum connections set to 1024
2022-12-05 17:15:59 +0000 Listening on 0.0.0.0:44705, CTRL+C to stop
2022-12-05 17:16:00 +0000 Stopping ...
  test_wallet_page__mtime                                        32m PASS0m (3.30s)
2022-12-05 17:16:02 +0000 Thin web server (v1.8.1 codename Infinite Smoothie)
2022-12-05 17:16:02 +0000 Maximum connections set to 1024
2022-12-05 17:16:02 +0000 Listening on 0.0.0.0:34383, CTRL+C to stop
2022-12-05 17:16:03 +0000 Stopping ...
  test_gzip                                                      32m PASS0m (2.26s)
2022-12-05 17:16:04 +0000 Thin web server (v1.8.1 codename Infinite Smoothie)
2022-12-05 17:16:04 +0000 Maximum connections set to 1024
2022-12-05 17:16:04 +0000 Listening on 0.0.0.0:44567, CTRL+C to stop
2022-12-05 17:16:06 +0000 Stopping ...
  test_renders_wallets_page                                      32m PASS0m (3.30s)
2022-12-05 17:16:08 +0000 Thin web server (v1.8.1 codename Infinite Smoothie)
2022-12-05 17:16:08 +0000 Maximum connections set to 1024
2022-12-05 17:16:08 +0000 Listening on 0.0.0.0:42139, CTRL+C to stop
2022-12-05 17:16:10 +0000 Stopping ...
  test_fetch_in_multiple_threads                                 32m PASS0m (4.13s)
  test_different_logos                                           32m PASS0m (0.00s)
  test_log                                                       32m PASS0m (0.00s)
2022-12-05 17:16:12 +0000 Thin web server (v1.8.1 codename Infinite Smoothie)
2022-12-05 17:16:12 +0000 Maximum connections set to 1024
2022-12-05 17:16:12 +0000 Listening on 0.0.0.0:36325, CTRL+C to stop
2022-12-05 17:16:13 +0000 Stopping ...
  test_wallet_page__balance                                      32m PASS0m (3.30s)
2022-12-05 17:16:15 +0000 Thin web server (v1.8.1 codename Infinite Smoothie)
2022-12-05 17:16:15 +0000 Maximum connections set to 1024
2022-12-05 17:16:15 +0000 Listening on 0.0.0.0:38213, CTRL+C to stop
2022-12-05 17:16:17 +0000 Stopping ...
  test_wallet_page__debt                                         32m PASS0m (3.30s)
2022-12-05 17:16:20 +0000 Thin web server (v1.8.1 codename Infinite Smoothie)
2022-12-05 17:16:20 +0000 Maximum connections set to 1024
2022-12-05 17:16:20 +0000 Listening on 0.0.0.0:34293, CTRL+C to stop
2022-12-05 17:16:20 +0000 Stopping ...
  test_increments_score                                          32m PASS0m (3.94s)
  test_invalid_alias                                             32m PASS0m (0.02s)
2022-12-05 17:16:22 +0000 Thin web server (v1.8.1 codename Infinite Smoothie)
2022-12-05 17:16:22 +0000 Maximum connections set to 1024
2022-12-05 17:16:22 +0000 Listening on 0.0.0.0:46281, CTRL+C to stop
2022-12-05 17:16:24 +0000 Stopping ...
  test_wallet_page__copies                                       32m PASS0m (3.30s)
2022-12-05 17:16:26 +0000 Thin web server (v1.8.1 codename Infinite Smoothie)
2022-12-05 17:16:26 +0000 Maximum connections set to 1024
2022-12-05 17:16:26 +0000 Listening on 0.0.0.0:33361, CTRL+C to stop
2022-12-05 17:16:26 +0000 Stopping ...
  test_headers_are_being_set_correctly                           32m PASS0m (2.27s)
2022-12-05 17:16:30 +0000 Thin web server (v1.8.1 codename Infinite Smoothie)
2022-12-05 17:16:30 +0000 Maximum connections set to 1024
2022-12-05 17:16:30 +0000 Listening on 0.0.0.0:42235, CTRL+C to stop
2022-12-05 17:16:36 +0000 Stopping ...
  test_score_is_reduced                                          32m PASS0m (10.24s)
2022-12-05 17:16:38 +0000 Thin web server (v1.8.1 codename Infinite Smoothie)
2022-12-05 17:16:38 +0000 Maximum connections set to 1024
2022-12-05 17:16:38 +0000 Listening on 0.0.0.0:45989, CTRL+C to stop
2022-12-05 17:16:40 +0000 Stopping ...
  test_wallet_page__key                                          32m PASS0m (3.32s)
2022-12-05 17:16:41 +0000 Thin web server (v1.8.1 codename Infinite Smoothie)
2022-12-05 17:16:41 +0000 Maximum connections set to 1024
2022-12-05 17:16:41 +0000 Listening on 0.0.0.0:46773, CTRL+C to stop
2022-12-05 17:16:43 +0000 Stopping ...
  test_wallet_page__txns                                         32m PASS0m (3.30s)

TestGem
  test_last_version_live                                         32m PASS0m (0.95s)
  test_last_version                                              32m PASS0m (0.00s)
  test_log                                                       32m PASS0m (0.00s)

TestThreadPool
  test_adds_and_stops                                            32m PASS0m (0.10s)
  test_closes_all_threads_right                                  32m PASS0m (0.00s)
  test_stops_stuck_threads                                       32m PASS0m (0.20s)
  test_prints_to_json                                            32m PASS0m (0.30s)
  test_prints_to_text                                            32m PASS0m (0.00s)
  test_stops_empty_pool                                          32m PASS0m (0.00s)
  test_log                                                       32m PASS0m (0.00s)

TestInvoice
  test_generates_invoice                                         32m PASS0m (0.01s)
  test_log                                                       32m PASS0m (0.00s)

TestVerboseThread
  test_grammar_exceptions_are_logged                             32m PASS0m (0.00s)
  test_syntax_exceptions_are_logged                              32m PASS0m (0.00s)
  test_log                                                       32m PASS0m (0.00s)
  test_exceptions_are_logged                                     32m PASS0m (0.00s)

TestHungryWallets
  test_doesnt_pull_twice_if_not_found                            32m PASS0m (2.61s)
  test_doesnt_pull_wallet_if_exists                              32m PASS0m (2.01s)
  test_log                                                       32m PASS0m (0.00s)
  test_pulls_wallet                                              32m PASS0m (2.01s)

TestId
  test_compares_two_ids                                          32m PASS0m (0.00s)
  test_log                                                       32m PASS0m (0.00s)
  test_checks_for_root                                           32m PASS0m (0.00s)
  test_generates_new_id                                          32m PASS0m (0.00s)
  test_list_of_banned_ids_is_not_empty                           32m PASS0m (0.00s)
  test_parses_id                                                 32m PASS0m (0.00s)
  test_compares_two_ids_by_text                                  32m PASS0m (0.00s)
  test_generates_id_only_once                                    32m PASS0m (0.00s)

TestDiff
  test_diff_with_copies                                          32m PASS0m (0.06s)
  test_log                                                       32m PASS0m (0.00s)

TestSyncWallets
  test_adds_wallet                                               32m PASS0m (2.51s)
  test_log                                                       32m PASS0m (0.00s)

TestAlias
  test_log                                                       32m PASS0m (0.00s)
  test_remove_removes_the_alias_from_the_alias_file              33m SKIP0m (0.00s)
  test_show_prints_out_the_aliased_wallet_id                     33m SKIP0m (0.00s)
  test_set_writes_alias_to_the_alias_file                        33m SKIP0m (0.00s)

TestSafeEntrance
  test_log                                                       32m PASS0m (0.00s)
  test_rejects_wallet_with_negative_balance                      32m PASS0m (0.03s)
  test_rejects_wallet_with_wrong_network                         32m PASS0m (0.00s)

TestCalculate
  test_log                                                       32m PASS0m (0.00s)
  test_calculates_score                                          32m PASS0m (0.01s)

TestCreate
  test_log                                                       32m PASS0m (0.00s)
  test_creates_wallet                                            32m PASS0m (0.00s)

TestRemotes
  test_read_mtime_from_file                                      32m PASS0m (0.00s)
  test_iterates_them_all_even_with_delays                        32m PASS0m (1.26s)
  test_reads_broken_file                                         32m PASS0m (0.01s)
  test_log_msg_of_iterates_when_take_too_long                    32m PASS0m (2.01s)
  test_quickly_ads_and_reads                                     32m PASS0m (5.03s)
  test_iterates_and_fails                                        32m PASS0m (0.47s)
  test_log                                                       32m PASS0m (0.00s)
  test_empty_remotes                                             32m PASS0m (0.00s)
  test_modifies_from_many_threads                                32m PASS0m (0.02s)
  test_log_msg_of_iterates_when_fail                             32m PASS0m (0.00s)
  test_iterates_all_failures                                     32m PASS0m (0.02s)
  test_mtime                                                     32m PASS0m (0.00s)
  test_adds_remotes                                              32m PASS0m (0.00s)
  test_finds_masters                                             32m PASS0m (0.00s)
  test_modifies_score                                            32m PASS0m (0.00s)
  test_removes_remotes                                           32m PASS0m (0.01s)
  test_reports_zold_error_header                                 32m PASS0m (0.01s)
  test_adds_from_many_threads                                    32m PASS0m (0.85s)
  test_reads_mtime_from_empty_file                               32m PASS0m (0.00s)
  test_resets_remotes                                            32m PASS0m (0.02s)
  test_closes_threads_carefully                                  32m PASS0m (1.26s)
  test_manifests_correct_network_name                            32m PASS0m (0.01s)
  test_tolerates_invalid_requests                                32m PASS0m (0.00s)
  test_unerror_remote                                            32m PASS0m (0.01s)

TestDeleteBannedWallets
  test_delete_them                                               32m PASS0m (0.01s)
  test_log                                                       32m PASS0m (0.00s)

TestPull
  test_fails_when_only_edge_nodes                                32m PASS0m (0.03s)
  test_log                                                       32m PASS0m (0.00s)
  test_pull_wallet                                               32m PASS0m (0.05s)

TestSignature
  test_log                                                       32m PASS0m (0.00s)
  test_signs_and_validates                                       32m PASS0m (0.02s)

TestRemove
  test_removes_no_wallets                                        32m PASS0m (0.01s)
  test_removes_absent_wallets                                    32m PASS0m (0.01s)
  test_removes_one_wallet                                        32m PASS0m (0.01s)
  test_removes_wallets                                           32m PASS0m (0.02s)
  test_log                                                       32m PASS0m (0.00s)

TestAsyncEntrance
  test_log                                                       32m PASS0m (0.00s)
  test_handles_broken_entrance_gracefully                        32m PASS0m (1.34s)
  test_sends_through                                             32m PASS0m (1.87s)
  test_renders_json                                              32m PASS0m (1.32s)
  test_sends_through_once                                        32m PASS0m (2.35s)

Zold::Test
  test_log                                                       32m PASS0m (0.00s)

TestTax
  test_prints_tax_formula                                        32m PASS0m (0.01s)
  test_calculates_tax_for_one_year                               32m PASS0m (0.01s)
  test_takes_tax_payment_into_account                            32m PASS0m (0.01s)
  test_calculates_debt                                           32m PASS0m (0.06s)
  test_checks_existence_of_duplicates                            32m PASS0m (0.03s)
  test_filters_out_incoming_payments                             32m PASS0m (0.01s)
  test_log                                                       32m PASS0m (0.00s)
  test_print_fee                                                 32m PASS0m (0.00s)

TestTreeWallets
  test_adds_many_wallets                                         32m PASS0m (0.05s)
  test_count_tree_wallets                                        32m PASS0m (0.00s)
  test_log                                                       32m PASS0m (0.00s)
  test_adds_wallet                                               32m PASS0m (0.01s)

FarmersTest
  test_calculates_large_score                                    32m PASS0m (0.30s)
  test_calculates_next_score                                     32m PASS0m (6.06s)
  test_log                                                       32m PASS0m (0.00s)
  test_kills_farmer                                              32m PASS0m (3.00s)

TestPropagate
  test_log                                                       32m PASS0m (0.00s)
  test_propagates_wallet                                         32m PASS0m (0.06s)

TestSyncEntrance
  test_log                                                       32m PASS0m (0.00s)
  test_renders_json                                              32m PASS0m (0.00s)

TestWallets
  test_adds_wallet                                               32m PASS0m (0.02s)
  test_log                                                       32m PASS0m (0.00s)
  test_substracts_dir_path_from_full_path                        32m PASS0m (0.00s)
  test_count_wallets                                             32m PASS0m (0.02s)
  test_lists_wallets_and_ignores_garbage                         32m PASS0m (0.01s)

TestMetronome
  test_prints_empty_to_text                                      32m PASS0m (0.00s)
  test_start_and_stop                                            32m PASS0m (0.10s)
  test_log                                                       32m PASS0m (0.00s)
  test_continues_even_after_error                                32m PASS0m (1.10s)
  test_prints_to_text                                            32m PASS0m (0.10s)

TestProtocolUp
  test_upgrades_protocol_in_wallet                               32m PASS0m (0.01s)
  test_log                                                       32m PASS0m (0.00s)

TestTxn
  test_converts_to_json                                          32m PASS0m (0.00s)
  test_prints_and_parses_time                                    32m PASS0m (0.00s)
  test_prints_and_parses                                         32m PASS0m (0.00s)
  test_log                                                       32m PASS0m (0.00s)
  test_accepts_text_as_details                                   32m PASS0m (0.00s)

TestJsonPage
  test_log                                                       32m PASS0m (0.00s)
  test_parses_broken_json_page                                   32m PASS0m (0.00s)
  test_parses_json_page                                          32m PASS0m (0.00s)
  test_parses_empty_page                                         32m PASS0m (0.00s)

TestHexnum
  test_prints_and_parses                                         32m PASS0m (0.00s)
  test_log                                                       32m PASS0m (0.00s)

TestAudit
  test_audits                                                    32m PASS0m (0.01s)
  test_log                                                       32m PASS0m (0.00s)

TestCachedWallets
  test_adds_wallet                                               32m PASS0m (0.02s)
  test_flushes_correctly                                         32m PASS0m (0.03s)
  test_log                                                       32m PASS0m (0.00s)

TestFetch
  test_log                                                       32m PASS0m (0.00s)
  test_fails_when_only_edge_nodes                                32m PASS0m (0.03s)
  test_fails_when_only_one_node                                  32m PASS0m (0.04s)
  test_fetches_multiple_wallets                                  32m PASS0m (0.07s)
  test_fetches_wallet                                            32m PASS0m (0.04s)

TestClean
  test_log                                                       32m PASS0m (0.00s)
  test_cleans_copies                                             32m PASS0m (0.02s)
  test_cleans_copies_in_threads                                  32m PASS0m (0.21s)
  test_clean_no_copies                                           32m PASS0m (0.02s)
  test_cleans_empty_wallets                                      32m PASS0m (0.00s)

TestPrefixes
  test_creates_and_validates                                     32m PASS0m (0.88s)
  test_log                                                       32m PASS0m (0.00s)

TestReconnect
  test_reconnects                                                32m PASS0m (0.05s)
  test_log                                                       32m PASS0m (0.00s)

TraceTest
  test_log                                                       32m PASS0m (0.00s)
  test_records_log_lines                                         32m PASS0m (0.00s)

TestRetire
  test_retires                                                   32m PASS0m (0.00s)
  test_log                                                       32m PASS0m (0.00s)

TestShow
  test_checks_wallet_balance                                     32m PASS0m (0.02s)
  test_log                                                       32m PASS0m (0.00s)

TestKey
  test_read_public_keys                                          32m PASS0m (0.01s)
  test_reads_public_rsa                                          32m PASS0m (0.02s)
  test_signs_and_verifies                                        32m PASS0m (0.02s)
  test_signs_and_verifies_with_random_key                        32m PASS0m (0.10s)
  test_parses_openssl_generated_keys                             32m PASS0m (0.18s)
  test_signs_with_real_keys                                      32m PASS0m (0.02s)
  test_log                                                       32m PASS0m (0.00s)
  test_reads_private_rsa                                         32m PASS0m (0.00s)
  test_reads_public_root_rsa                                     32m PASS0m (0.00s)

TestNoDupEntrance
  test_log                                                       32m PASS0m (0.00s)
  test_ignores_dup                                               32m PASS0m (0.01s)

TestLog
  test_prints_from_many_threads                                  32m PASS0m (0.00s)
2022-12-05T17:17:26Z 33mDEBUG0m This is info
and it is multi
line
2022-12-05T17:17:26Z 33mDEBUG0m Works fine?
2022-12-05T17:17:26Z 33mDEBUG0m true
2022-12-05T17:17:26Z 33mDEBUG0m 1
  test_prints_with_various_formatters                            32m PASS0m (0.00s)
  test_log                                                       32m PASS0m (0.00s)

TestRemote
  test_log                                                       32m PASS0m (0.00s)
  test_remote_trim_with_tolerate                                 32m PASS0m (0.06s)
  test_updates_just_once                                         32m PASS0m (0.03s)
  test_sets_masters                                              32m PASS0m (0.01s)
  test_select_doesnt_touch_masters                               32m PASS0m (0.02s)
  test_select_selects_the_strongest_nodes                        32m PASS0m (0.18s)
  test_new_version_rubygems                                      32m PASS0m (0.05s)
  test_elects_a_remote                                           32m PASS0m (0.01s)
  test_resets_remotes                                            32m PASS0m (0.01s)
  test_updates_remote                                            32m PASS0m (0.06s)
  test_select_respects_max_nodes_option                          32m PASS0m (0.13s)

TestPush
  test_fails_when_only_one_node                                  32m PASS0m (0.02s)
  test_pushes_multiple_wallets                                   32m PASS0m (0.04s)
  test_fails_when_only_edge_nodes                                32m PASS0m (0.02s)
  test_log                                                       32m PASS0m (0.00s)
  test_pushes_wallet                                             32m PASS0m (0.02s)

TestTaxes
  test_pays_taxes                                                32m PASS0m (0.05s)
  test_log                                                       32m PASS0m (0.00s)

TestZold
  test_print_helps                                               32m PASS0m (86.12s)
  test_log                                                       32m PASS0m (0.00s)
  test_show_version                                              32m PASS0m (1.02s)
  test_pull_on_start                                             32m PASS0m (74.66s)
  test_help                                                      32m PASS0m (0.87s)
  test_calculate_scores                                          32m PASS0m (6.74s)
  test_redeploy_on_upgrade                                       32m PASS0m (54.40s)
  test_spread_wallets                                            32m PASS0m (93.64s)
  test_push_and_pull                                             32m PASS0m (153.61s)
  test_create_new_wallet                                         32m PASS0m (7.79s)
  test_distribute_wallet                                         32m PASS0m (99.22s)

TestHands
  test_runs_in_many_threads                                      32m PASS0m (0.00s)
  test_log                                                       32m PASS0m (0.00s)
  test_runs_with_index                                           32m PASS0m (0.00s)
  test_runs_with_empty_set                                       32m PASS0m (0.00s)
  test_runs_with_exceptions                                      32m PASS0m (0.10s)

TestVersion
  test_has_protocol                                              32m PASS0m (0.00s)
  test_log                                                       32m PASS0m (0.00s)
  test_has_version                                               32m PASS0m (0.00s)

TestPatch
  test_accepts_negative_balance_in_root_wallet                   32m PASS0m (0.04s)
  test_protocols_new_txns                                        32m PASS0m (0.06s)
  test_builds_patch                                              32m PASS0m (0.13s)
  test_log                                                       32m PASS0m (0.00s)
  test_merges_fragmented_parts                                   32m PASS0m (0.08s)
  test_merges_similar_ids_but_different_signs                    32m PASS0m (0.05s)
  test_rejects_fake_positives                                    32m PASS0m (0.02s)

TestHttp
  test_sends_valid_network_header                                32m PASS0m (0.00s)
  test_sends_valid_version_header                                32m PASS0m (0.00s)
  test_downloads_file                                            32m PASS0m (0.01s)
  test_pings_broken_uri                                          32m PASS0m (0.00s)
  test_uploads_file                                              32m PASS0m (0.01s)
  test_pings_live_uri                                            32m PASS0m (0.00s)
  test_doesnt_terminate_on_long_call                             32m PASS0m (1.25s)
  test_sends_correct_http_headers                                32m PASS0m (0.00s)
  test_terminates_on_timeout                                     32m PASS0m (0.35s)
  test_sends_valid_protocol_header                               32m PASS0m (0.00s)
  test_log                                                       32m PASS0m (0.00s)
  test_pings_with_exception                                      32m PASS0m (0.00s)

TestEntrance
  test_log                                                       32m PASS0m (0.00s)
  test_pushes_wallet                                             32m PASS0m (0.09s)
  test_renders_json                                              32m PASS0m (0.04s)

TestPay
  test_notifies_about_tax_status                                 32m PASS0m (0.05s)
  test_pay_in_many_threads                                       32m PASS0m (0.35s)
  test_pays_and_taxes                                            32m PASS0m (0.09s)
  test_sends_from_normal_wallet                                  32m PASS0m (0.05s)
  test_sends_from_root_wallet                                    32m PASS0m (0.05s)
  test_log                                                       32m PASS0m (0.00s)
  test_pay_without_invoice                                       32m PASS0m (0.09s)
  test_sends_from_wallet_to_wallet                               32m PASS0m (0.08s)
  test_pay_with_keygap                                           32m PASS0m (0.04s)

TestNoSpamEntrance
  test_ignores_spam                                              32m PASS0m (0.00s)
  test_log                                                       32m PASS0m (0.00s)

TestAmount
  test_log                                                       32m PASS0m (0.00s)
  test_divides                                                   32m PASS0m (0.00s)
  test_compares_amounts                                          32m PASS0m (0.00s)
  test_compares_with_zero                                        32m PASS0m (0.00s)
  test_multiplies                                                32m PASS0m (0.00s)
  test_prints_zld_with_many_digits                               32m PASS0m (0.00s)
  test_parses_zents                                              32m PASS0m (0.00s)
  test_parses_zld                                                32m PASS0m (0.00s)

TestGc
  test_collects_garbage                                          32m PASS0m (0.02s)
  test_doesnt_touch_fresh_wallets                                32m PASS0m (0.01s)
  test_doesnt_touch_non_empty_wallets                            32m PASS0m (0.05s)
  test_log                                                       32m PASS0m (0.00s)

TestWallet
  test_calculates_wallet_age_in_hours                            32m PASS0m (0.01s)
  test_raises_when_broken_format                                 32m PASS0m (0.00s)
  test_refurbishes_empty_wallet                                  32m PASS0m (0.01s)
  test_generates_memo                                            32m PASS0m (0.01s)
  test_refurbishes_wallet                                        32m PASS0m (0.05s)
  test_collects_memory_garbage                                   33m SKIP0m (0.00s)
  test_positive_transactions_go_first                            32m PASS0m (0.05s)
  test_iterates_income_transactions                              32m PASS0m (0.01s)
  test_validate_key_on_payment                                   32m PASS0m (0.03s)
  test_flushes_and_reads_again                                   32m PASS0m (0.01s)
  test_reads_empty_wallet                                        32m PASS0m (0.01s)
  test_log                                                       32m PASS0m (0.00s)
  test_adds_transaction                                          32m PASS0m (0.07s)
  test_checks_similar_transaction                                32m PASS0m (0.03s)
  test_returns_digest                                            32m PASS0m (0.01s)
  test_reads_large_wallet                                        32m PASS0m (0.15s)
  test_returns_protocol                                          32m PASS0m (0.01s)
  test_returns_modified_time                                     32m PASS0m (0.01s)
  test_sorts_them_always_right                                   32m PASS0m (1.38s)
  test_adds_transaction_and_reads_back                           32m PASS0m (0.03s)
  test_adds_similar_transaction                                  32m PASS0m (0.03s)

TestNode
  test_log                                                       32m PASS0m (0.00s)
2022-12-05 17:27:13 +0000 Thin web server (v1.8.1 codename Infinite Smoothie)
2022-12-05 17:27:13 +0000 Maximum connections set to 1024
2022-12-05 17:27:13 +0000 Listening on 0.0.0.0:43645, CTRL+C to stop
2022-12-05 17:27:15 +0000 Stopping ...
  test_push_and_fetch                                            32m PASS0m (6.39s)

Finished in 810.26468s
361 tests, 3466 assertions, 32m0 failures, 0 errors, 0m33m7 skips0m
Using the default profile...
Feature: Command Line Processing
  As an payment originator I want to be able to use
  Zold as a command line tool

  Scenario: Help can be printed90m   # features/cli.feature:50m
    32mWhen I run 32m1mbin/zold0m0m32m with "32m1m-h0m0m32m"90m # features/step_definitions/steps.rb:420m0m
    32mThen Exit code is zero90m        # features/step_definitions/steps.rb:700m0m
    32mAnd Stdout contains "32m1m--help0m0m32m"90m  # features/step_definitions/steps.rb:620m0m

  Scenario: Version can be printed90m       # features/cli.feature:100m
    32mWhen I run 32m1mbin/zold0m0m32m with "32m1m--version0m0m32m"90m # features/step_definitions/steps.rb:420m0m
    32mThen Exit code is zero90m               # features/step_definitions/steps.rb:700m0m

  Scenario: Wallet can be created90m                                     # features/cli.feature:140m
    32mWhen I run 32m1mbin/zold0m0m32m with "32m1m--trace --public-key=id_rsa.pub create0m0m32m"90m # features/step_definitions/steps.rb:420m0m
    32mThen Exit code is zero90m                                            # features/step_definitions/steps.rb:700m0m

Feature: Gem Package
  As a source code writer I want to be able to
  package the Gem into .gem file

  Scenario: Gem can be packaged90m                # features/gem_package.feature:50m
    32mGiven It is Unix90m                           # features/step_definitions/steps.rb:780m0m
    32mGiven I have "32m1mexecs.rb0m0m32m" file with content:90m # features/step_definitions/steps.rb:550m0m
32m      """0m
32m      #!/usr/bin/env ruby0m
32m      require 'rubygems'0m
32m      spec = Gem::Specification::load('./spec.rb')0m
32m      if spec.executables.empty?0m
32m        fail 'no executables: ' + IO.read('./spec.rb')0m
32m      end0m
32m      """0m
    32mWhen I run bash with:90m                      # features/step_definitions/steps.rb:480m0m
32m      """0m
32m      set -x0m
32m      set -e0m
32m      cd zold0m
32m      gem build zold.gemspec0m
32m      gem specification --ruby zold-*.gem > ../spec.rb0m
32m      cd ..0m
32m      ruby execs.rb0m
32m      """0m
    32mThen Exit code is zero90m                     # features/step_definitions/steps.rb:700m0m

4 scenarios (32m4 passed0m)
11 steps (32m11 passed0m)
0m10.824s
Coverage report generated for Cucumber Features to /home/r/repo/coverage. 357 / 883 LOC (40.43%) covered.
Running RuboCop...
Inspecting 168 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.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.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.0m32m.0m32m.0m32m.0m32m.0m32m.0m32m.0m32m.0m32m.0m32m.0m32m.0m32m.0m

168 files inspected, 32mno offenses0m detected
Running xcop...
Inspecting 0 files...

0 files checked, everything looks 32mpretty0m
+ git add lib/zold/version.rb
+ git commit -m 'version set to 0.31.3'
[__rultor 758a9b4] version set to 0.31.3
 1 file changed, 1 insertion(+), 1 deletion(-)
+ gem build zold.gemspec
WARNING:  open-ended dependency on backtrace (>= 0.3) is not recommended
  if backtrace is semantically versioned, use:
    add_runtime_dependency 'backtrace', '~> 0.3'
WARNING:  open-ended dependency on futex (>= 0.8.5) is not recommended
  if futex is semantically versioned, use:
    add_runtime_dependency 'futex', '~> 0.8', '>= 0.8.5'
WARNING:  open-ended dependency on threads (>= 0.3) is not recommended
  if threads is semantically versioned, use:
    add_runtime_dependency 'threads', '~> 0.3'
WARNING:  open-ended dependency on total (>= 0.3) is not recommended
  if total is semantically versioned, use:
    add_runtime_dependency 'total', '~> 0.3'
WARNING:  open-ended dependency on zache (>= 0.12) is not recommended
  if zache is semantically versioned, use:
    add_runtime_dependency 'zache', '~> 0.12'
WARNING:  open-ended dependency on xcop (>= 0.6, development) is not recommended
  if xcop is semantically versioned, use:
    add_development_dependency 'xcop', '~> 0.6'
WARNING:  See http://guides.rubygems.org/specification-reference/ for help
  Successfully built RubyGem
  Name: zold
  Version: 0.31.3
  File: zold-0.31.3.gem
+ chmod 0600 ../rubygems.yml
+ gem push zold-0.31.3.gem --config-file ../rubygems.yml
Pushing gem to https://rubygems.org...
Successfully registered gem: zold (0.31.3)
+ mv /home/r/repo .
++ whoami
+ chown -R root repo
+ '[' -n '' ']'
++ whoami
+ sudo chown -R rultor repo
+ cd repo
+ git checkout __rultor
Already on '__rultor'
+ git tag 0.31.3 -m '0.31.3: tagged by rultor.com'
+ git reset --hard
HEAD is now at 758a9b4 version set to 0.31.3
+ git clean -fd
+ git checkout master
Switched to branch 'master'
Your branch is up to date with 'origin/master'.
+ git branch -D __rultor
Deleted branch __rultor (was 758a9b4).
+ git push --all origin
Everything up-to-date
+ git push --tags origin
To github.com:zold-io/zold.git
 * [new tag]         0.31.3 -> 0.31.3
container 11adc922386330e3b4e07d0fe07c51e426b17e22d3c38d045742da9653e0085c is dead
Mon 05 Dec 2022 06:28:11 PM CET