Running as unit: rb-build-arm64_6-90431.service ==================================================================================== Sat Apr 26 18:54:35 UTC 2025 - running /srv/jenkins/bin/reproducible_build.sh (for job reproducible_builder_arm64_6) on jenkins, called using "codethink03-arm64 codethink04-arm64" as arguments. Sat Apr 26 18:54:35 UTC 2025 - actually running "reproducible_build.sh" (md5sum 68e686e434c9ab7bc3ec047d8b309cbc) as "/tmp/jenkins-script-KUI0McnZ" $ git clone https://salsa.debian.org/qa/jenkins.debian.net.git ; more CONTRIBUTING Sat Apr 26 18:54:35 UTC 2025 - checking /var/lib/jenkins/offline_nodes if codethink03-arm64.debian.net is marked as down. Sat Apr 26 18:54:35 UTC 2025 - checking via ssh if codethink03-arm64.debian.net is up. removed '/tmp/read-only-fs-test-9JIndy' Sat Apr 26 18:54:36 UTC 2025 - checking /var/lib/jenkins/offline_nodes if codethink04-arm64.debian.net is marked as down. Sat Apr 26 18:54:36 UTC 2025 - checking via ssh if codethink04-arm64.debian.net is up. removed '/tmp/read-only-fs-test-DHAeqR' ok, let's check if ruby-rubocop-ast is building anywhere yet… ok, ruby-rubocop-ast is not building anywhere… UPDATE 1 ============================================================================= Initialising reproducibly build of ruby-rubocop-ast in unstable on arm64 on jenkins now. 1st build will be done on codethink03-arm64.debian.net. 2nd build will be done on codethink04-arm64.debian.net. ============================================================================= Sat Apr 26 18:54:59 UTC 2025 I: starting to build ruby-rubocop-ast/unstable/arm64 on jenkins on '2025-04-26 18:54' Sat Apr 26 18:54:59 UTC 2025 I: The jenkins build log is/was available at https://jenkins.debian.net/userContent/reproducible/debian/build_service/arm64_6/90431/console.log 1745693699 arm64 unstable ruby-rubocop-ast Sat Apr 26 18:54:59 UTC 2025 I: Downloading source for unstable/ruby-rubocop-ast=1.24.0-2 --2025-04-26 18:55:00-- http://deb.debian.org/debian/pool/main/r/ruby-rubocop-ast/ruby-rubocop-ast_1.24.0-2.dsc Connecting to 46.16.76.132:3128... connected. Proxy request sent, awaiting response... 200 OK Length: 2224 (2.2K) [text/prs.lines.tag] Saving to: ‘ruby-rubocop-ast_1.24.0-2.dsc’ 0K .. 100% 184M=0s 2025-04-26 18:55:00 (184 MB/s) - ‘ruby-rubocop-ast_1.24.0-2.dsc’ saved [2224/2224] --2025-04-26 18:55:00-- http://deb.debian.org/debian/pool/main/r/ruby-rubocop-ast/ruby-rubocop-ast_1.24.0-2.dsc Connecting to 46.16.76.132:3128... connected. Proxy request sent, awaiting response... 200 OK Length: 2224 (2.2K) [text/prs.lines.tag] Saving to: ‘ruby-rubocop-ast_1.24.0-2.dsc’ 0K .. 100% 184M=0s 2025-04-26 18:55:00 (184 MB/s) - ‘ruby-rubocop-ast_1.24.0-2.dsc’ saved [2224/2224] Sat Apr 26 18:55:00 UTC 2025 I: ruby-rubocop-ast_1.24.0-2.dsc -----BEGIN PGP SIGNED MESSAGE----- Hash: SHA256 Format: 3.0 (quilt) Source: ruby-rubocop-ast Binary: ruby-rubocop-ast Architecture: all Version: 1.24.0-2 Maintainer: Debian Ruby Team Uploaders: Antonio Terceiro , Utkarsh Gupta Homepage: https://github.com/rubocop/rubocop-ast Standards-Version: 4.6.1 Vcs-Browser: https://salsa.debian.org/ruby-team/ruby-rubocop-ast Vcs-Git: https://salsa.debian.org/ruby-team/ruby-rubocop-ast.git Testsuite: autopkgtest-pkg-ruby Build-Depends: debhelper-compat (= 13), gem2deb (>= 1), racc, rake, ruby-oedipus-lex, ruby-rspec, ruby-whitequark-parser (>= 3.1.1.0) Package-List: ruby-rubocop-ast deb ruby optional arch=all Checksums-Sha1: 4f979a247f95a082504e80645154f4a4b30e5caf 128125 ruby-rubocop-ast_1.24.0.orig.tar.gz ffd1f916c0f809ec22963214f1c6abc0349f22e0 3600 ruby-rubocop-ast_1.24.0-2.debian.tar.xz Checksums-Sha256: feadaaa1a1f0675e43c64a06a356645521e3c5da944b69f1303a89d70f0fd97d 128125 ruby-rubocop-ast_1.24.0.orig.tar.gz a85b55e430471f84a068b47c0525832aac154acc1db1f44cbe1ddb0e6fb29d9b 3600 ruby-rubocop-ast_1.24.0-2.debian.tar.xz Files: c1f6cccee88a2266c9d5404090c89202 128125 ruby-rubocop-ast_1.24.0.orig.tar.gz d63c8361ea267937c42c55efcc053137 3600 ruby-rubocop-ast_1.24.0-2.debian.tar.xz Ruby-Versions: all -----BEGIN PGP SIGNATURE----- iQJJBAEBCAAzFiEEjtbD+LrJ23/BMKhw+COicpiDyXwFAmOjexMVHGthbmFzaGly b0BkZWJpYW4ub3JnAAoJEPgjonKYg8l8CiMP/AhmZG+blRRHfv68AamTdQimuVkD jEMX0NdvINCvYMooF9BgymR/uycU2JMEuxZ1NlKTh2w1RqD3s3NCdQT3oiLKXZd0 uN7nrXmNM9ibuTj8LHD3cqoCiYHE8pRNnzIOdPaN6XE6bX9J7dgcg7vArVSar+Ja Ecft444GxjsU1aMAsqeuDLK5WqOX0+0+1nQb54b6itO/D+9IwUb845j9E/uhA/Jd ityydpeRvppGmKSbl6kvtvZX2KPMdNf6rCk11ILXxZRG5ZiY0SJ1OAg8qMxB9sS2 /CQgcjNUGWAKO8pbnD+/ou0TOjYqg8zR+xplEN3cRB7S0RCJA6nxxZ8wlBPERJH7 ilUDjRtHHdlPcwDstK4hRWu3TNvcri2keBiZW5yS1g8H0UTg/Y6iTHuaOnuMGleC /DJHABVgmVYHaWbEI0fRf1Dh8TbDMIIVnJaC61bJwfLMJ/2PvvmAXKI21Ub0trE8 qBvQuc0LOoW09XjTOFd5J5tEnDjgBB8g0HIoEf9/N7Bm7drK4IkAT3xU+BR34YVO zIGwRTbtHcQLrF2vR2WsTWEmWEMJAQrAdnOXd1DLc5NIjKMkwNmUuq10yFOPgpuJ opxjcVTWkmE1whhQRPz30iIVQx+RMl9VJuVmYJYh11Bxl0UQ3Rb2eCMOiF3TBc+e k9mYHxAYmZZSJAor =Tao1 -----END PGP SIGNATURE----- Sat Apr 26 18:55:00 UTC 2025 I: Checking whether the package is not for us Sat Apr 26 18:55:00 UTC 2025 I: Starting 1st build on remote node codethink03-arm64.debian.net. Sat Apr 26 18:55:00 UTC 2025 I: Preparing to do remote build '1' on codethink03-arm64.debian.net. Sat Apr 26 18:55:00 UTC 2025 - checking /var/lib/jenkins/offline_nodes if codethink03-arm64.debian.net is marked as down. Sat Apr 26 18:55:00 UTC 2025 - checking via ssh if codethink03-arm64.debian.net is up. removed '/tmp/read-only-fs-test-65QpLD' ==================================================================================== Sat May 30 01:18:01 UTC 2026 - running /srv/jenkins/bin/reproducible_build.sh (for job /srv/jenkins/bin/reproducible_build.sh) on codethink03-arm64, called using "1 ruby-rubocop-ast unstable /srv/reproducible-results/rbuild-debian/r-b-build.XpjqCx9r 1.24.0-2" as arguments. Sat May 30 01:18:01 UTC 2026 - actually running "reproducible_build.sh" (md5sum 68e686e434c9ab7bc3ec047d8b309cbc) as "/tmp/jenkins-script-2MS0dRsm" $ git clone https://salsa.debian.org/qa/jenkins.debian.net.git ; more CONTRIBUTING Sat May 30 01:18:01 UTC 2026 I: Downloading source for unstable/ruby-rubocop-ast=1.24.0-2 Reading package lists... NOTICE: 'ruby-rubocop-ast' packaging is maintained in the 'Git' version control system at: https://salsa.debian.org/ruby-team/ruby-rubocop-ast.git Please use: git clone https://salsa.debian.org/ruby-team/ruby-rubocop-ast.git to retrieve the latest (possibly unreleased) updates to the package. Need to get 134 kB of source archives. Get:1 http://deb.debian.org/debian unstable/main ruby-rubocop-ast 1.24.0-2 (dsc) [2224 B] Get:2 http://deb.debian.org/debian unstable/main ruby-rubocop-ast 1.24.0-2 (tar) [128 kB] Get:3 http://deb.debian.org/debian unstable/main ruby-rubocop-ast 1.24.0-2 (diff) [3600 B] Fetched 134 kB in 0s (1780 kB/s) Download complete and in download only mode Reading package lists... NOTICE: 'ruby-rubocop-ast' packaging is maintained in the 'Git' version control system at: https://salsa.debian.org/ruby-team/ruby-rubocop-ast.git Please use: git clone https://salsa.debian.org/ruby-team/ruby-rubocop-ast.git to retrieve the latest (possibly unreleased) updates to the package. Need to get 134 kB of source archives. Get:1 http://deb.debian.org/debian unstable/main ruby-rubocop-ast 1.24.0-2 (dsc) [2224 B] Get:2 http://deb.debian.org/debian unstable/main ruby-rubocop-ast 1.24.0-2 (tar) [128 kB] Get:3 http://deb.debian.org/debian unstable/main ruby-rubocop-ast 1.24.0-2 (diff) [3600 B] Fetched 134 kB in 0s (1780 kB/s) Download complete and in download only mode ============================================================================= Building ruby-rubocop-ast in unstable on arm64 on codethink03-arm64 now. Date: Sat May 30 02:18:01 BST 2026 Date UTC: Sat May 30 01:18:01 UTC 2026 ============================================================================= W: /root/.pbuilderrc does not exist I: Logging to b1/build.log I: pbuilder: network access will be disabled during build I: Current time: Fri May 29 13:18:02 -12 2026 I: pbuilder-time-stamp: 1780103882 I: Building the build Environment I: extracting base tarball [/var/cache/pbuilder/unstable-reproducible-base.tgz] I: copying local configuration W: --override-config is not set; not updating apt.conf Read the manpage for details. I: mounting /proc filesystem I: mounting /sys filesystem I: creating /{dev,run}/shm I: mounting /dev/pts filesystem I: redirecting /dev/ptmx to /dev/pts/ptmx I: policy-rc.d already exists I: Copying source file I: copying [ruby-rubocop-ast_1.24.0-2.dsc] I: copying [./ruby-rubocop-ast_1.24.0.orig.tar.gz] I: copying [./ruby-rubocop-ast_1.24.0-2.debian.tar.xz] I: Extracting source dpkg-source: warning: cannot verify inline signature for ./ruby-rubocop-ast_1.24.0-2.dsc: unsupported subcommand dpkg-source: info: extracting ruby-rubocop-ast in ruby-rubocop-ast-1.24.0 dpkg-source: info: unpacking ruby-rubocop-ast_1.24.0.orig.tar.gz dpkg-source: info: unpacking ruby-rubocop-ast_1.24.0-2.debian.tar.xz dpkg-source: info: using patch list from debian/patches/series dpkg-source: info: applying 0001-gemspec-drop-git-usage.patch dpkg-source: info: applying 0002-Fix-compile-task.patch I: Not using root during the build. I: Installing the build-deps I: user script /srv/workspace/pbuilder/2893848/tmp/hooks/D02_print_environment starting I: set BUILDDIR='/build/reproducible-path' BUILDUSERGECOS='first user,first room,first work-phone,first home-phone,first other' BUILDUSERNAME='pbuilder1' BUILD_ARCH='arm64' DEBIAN_FRONTEND='noninteractive' DEB_BUILD_OPTIONS='buildinfo=+all reproducible=+all parallel=12 ' DISTRIBUTION='unstable' HOME='/root' HOST_ARCH='arm64' IFS=' ' INVOCATION_ID='d8c94ffce52c47cb84cc1da279b6dc62' LANG='C' LANGUAGE='en_US:en' LC_ALL='C' MAIL='/var/mail/root' OPTIND='1' PATH='/usr/sbin:/usr/bin:/sbin:/bin:/usr/games' PBCURRENTCOMMANDLINEOPERATION='build' PBUILDER_OPERATION='build' PBUILDER_PKGDATADIR='/usr/share/pbuilder' PBUILDER_PKGLIBDIR='/usr/lib/pbuilder' PBUILDER_SYSCONFDIR='/etc' PPID='2893848' PS1='# ' PS2='> ' PS4='+ ' PWD='/' SHELL='/bin/bash' SHLVL='2' SUDO_COMMAND='/usr/bin/timeout -k 18.1h 18h /usr/bin/ionice -c 3 /usr/bin/nice /usr/sbin/pbuilder --build --configfile /srv/reproducible-results/rbuild-debian/r-b-build.XpjqCx9r/pbuilderrc_uiMP --distribution unstable --hookdir /etc/pbuilder/first-build-hooks --debbuildopts -b --basetgz /var/cache/pbuilder/unstable-reproducible-base.tgz --buildresult /srv/reproducible-results/rbuild-debian/r-b-build.XpjqCx9r/b1 --logfile b1/build.log ruby-rubocop-ast_1.24.0-2.dsc' SUDO_GID='109' SUDO_UID='104' SUDO_USER='jenkins' TERM='unknown' TZ='/usr/share/zoneinfo/Etc/GMT+12' USER='root' _='/usr/bin/systemd-run' http_proxy='http://192.168.101.4:3128' I: uname -a Linux codethink03-arm64 6.1.0-33-cloud-arm64 #1 SMP Debian 6.1.133-1 (2025-04-10) aarch64 GNU/Linux I: ls -l /bin lrwxrwxrwx 1 root root 7 Mar 4 2025 /bin -> usr/bin I: user script /srv/workspace/pbuilder/2893848/tmp/hooks/D02_print_environment finished -> Attempting to satisfy build-dependencies -> Creating pbuilder-satisfydepends-dummy package Package: pbuilder-satisfydepends-dummy Version: 0.invalid.0 Architecture: arm64 Maintainer: Debian Pbuilder Team Description: Dummy package to satisfy dependencies with aptitude - created by pbuilder This package was created automatically by pbuilder to satisfy the build-dependencies of the package being currently built. Depends: debhelper-compat (= 13), gem2deb (>= 1), racc, rake, ruby-oedipus-lex, ruby-rspec, ruby-whitequark-parser (>= 3.1.1.0) dpkg-deb: building package 'pbuilder-satisfydepends-dummy' in '/tmp/satisfydepends-aptitude/pbuilder-satisfydepends-dummy.deb'. Selecting previously unselected package pbuilder-satisfydepends-dummy. (Reading database ... 19953 files and directories currently installed.) Preparing to unpack .../pbuilder-satisfydepends-dummy.deb ... Unpacking pbuilder-satisfydepends-dummy (0.invalid.0) ... dpkg: pbuilder-satisfydepends-dummy: dependency problems, but configuring anyway as you requested: pbuilder-satisfydepends-dummy depends on debhelper-compat (= 13); however: Package debhelper-compat is not installed. pbuilder-satisfydepends-dummy depends on gem2deb (>= 1); however: Package gem2deb is not installed. pbuilder-satisfydepends-dummy depends on racc; however: Package racc is not installed. pbuilder-satisfydepends-dummy depends on rake; however: Package rake is not installed. pbuilder-satisfydepends-dummy depends on ruby-oedipus-lex; however: Package ruby-oedipus-lex is not installed. pbuilder-satisfydepends-dummy depends on ruby-rspec; however: Package ruby-rspec is not installed. pbuilder-satisfydepends-dummy depends on ruby-whitequark-parser (>= 3.1.1.0); however: Package ruby-whitequark-parser is not installed. Setting up pbuilder-satisfydepends-dummy (0.invalid.0) ... Reading package lists... Building dependency tree... Reading state information... Initializing package states... Writing extended state information... Building tag database... pbuilder-satisfydepends-dummy is already installed at the requested version (0.invalid.0) pbuilder-satisfydepends-dummy is already installed at the requested version (0.invalid.0) The following NEW packages will be installed: autoconf{a} automake{a} autopoint{a} autotools-dev{a} bsdextrautils{a} ca-certificates{a} debhelper{a} devscripts{a} dh-autoreconf{a} dh-strip-nondeterminism{a} dwz{a} file{a} gem2deb{a} gem2deb-test-runner{a} gettext{a} gettext-base{a} gpg{a} gpg-agent{a} gpgconf{a} gpgv{a} groff-base{a} intltool-debian{a} libarchive-zip-perl{a} libassuan9{a} libb-hooks-op-check-perl{a} libclass-method-modifiers-perl{a} libclass-xsaccessor-perl{a} libclone-perl{a} libdebhelper-perl{a} libdevel-callchecker-perl{a} libdynaloader-functions-perl{a} libelf1t64{a} libencode-locale-perl{a} libexpat1{a} libffi8{a} libfile-dirlist-perl{a} libfile-homedir-perl{a} libfile-listing-perl{a} libfile-stripnondeterminism-perl{a} libfile-touch-perl{a} libfile-which-perl{a} libgcrypt20{a} libgmp-dev{a} libgmpxx4ldbl{a} libgpg-error0{a} libhtml-parser-perl{a} libhtml-tagset-perl{a} libhtml-tree-perl{a} libhttp-cookies-perl{a} libhttp-date-perl{a} libhttp-message-perl{a} libhttp-negotiate-perl{a} libimport-into-perl{a} libio-html-perl{a} libio-socket-ssl-perl{a} libksba8{a} liblwp-mediatypes-perl{a} liblwp-protocol-https-perl{a} libmagic-mgc{a} libmagic1t64{a} libmodule-runtime-perl{a} libmoo-perl{a} libnet-http-perl{a} libnet-ssleay-perl{a} libnpth0t64{a} libparams-classify-perl{a} libpipeline1{a} libpython3-stdlib{a} libpython3.13-minimal{a} libpython3.13-stdlib{a} libreadline8t64{a} librole-tiny-perl{a} libruby{a} libruby3.3{a} libsub-quote-perl{a} libtimedate-perl{a} libtool{a} libtry-tiny-perl{a} libuchardet0{a} libunistring5{a} liburi-perl{a} libwww-perl{a} libwww-robotrules-perl{a} libxml2{a} libyaml-0-2{a} m4{a} man-db{a} media-types{a} netbase{a} openssl{a} patchutils{a} perl-openssl-defaults{a} pinentry-curses{a} po-debconf{a} python3{a} python3-minimal{a} python3.13{a} python3.13-minimal{a} racc{a} rake{a} readline-common{a} ruby{a} ruby-all-dev{a} ruby-ast{a} ruby-csv{a} ruby-did-you-mean{a} ruby-diff-lcs{a} ruby-minitest{a} ruby-net-telnet{a} ruby-oedipus-lex{a} ruby-power-assert{a} ruby-rspec{a} ruby-rspec-core{a} ruby-rspec-expectations{a} ruby-rspec-mocks{a} ruby-rspec-support{a} ruby-ruby2-keywords{a} ruby-rubygems{a} ruby-test-unit{a} ruby-webrick{a} ruby-whitequark-parser{a} ruby-xmlrpc{a} ruby3.3{a} ruby3.3-dev{a} rubygems-integration{a} sensible-utils{a} sopv-gpgv{a} tzdata{a} wdiff{a} The following packages are RECOMMENDED but will NOT be installed: apt-file curl dctrl-tools debian-keyring dput dput-ng dupload equivs fonts-lato gnupg libarchive-cpio-perl libdata-dump-perl libdistro-info-perl libgit-wrapper-perl libgitlab-api-v4-perl libgpg-error-l10n libhtml-form-perl libhtml-format-perl libhttp-daemon-perl libio-compress-brotli-perl libjs-jquery libjson-perl liblist-compare-perl libltdl-dev libmail-sendmail-perl libmailtools-perl libnamespace-clean-perl libsoap-lite-perl libstring-shellquote-perl libxstring-perl licensecheck lintian lynx lzip pristine-tar python3-apt python3-argcomplete python3-debian python3-magic python3-requests python3-unidiff python3-xdg ruby-sdbm ruby3.3-doc sopv-doc strace unzip wget zip 0 packages upgraded, 129 newly installed, 0 to remove and 0 not upgraded. Need to get 35.0 MB of archives. After unpacking 148 MB will be used. Writing extended state information... Get: 1 http://deb.debian.org/debian unstable/main arm64 libpython3.13-minimal arm64 3.13.3-2 [855 kB] Get: 2 http://deb.debian.org/debian unstable/main arm64 libexpat1 arm64 2.7.1-1 [93.3 kB] Get: 3 http://deb.debian.org/debian unstable/main arm64 python3.13-minimal arm64 3.13.3-2 [1998 kB] Get: 4 http://deb.debian.org/debian unstable/main arm64 python3-minimal arm64 3.13.3-1 [27.2 kB] Get: 5 http://deb.debian.org/debian unstable/main arm64 media-types all 13.0.0 [29.3 kB] Get: 6 http://deb.debian.org/debian unstable/main arm64 netbase all 6.5 [12.4 kB] Get: 7 http://deb.debian.org/debian unstable/main arm64 tzdata all 2025b-2 [260 kB] Get: 8 http://deb.debian.org/debian unstable/main arm64 libffi8 arm64 3.4.8-2 [21.3 kB] Get: 9 http://deb.debian.org/debian unstable/main arm64 readline-common all 8.2-6 [69.4 kB] Get: 10 http://deb.debian.org/debian unstable/main arm64 libreadline8t64 arm64 8.2-6 [159 kB] Get: 11 http://deb.debian.org/debian unstable/main arm64 libpython3.13-stdlib arm64 3.13.3-2 [1890 kB] Get: 12 http://deb.debian.org/debian unstable/main arm64 python3.13 arm64 3.13.3-2 [751 kB] Get: 13 http://deb.debian.org/debian unstable/main arm64 libpython3-stdlib arm64 3.13.3-1 [10.2 kB] Get: 14 http://deb.debian.org/debian unstable/main arm64 python3 arm64 3.13.3-1 [28.2 kB] Get: 15 http://deb.debian.org/debian unstable/main arm64 sensible-utils all 0.0.25 [25.0 kB] Get: 16 http://deb.debian.org/debian unstable/main arm64 openssl arm64 3.5.0-1 [1454 kB] Get: 17 http://deb.debian.org/debian unstable/main arm64 ca-certificates all 20250419 [162 kB] Get: 18 http://deb.debian.org/debian unstable/main arm64 libmagic-mgc arm64 1:5.46-5 [338 kB] Get: 19 http://deb.debian.org/debian unstable/main arm64 libmagic1t64 arm64 1:5.46-5 [103 kB] Get: 20 http://deb.debian.org/debian unstable/main arm64 file arm64 1:5.46-5 [43.7 kB] Get: 21 http://deb.debian.org/debian unstable/main arm64 gettext-base arm64 0.23.1-1 [241 kB] Get: 22 http://deb.debian.org/debian unstable/main arm64 libuchardet0 arm64 0.0.8-1+b2 [69.2 kB] Get: 23 http://deb.debian.org/debian unstable/main arm64 groff-base arm64 1.23.0-7 [1129 kB] Get: 24 http://deb.debian.org/debian unstable/main arm64 bsdextrautils arm64 2.41-4 [93.9 kB] Get: 25 http://deb.debian.org/debian unstable/main arm64 libpipeline1 arm64 1.5.8-1 [40.2 kB] Get: 26 http://deb.debian.org/debian unstable/main arm64 man-db arm64 2.13.0-1 [1404 kB] Get: 27 http://deb.debian.org/debian unstable/main arm64 m4 arm64 1.4.19-8 [285 kB] Get: 28 http://deb.debian.org/debian unstable/main arm64 autoconf all 2.72-3.1 [494 kB] Get: 29 http://deb.debian.org/debian unstable/main arm64 autotools-dev all 20240727.1 [60.2 kB] Get: 30 http://deb.debian.org/debian unstable/main arm64 automake all 1:1.17-4 [862 kB] Get: 31 http://deb.debian.org/debian unstable/main arm64 autopoint all 0.23.1-1 [770 kB] Get: 32 http://deb.debian.org/debian unstable/main arm64 libdebhelper-perl all 13.24.2 [90.9 kB] Get: 33 http://deb.debian.org/debian unstable/main arm64 libtool all 2.5.4-4 [539 kB] Get: 34 http://deb.debian.org/debian unstable/main arm64 dh-autoreconf all 20 [17.1 kB] Get: 35 http://deb.debian.org/debian unstable/main arm64 libarchive-zip-perl all 1.68-1 [104 kB] Get: 36 http://deb.debian.org/debian unstable/main arm64 libfile-stripnondeterminism-perl all 1.14.1-2 [19.7 kB] Get: 37 http://deb.debian.org/debian unstable/main arm64 dh-strip-nondeterminism all 1.14.1-2 [8620 B] Get: 38 http://deb.debian.org/debian unstable/main arm64 libelf1t64 arm64 0.192-4 [189 kB] Get: 39 http://deb.debian.org/debian unstable/main arm64 dwz arm64 0.15-1+b1 [102 kB] Get: 40 http://deb.debian.org/debian unstable/main arm64 libunistring5 arm64 1.3-2 [453 kB] Get: 41 http://deb.debian.org/debian unstable/main arm64 libxml2 arm64 2.12.7+dfsg+really2.9.14-0.4 [629 kB] Get: 42 http://deb.debian.org/debian unstable/main arm64 gettext arm64 0.23.1-1 [1610 kB] Get: 43 http://deb.debian.org/debian unstable/main arm64 intltool-debian all 0.35.0+20060710.6 [22.9 kB] Get: 44 http://deb.debian.org/debian unstable/main arm64 po-debconf all 1.0.21+nmu1 [248 kB] Get: 45 http://deb.debian.org/debian unstable/main arm64 debhelper all 13.24.2 [919 kB] Get: 46 http://deb.debian.org/debian unstable/main arm64 libgpg-error0 arm64 1.51-4 [78.5 kB] Get: 47 http://deb.debian.org/debian unstable/main arm64 libassuan9 arm64 3.0.2-2 [59.1 kB] Get: 48 http://deb.debian.org/debian unstable/main arm64 libgcrypt20 arm64 1.11.0-7 [742 kB] Get: 49 http://deb.debian.org/debian unstable/main arm64 gpgconf arm64 2.4.7-15 [121 kB] Get: 50 http://deb.debian.org/debian unstable/main arm64 libksba8 arm64 1.6.7-2+b1 [125 kB] Get: 51 http://deb.debian.org/debian unstable/main arm64 libnpth0t64 arm64 1.8-3 [22.9 kB] Get: 52 http://deb.debian.org/debian unstable/main arm64 gpg arm64 2.4.7-15 [577 kB] Get: 53 http://deb.debian.org/debian unstable/main arm64 pinentry-curses arm64 1.3.1-2 [83.5 kB] Get: 54 http://deb.debian.org/debian unstable/main arm64 gpg-agent arm64 2.4.7-15 [248 kB] Get: 55 http://deb.debian.org/debian unstable/main arm64 libfile-dirlist-perl all 0.05-3 [7600 B] Get: 56 http://deb.debian.org/debian unstable/main arm64 libfile-which-perl all 1.27-2 [15.1 kB] Get: 57 http://deb.debian.org/debian unstable/main arm64 libfile-homedir-perl all 1.006-2 [42.4 kB] Get: 58 http://deb.debian.org/debian unstable/main arm64 libfile-touch-perl all 0.12-2 [8816 B] Get: 59 http://deb.debian.org/debian unstable/main arm64 libclass-method-modifiers-perl all 2.15-1 [18.0 kB] Get: 60 http://deb.debian.org/debian unstable/main arm64 libclass-xsaccessor-perl arm64 1.19-4+b5 [34.9 kB] Get: 61 http://deb.debian.org/debian unstable/main arm64 libb-hooks-op-check-perl arm64 0.22-3+b2 [10.6 kB] Get: 62 http://deb.debian.org/debian unstable/main arm64 libdynaloader-functions-perl all 0.004-2 [12.2 kB] Get: 63 http://deb.debian.org/debian unstable/main arm64 libdevel-callchecker-perl arm64 0.009-2 [15.7 kB] Get: 64 http://deb.debian.org/debian unstable/main arm64 libparams-classify-perl arm64 0.015-2+b4 [22.3 kB] Get: 65 http://deb.debian.org/debian unstable/main arm64 libmodule-runtime-perl all 0.018-1 [17.8 kB] Get: 66 http://deb.debian.org/debian unstable/main arm64 libimport-into-perl all 1.002005-2 [11.3 kB] Get: 67 http://deb.debian.org/debian unstable/main arm64 librole-tiny-perl all 2.002004-1 [21.4 kB] Get: 68 http://deb.debian.org/debian unstable/main arm64 libsub-quote-perl all 2.006008-1 [21.8 kB] Get: 69 http://deb.debian.org/debian unstable/main arm64 libmoo-perl all 2.005005-1 [58.0 kB] Get: 70 http://deb.debian.org/debian unstable/main arm64 libencode-locale-perl all 1.05-3 [12.9 kB] Get: 71 http://deb.debian.org/debian unstable/main arm64 libtimedate-perl all 2.3300-2 [39.3 kB] Get: 72 http://deb.debian.org/debian unstable/main arm64 libhttp-date-perl all 6.06-1 [10.7 kB] Get: 73 http://deb.debian.org/debian unstable/main arm64 libfile-listing-perl all 6.16-1 [12.4 kB] Get: 74 http://deb.debian.org/debian unstable/main arm64 libhtml-tagset-perl all 3.24-1 [14.7 kB] Get: 75 http://deb.debian.org/debian unstable/main arm64 liburi-perl all 5.30-1 [105 kB] Get: 76 http://deb.debian.org/debian unstable/main arm64 libhtml-parser-perl arm64 3.83-1+b2 [97.5 kB] Get: 77 http://deb.debian.org/debian unstable/main arm64 libhtml-tree-perl all 5.07-3 [211 kB] Get: 78 http://deb.debian.org/debian unstable/main arm64 libclone-perl arm64 0.47-1+b1 [13.7 kB] Get: 79 http://deb.debian.org/debian unstable/main arm64 libio-html-perl all 1.004-3 [16.2 kB] Get: 80 http://deb.debian.org/debian unstable/main arm64 liblwp-mediatypes-perl all 6.04-2 [20.2 kB] Get: 81 http://deb.debian.org/debian unstable/main arm64 libhttp-message-perl all 7.00-2 [79.8 kB] Get: 82 http://deb.debian.org/debian unstable/main arm64 libhttp-cookies-perl all 6.11-1 [19.1 kB] Get: 83 http://deb.debian.org/debian unstable/main arm64 libhttp-negotiate-perl all 6.01-2 [13.1 kB] Get: 84 http://deb.debian.org/debian unstable/main arm64 perl-openssl-defaults arm64 7+b2 [6712 B] Get: 85 http://deb.debian.org/debian unstable/main arm64 libnet-ssleay-perl arm64 1.94-3 [323 kB] Get: 86 http://deb.debian.org/debian unstable/main arm64 libio-socket-ssl-perl all 2.089-1 [223 kB] Get: 87 http://deb.debian.org/debian unstable/main arm64 libnet-http-perl all 6.23-1 [23.9 kB] Get: 88 http://deb.debian.org/debian unstable/main arm64 liblwp-protocol-https-perl all 6.14-1 [10.8 kB] Get: 89 http://deb.debian.org/debian unstable/main arm64 libtry-tiny-perl all 0.32-1 [22.9 kB] Get: 90 http://deb.debian.org/debian unstable/main arm64 libwww-robotrules-perl all 6.02-1 [12.9 kB] Get: 91 http://deb.debian.org/debian unstable/main arm64 libwww-perl all 6.78-1 [183 kB] Get: 92 http://deb.debian.org/debian unstable/main arm64 patchutils arm64 0.4.2-1+b1 [71.3 kB] Get: 93 http://deb.debian.org/debian unstable/main arm64 gpgv arm64 2.4.7-15 [219 kB] Get: 94 http://deb.debian.org/debian unstable/main arm64 sopv-gpgv all 0.1.4-1 [11.3 kB] Get: 95 http://deb.debian.org/debian unstable/main arm64 wdiff arm64 1.2.2-9 [122 kB] Get: 96 http://deb.debian.org/debian unstable/main arm64 devscripts all 2.25.10 [1062 kB] Get: 97 http://deb.debian.org/debian unstable/main arm64 rubygems-integration all 1.19 [5488 B] Get: 98 http://deb.debian.org/debian unstable/main arm64 ruby-csv all 3.3.4-1 [42.2 kB] Get: 99 http://deb.debian.org/debian unstable/main arm64 ruby-did-you-mean all 1.6.3-2 [20.9 kB] Get: 100 http://deb.debian.org/debian unstable/main arm64 ruby-minitest all 5.25.4-2 [66.2 kB] Get: 101 http://deb.debian.org/debian unstable/main arm64 ruby-net-telnet all 0.2.0-1 [13.1 kB] Get: 102 http://deb.debian.org/debian unstable/main arm64 ruby-ruby2-keywords all 0.0.5-1 [4300 B] Get: 103 http://deb.debian.org/debian unstable/main arm64 ruby-power-assert all 2.0.3-1 [11.8 kB] Get: 104 http://deb.debian.org/debian unstable/main arm64 ruby-test-unit all 3.6.2-1 [79.1 kB] Get: 105 http://deb.debian.org/debian unstable/main arm64 ruby-webrick all 1.9.1-1 [59.6 kB] Get: 106 http://deb.debian.org/debian unstable/main arm64 ruby-xmlrpc all 0.3.3-2 [24.4 kB] Get: 107 http://deb.debian.org/debian unstable/main arm64 libyaml-0-2 arm64 0.2.5-2 [49.2 kB] Get: 108 http://deb.debian.org/debian unstable/main arm64 libruby3.3 arm64 3.3.8-1 [6140 kB] Get: 109 http://deb.debian.org/debian unstable/main arm64 ruby3.3 arm64 3.3.8-1 [834 kB] Get: 110 http://deb.debian.org/debian unstable/main arm64 libruby arm64 1:3.3+b1 [5436 B] Get: 111 http://deb.debian.org/debian unstable/main arm64 ruby-rubygems all 3.6.7-2 [407 kB] Get: 112 http://deb.debian.org/debian unstable/main arm64 ruby arm64 1:3.3+b1 [6560 B] Get: 113 http://deb.debian.org/debian unstable/main arm64 rake all 13.2.1-1 [65.2 kB] Get: 114 http://deb.debian.org/debian unstable/main arm64 gem2deb-test-runner arm64 2.2.5 [17.9 kB] Get: 115 http://deb.debian.org/debian unstable/main arm64 libgmpxx4ldbl arm64 2:6.3.0+dfsg-3 [329 kB] Get: 116 http://deb.debian.org/debian unstable/main arm64 libgmp-dev arm64 2:6.3.0+dfsg-3 [621 kB] Get: 117 http://deb.debian.org/debian unstable/main arm64 ruby3.3-dev arm64 3.3.8-1 [1045 kB] Get: 118 http://deb.debian.org/debian unstable/main arm64 ruby-all-dev arm64 1:3.3+b1 [6496 B] Get: 119 http://deb.debian.org/debian unstable/main arm64 gem2deb arm64 2.2.5 [48.0 kB] Get: 120 http://deb.debian.org/debian unstable/main arm64 racc all 1.8.1-1 [75.4 kB] Get: 121 http://deb.debian.org/debian unstable/main arm64 ruby-ast all 2.4.3-1 [10.7 kB] Get: 122 http://deb.debian.org/debian unstable/main arm64 ruby-diff-lcs all 1.5.1-1 [28.1 kB] Get: 123 http://deb.debian.org/debian unstable/main arm64 ruby-oedipus-lex all 2.6.0-2 [19.1 kB] Get: 124 http://deb.debian.org/debian unstable/main arm64 ruby-rspec-support all 3.13.0c0e0m0s1-2 [28.5 kB] Get: 125 http://deb.debian.org/debian unstable/main arm64 ruby-rspec-core all 3.13.0c0e0m0s1-2 [164 kB] Get: 126 http://deb.debian.org/debian unstable/main arm64 ruby-rspec-expectations all 3.13.0c0e0m0s1-2 [90.2 kB] Get: 127 http://deb.debian.org/debian unstable/main arm64 ruby-rspec-mocks all 3.13.0c0e0m0s1-2 [81.3 kB] Get: 128 http://deb.debian.org/debian unstable/main arm64 ruby-rspec all 3.13.0c0e0m0s1-2 [5184 B] Get: 129 http://deb.debian.org/debian unstable/main arm64 ruby-whitequark-parser all 3.3.4.2-2 [507 kB] Fetched 35.0 MB in 0s (95.9 MB/s) Preconfiguring packages ... Selecting previously unselected package libpython3.13-minimal:arm64. (Reading database ... (Reading database ... 5% (Reading database ... 10% (Reading database ... 15% (Reading database ... 20% (Reading database ... 25% (Reading database ... 30% (Reading database ... 35% (Reading database ... 40% (Reading database ... 45% (Reading database ... 50% (Reading database ... 55% (Reading database ... 60% (Reading database ... 65% (Reading database ... 70% (Reading database ... 75% (Reading database ... 80% (Reading database ... 85% (Reading database ... 90% (Reading database ... 95% (Reading database ... 100% (Reading database ... 19953 files and directories currently installed.) Preparing to unpack .../libpython3.13-minimal_3.13.3-2_arm64.deb ... Unpacking libpython3.13-minimal:arm64 (3.13.3-2) ... Selecting previously unselected package libexpat1:arm64. Preparing to unpack .../libexpat1_2.7.1-1_arm64.deb ... Unpacking libexpat1:arm64 (2.7.1-1) ... Selecting previously unselected package python3.13-minimal. Preparing to unpack .../python3.13-minimal_3.13.3-2_arm64.deb ... Unpacking python3.13-minimal (3.13.3-2) ... Setting up libpython3.13-minimal:arm64 (3.13.3-2) ... Setting up libexpat1:arm64 (2.7.1-1) ... Setting up python3.13-minimal (3.13.3-2) ... Selecting previously unselected package python3-minimal. (Reading database ... (Reading database ... 5% (Reading database ... 10% (Reading database ... 15% (Reading database ... 20% (Reading database ... 25% (Reading database ... 30% (Reading database ... 35% (Reading database ... 40% (Reading database ... 45% (Reading database ... 50% (Reading database ... 55% (Reading database ... 60% (Reading database ... 65% (Reading database ... 70% (Reading database ... 75% (Reading database ... 80% (Reading database ... 85% (Reading database ... 90% (Reading database ... 95% (Reading database ... 100% (Reading database ... 20287 files and directories currently installed.) Preparing to unpack .../0-python3-minimal_3.13.3-1_arm64.deb ... Unpacking python3-minimal (3.13.3-1) ... Selecting previously unselected package media-types. Preparing to unpack .../1-media-types_13.0.0_all.deb ... Unpacking media-types (13.0.0) ... Selecting previously unselected package netbase. Preparing to unpack .../2-netbase_6.5_all.deb ... Unpacking netbase (6.5) ... Selecting previously unselected package tzdata. Preparing to unpack .../3-tzdata_2025b-2_all.deb ... Unpacking tzdata (2025b-2) ... Selecting previously unselected package libffi8:arm64. Preparing to unpack .../4-libffi8_3.4.8-2_arm64.deb ... Unpacking libffi8:arm64 (3.4.8-2) ... Selecting previously unselected package readline-common. Preparing to unpack .../5-readline-common_8.2-6_all.deb ... Unpacking readline-common (8.2-6) ... Selecting previously unselected package libreadline8t64:arm64. Preparing to unpack .../6-libreadline8t64_8.2-6_arm64.deb ... Adding 'diversion of /lib/aarch64-linux-gnu/libhistory.so.8 to /lib/aarch64-linux-gnu/libhistory.so.8.usr-is-merged by libreadline8t64' Adding 'diversion of /lib/aarch64-linux-gnu/libhistory.so.8.2 to /lib/aarch64-linux-gnu/libhistory.so.8.2.usr-is-merged by libreadline8t64' Adding 'diversion of /lib/aarch64-linux-gnu/libreadline.so.8 to /lib/aarch64-linux-gnu/libreadline.so.8.usr-is-merged by libreadline8t64' Adding 'diversion of /lib/aarch64-linux-gnu/libreadline.so.8.2 to /lib/aarch64-linux-gnu/libreadline.so.8.2.usr-is-merged by libreadline8t64' Unpacking libreadline8t64:arm64 (8.2-6) ... Selecting previously unselected package libpython3.13-stdlib:arm64. Preparing to unpack .../7-libpython3.13-stdlib_3.13.3-2_arm64.deb ... Unpacking libpython3.13-stdlib:arm64 (3.13.3-2) ... Selecting previously unselected package python3.13. Preparing to unpack .../8-python3.13_3.13.3-2_arm64.deb ... Unpacking python3.13 (3.13.3-2) ... Selecting previously unselected package libpython3-stdlib:arm64. Preparing to unpack .../9-libpython3-stdlib_3.13.3-1_arm64.deb ... Unpacking libpython3-stdlib:arm64 (3.13.3-1) ... Setting up python3-minimal (3.13.3-1) ... Selecting previously unselected package python3. (Reading database ... (Reading database ... 5% (Reading database ... 10% (Reading database ... 15% (Reading database ... 20% (Reading database ... 25% (Reading database ... 30% (Reading database ... 35% (Reading database ... 40% (Reading database ... 45% (Reading database ... 50% (Reading database ... 55% (Reading database ... 60% (Reading database ... 65% (Reading database ... 70% (Reading database ... 75% (Reading database ... 80% (Reading database ... 85% (Reading database ... 90% (Reading database ... 95% (Reading database ... 100% (Reading database ... 21299 files and directories currently installed.) Preparing to unpack .../000-python3_3.13.3-1_arm64.deb ... Unpacking python3 (3.13.3-1) ... Selecting previously unselected package sensible-utils. Preparing to unpack .../001-sensible-utils_0.0.25_all.deb ... Unpacking sensible-utils (0.0.25) ... Selecting previously unselected package openssl. Preparing to unpack .../002-openssl_3.5.0-1_arm64.deb ... Unpacking openssl (3.5.0-1) ... Selecting previously unselected package ca-certificates. Preparing to unpack .../003-ca-certificates_20250419_all.deb ... Unpacking ca-certificates (20250419) ... Selecting previously unselected package libmagic-mgc. Preparing to unpack .../004-libmagic-mgc_1%3a5.46-5_arm64.deb ... Unpacking libmagic-mgc (1:5.46-5) ... Selecting previously unselected package libmagic1t64:arm64. Preparing to unpack .../005-libmagic1t64_1%3a5.46-5_arm64.deb ... Unpacking libmagic1t64:arm64 (1:5.46-5) ... Selecting previously unselected package file. Preparing to unpack .../006-file_1%3a5.46-5_arm64.deb ... Unpacking file (1:5.46-5) ... Selecting previously unselected package gettext-base. Preparing to unpack .../007-gettext-base_0.23.1-1_arm64.deb ... Unpacking gettext-base (0.23.1-1) ... Selecting previously unselected package libuchardet0:arm64. Preparing to unpack .../008-libuchardet0_0.0.8-1+b2_arm64.deb ... Unpacking libuchardet0:arm64 (0.0.8-1+b2) ... Selecting previously unselected package groff-base. Preparing to unpack .../009-groff-base_1.23.0-7_arm64.deb ... Unpacking groff-base (1.23.0-7) ... Selecting previously unselected package bsdextrautils. Preparing to unpack .../010-bsdextrautils_2.41-4_arm64.deb ... Unpacking bsdextrautils (2.41-4) ... Selecting previously unselected package libpipeline1:arm64. Preparing to unpack .../011-libpipeline1_1.5.8-1_arm64.deb ... Unpacking libpipeline1:arm64 (1.5.8-1) ... Selecting previously unselected package man-db. Preparing to unpack .../012-man-db_2.13.0-1_arm64.deb ... Unpacking man-db (2.13.0-1) ... Selecting previously unselected package m4. Preparing to unpack .../013-m4_1.4.19-8_arm64.deb ... Unpacking m4 (1.4.19-8) ... Selecting previously unselected package autoconf. Preparing to unpack .../014-autoconf_2.72-3.1_all.deb ... Unpacking autoconf (2.72-3.1) ... Selecting previously unselected package autotools-dev. Preparing to unpack .../015-autotools-dev_20240727.1_all.deb ... Unpacking autotools-dev (20240727.1) ... Selecting previously unselected package automake. Preparing to unpack .../016-automake_1%3a1.17-4_all.deb ... Unpacking automake (1:1.17-4) ... Selecting previously unselected package autopoint. Preparing to unpack .../017-autopoint_0.23.1-1_all.deb ... Unpacking autopoint (0.23.1-1) ... Selecting previously unselected package libdebhelper-perl. Preparing to unpack .../018-libdebhelper-perl_13.24.2_all.deb ... Unpacking libdebhelper-perl (13.24.2) ... Selecting previously unselected package libtool. Preparing to unpack .../019-libtool_2.5.4-4_all.deb ... Unpacking libtool (2.5.4-4) ... Selecting previously unselected package dh-autoreconf. Preparing to unpack .../020-dh-autoreconf_20_all.deb ... Unpacking dh-autoreconf (20) ... Selecting previously unselected package libarchive-zip-perl. Preparing to unpack .../021-libarchive-zip-perl_1.68-1_all.deb ... Unpacking libarchive-zip-perl (1.68-1) ... Selecting previously unselected package libfile-stripnondeterminism-perl. Preparing to unpack .../022-libfile-stripnondeterminism-perl_1.14.1-2_all.deb ... Unpacking libfile-stripnondeterminism-perl (1.14.1-2) ... Selecting previously unselected package dh-strip-nondeterminism. Preparing to unpack .../023-dh-strip-nondeterminism_1.14.1-2_all.deb ... Unpacking dh-strip-nondeterminism (1.14.1-2) ... Selecting previously unselected package libelf1t64:arm64. Preparing to unpack .../024-libelf1t64_0.192-4_arm64.deb ... Unpacking libelf1t64:arm64 (0.192-4) ... Selecting previously unselected package dwz. Preparing to unpack .../025-dwz_0.15-1+b1_arm64.deb ... Unpacking dwz (0.15-1+b1) ... Selecting previously unselected package libunistring5:arm64. Preparing to unpack .../026-libunistring5_1.3-2_arm64.deb ... Unpacking libunistring5:arm64 (1.3-2) ... Selecting previously unselected package libxml2:arm64. Preparing to unpack .../027-libxml2_2.12.7+dfsg+really2.9.14-0.4_arm64.deb ... Unpacking libxml2:arm64 (2.12.7+dfsg+really2.9.14-0.4) ... Selecting previously unselected package gettext. Preparing to unpack .../028-gettext_0.23.1-1_arm64.deb ... Unpacking gettext (0.23.1-1) ... Selecting previously unselected package intltool-debian. Preparing to unpack .../029-intltool-debian_0.35.0+20060710.6_all.deb ... Unpacking intltool-debian (0.35.0+20060710.6) ... Selecting previously unselected package po-debconf. Preparing to unpack .../030-po-debconf_1.0.21+nmu1_all.deb ... Unpacking po-debconf (1.0.21+nmu1) ... Selecting previously unselected package debhelper. Preparing to unpack .../031-debhelper_13.24.2_all.deb ... Unpacking debhelper (13.24.2) ... Selecting previously unselected package libgpg-error0:arm64. Preparing to unpack .../032-libgpg-error0_1.51-4_arm64.deb ... Unpacking libgpg-error0:arm64 (1.51-4) ... Selecting previously unselected package libassuan9:arm64. Preparing to unpack .../033-libassuan9_3.0.2-2_arm64.deb ... Unpacking libassuan9:arm64 (3.0.2-2) ... Selecting previously unselected package libgcrypt20:arm64. Preparing to unpack .../034-libgcrypt20_1.11.0-7_arm64.deb ... Unpacking libgcrypt20:arm64 (1.11.0-7) ... Selecting previously unselected package gpgconf. Preparing to unpack .../035-gpgconf_2.4.7-15_arm64.deb ... Unpacking gpgconf (2.4.7-15) ... Selecting previously unselected package libksba8:arm64. Preparing to unpack .../036-libksba8_1.6.7-2+b1_arm64.deb ... Unpacking libksba8:arm64 (1.6.7-2+b1) ... Selecting previously unselected package libnpth0t64:arm64. Preparing to unpack .../037-libnpth0t64_1.8-3_arm64.deb ... Unpacking libnpth0t64:arm64 (1.8-3) ... Selecting previously unselected package gpg. Preparing to unpack .../038-gpg_2.4.7-15_arm64.deb ... Unpacking gpg (2.4.7-15) ... Selecting previously unselected package pinentry-curses. Preparing to unpack .../039-pinentry-curses_1.3.1-2_arm64.deb ... Unpacking pinentry-curses (1.3.1-2) ... Selecting previously unselected package gpg-agent. Preparing to unpack .../040-gpg-agent_2.4.7-15_arm64.deb ... Unpacking gpg-agent (2.4.7-15) ... Selecting previously unselected package libfile-dirlist-perl. Preparing to unpack .../041-libfile-dirlist-perl_0.05-3_all.deb ... Unpacking libfile-dirlist-perl (0.05-3) ... Selecting previously unselected package libfile-which-perl. Preparing to unpack .../042-libfile-which-perl_1.27-2_all.deb ... Unpacking libfile-which-perl (1.27-2) ... Selecting previously unselected package libfile-homedir-perl. Preparing to unpack .../043-libfile-homedir-perl_1.006-2_all.deb ... Unpacking libfile-homedir-perl (1.006-2) ... Selecting previously unselected package libfile-touch-perl. Preparing to unpack .../044-libfile-touch-perl_0.12-2_all.deb ... Unpacking libfile-touch-perl (0.12-2) ... Selecting previously unselected package libclass-method-modifiers-perl. Preparing to unpack .../045-libclass-method-modifiers-perl_2.15-1_all.deb ... Unpacking libclass-method-modifiers-perl (2.15-1) ... Selecting previously unselected package libclass-xsaccessor-perl. Preparing to unpack .../046-libclass-xsaccessor-perl_1.19-4+b5_arm64.deb ... Unpacking libclass-xsaccessor-perl (1.19-4+b5) ... Selecting previously unselected package libb-hooks-op-check-perl:arm64. Preparing to unpack .../047-libb-hooks-op-check-perl_0.22-3+b2_arm64.deb ... Unpacking libb-hooks-op-check-perl:arm64 (0.22-3+b2) ... Selecting previously unselected package libdynaloader-functions-perl. Preparing to unpack .../048-libdynaloader-functions-perl_0.004-2_all.deb ... Unpacking libdynaloader-functions-perl (0.004-2) ... Selecting previously unselected package libdevel-callchecker-perl:arm64. Preparing to unpack .../049-libdevel-callchecker-perl_0.009-2_arm64.deb ... Unpacking libdevel-callchecker-perl:arm64 (0.009-2) ... Selecting previously unselected package libparams-classify-perl:arm64. Preparing to unpack .../050-libparams-classify-perl_0.015-2+b4_arm64.deb ... Unpacking libparams-classify-perl:arm64 (0.015-2+b4) ... Selecting previously unselected package libmodule-runtime-perl. Preparing to unpack .../051-libmodule-runtime-perl_0.018-1_all.deb ... Unpacking libmodule-runtime-perl (0.018-1) ... Selecting previously unselected package libimport-into-perl. Preparing to unpack .../052-libimport-into-perl_1.002005-2_all.deb ... Unpacking libimport-into-perl (1.002005-2) ... Selecting previously unselected package librole-tiny-perl. Preparing to unpack .../053-librole-tiny-perl_2.002004-1_all.deb ... Unpacking librole-tiny-perl (2.002004-1) ... Selecting previously unselected package libsub-quote-perl. Preparing to unpack .../054-libsub-quote-perl_2.006008-1_all.deb ... Unpacking libsub-quote-perl (2.006008-1) ... Selecting previously unselected package libmoo-perl. Preparing to unpack .../055-libmoo-perl_2.005005-1_all.deb ... Unpacking libmoo-perl (2.005005-1) ... Selecting previously unselected package libencode-locale-perl. Preparing to unpack .../056-libencode-locale-perl_1.05-3_all.deb ... Unpacking libencode-locale-perl (1.05-3) ... Selecting previously unselected package libtimedate-perl. Preparing to unpack .../057-libtimedate-perl_2.3300-2_all.deb ... Unpacking libtimedate-perl (2.3300-2) ... Selecting previously unselected package libhttp-date-perl. Preparing to unpack .../058-libhttp-date-perl_6.06-1_all.deb ... Unpacking libhttp-date-perl (6.06-1) ... Selecting previously unselected package libfile-listing-perl. Preparing to unpack .../059-libfile-listing-perl_6.16-1_all.deb ... Unpacking libfile-listing-perl (6.16-1) ... Selecting previously unselected package libhtml-tagset-perl. Preparing to unpack .../060-libhtml-tagset-perl_3.24-1_all.deb ... Unpacking libhtml-tagset-perl (3.24-1) ... Selecting previously unselected package liburi-perl. Preparing to unpack .../061-liburi-perl_5.30-1_all.deb ... Unpacking liburi-perl (5.30-1) ... Selecting previously unselected package libhtml-parser-perl:arm64. Preparing to unpack .../062-libhtml-parser-perl_3.83-1+b2_arm64.deb ... Unpacking libhtml-parser-perl:arm64 (3.83-1+b2) ... Selecting previously unselected package libhtml-tree-perl. Preparing to unpack .../063-libhtml-tree-perl_5.07-3_all.deb ... Unpacking libhtml-tree-perl (5.07-3) ... Selecting previously unselected package libclone-perl:arm64. Preparing to unpack .../064-libclone-perl_0.47-1+b1_arm64.deb ... Unpacking libclone-perl:arm64 (0.47-1+b1) ... Selecting previously unselected package libio-html-perl. Preparing to unpack .../065-libio-html-perl_1.004-3_all.deb ... Unpacking libio-html-perl (1.004-3) ... Selecting previously unselected package liblwp-mediatypes-perl. Preparing to unpack .../066-liblwp-mediatypes-perl_6.04-2_all.deb ... Unpacking liblwp-mediatypes-perl (6.04-2) ... Selecting previously unselected package libhttp-message-perl. Preparing to unpack .../067-libhttp-message-perl_7.00-2_all.deb ... Unpacking libhttp-message-perl (7.00-2) ... Selecting previously unselected package libhttp-cookies-perl. Preparing to unpack .../068-libhttp-cookies-perl_6.11-1_all.deb ... Unpacking libhttp-cookies-perl (6.11-1) ... Selecting previously unselected package libhttp-negotiate-perl. Preparing to unpack .../069-libhttp-negotiate-perl_6.01-2_all.deb ... Unpacking libhttp-negotiate-perl (6.01-2) ... Selecting previously unselected package perl-openssl-defaults:arm64. Preparing to unpack .../070-perl-openssl-defaults_7+b2_arm64.deb ... Unpacking perl-openssl-defaults:arm64 (7+b2) ... Selecting previously unselected package libnet-ssleay-perl:arm64. Preparing to unpack .../071-libnet-ssleay-perl_1.94-3_arm64.deb ... Unpacking libnet-ssleay-perl:arm64 (1.94-3) ... Selecting previously unselected package libio-socket-ssl-perl. Preparing to unpack .../072-libio-socket-ssl-perl_2.089-1_all.deb ... Unpacking libio-socket-ssl-perl (2.089-1) ... Selecting previously unselected package libnet-http-perl. Preparing to unpack .../073-libnet-http-perl_6.23-1_all.deb ... Unpacking libnet-http-perl (6.23-1) ... Selecting previously unselected package liblwp-protocol-https-perl. Preparing to unpack .../074-liblwp-protocol-https-perl_6.14-1_all.deb ... Unpacking liblwp-protocol-https-perl (6.14-1) ... Selecting previously unselected package libtry-tiny-perl. Preparing to unpack .../075-libtry-tiny-perl_0.32-1_all.deb ... Unpacking libtry-tiny-perl (0.32-1) ... Selecting previously unselected package libwww-robotrules-perl. Preparing to unpack .../076-libwww-robotrules-perl_6.02-1_all.deb ... Unpacking libwww-robotrules-perl (6.02-1) ... Selecting previously unselected package libwww-perl. Preparing to unpack .../077-libwww-perl_6.78-1_all.deb ... Unpacking libwww-perl (6.78-1) ... Selecting previously unselected package patchutils. Preparing to unpack .../078-patchutils_0.4.2-1+b1_arm64.deb ... Unpacking patchutils (0.4.2-1+b1) ... Selecting previously unselected package gpgv. Preparing to unpack .../079-gpgv_2.4.7-15_arm64.deb ... Unpacking gpgv (2.4.7-15) ... Selecting previously unselected package sopv-gpgv. Preparing to unpack .../080-sopv-gpgv_0.1.4-1_all.deb ... Unpacking sopv-gpgv (0.1.4-1) ... Selecting previously unselected package wdiff. Preparing to unpack .../081-wdiff_1.2.2-9_arm64.deb ... Unpacking wdiff (1.2.2-9) ... Selecting previously unselected package devscripts. Preparing to unpack .../082-devscripts_2.25.10_all.deb ... Unpacking devscripts (2.25.10) ... Selecting previously unselected package rubygems-integration. Preparing to unpack .../083-rubygems-integration_1.19_all.deb ... Unpacking rubygems-integration (1.19) ... Selecting previously unselected package ruby-csv. Preparing to unpack .../084-ruby-csv_3.3.4-1_all.deb ... Unpacking ruby-csv (3.3.4-1) ... Selecting previously unselected package ruby-did-you-mean. Preparing to unpack .../085-ruby-did-you-mean_1.6.3-2_all.deb ... Unpacking ruby-did-you-mean (1.6.3-2) ... Selecting previously unselected package ruby-minitest. Preparing to unpack .../086-ruby-minitest_5.25.4-2_all.deb ... Unpacking ruby-minitest (5.25.4-2) ... Selecting previously unselected package ruby-net-telnet. Preparing to unpack .../087-ruby-net-telnet_0.2.0-1_all.deb ... Unpacking ruby-net-telnet (0.2.0-1) ... Selecting previously unselected package ruby-ruby2-keywords. Preparing to unpack .../088-ruby-ruby2-keywords_0.0.5-1_all.deb ... Unpacking ruby-ruby2-keywords (0.0.5-1) ... Selecting previously unselected package ruby-power-assert. Preparing to unpack .../089-ruby-power-assert_2.0.3-1_all.deb ... Unpacking ruby-power-assert (2.0.3-1) ... Selecting previously unselected package ruby-test-unit. Preparing to unpack .../090-ruby-test-unit_3.6.2-1_all.deb ... Unpacking ruby-test-unit (3.6.2-1) ... Selecting previously unselected package ruby-webrick. Preparing to unpack .../091-ruby-webrick_1.9.1-1_all.deb ... Unpacking ruby-webrick (1.9.1-1) ... Selecting previously unselected package ruby-xmlrpc. Preparing to unpack .../092-ruby-xmlrpc_0.3.3-2_all.deb ... Unpacking ruby-xmlrpc (0.3.3-2) ... Selecting previously unselected package libyaml-0-2:arm64. Preparing to unpack .../093-libyaml-0-2_0.2.5-2_arm64.deb ... Unpacking libyaml-0-2:arm64 (0.2.5-2) ... Selecting previously unselected package libruby3.3:arm64. Preparing to unpack .../094-libruby3.3_3.3.8-1_arm64.deb ... Unpacking libruby3.3:arm64 (3.3.8-1) ... Selecting previously unselected package ruby3.3. Preparing to unpack .../095-ruby3.3_3.3.8-1_arm64.deb ... Unpacking ruby3.3 (3.3.8-1) ... Selecting previously unselected package libruby:arm64. Preparing to unpack .../096-libruby_1%3a3.3+b1_arm64.deb ... Unpacking libruby:arm64 (1:3.3+b1) ... Selecting previously unselected package ruby-rubygems. Preparing to unpack .../097-ruby-rubygems_3.6.7-2_all.deb ... Unpacking ruby-rubygems (3.6.7-2) ... Selecting previously unselected package ruby. Preparing to unpack .../098-ruby_1%3a3.3+b1_arm64.deb ... Unpacking ruby (1:3.3+b1) ... Selecting previously unselected package rake. Preparing to unpack .../099-rake_13.2.1-1_all.deb ... Unpacking rake (13.2.1-1) ... Selecting previously unselected package gem2deb-test-runner. Preparing to unpack .../100-gem2deb-test-runner_2.2.5_arm64.deb ... Unpacking gem2deb-test-runner (2.2.5) ... Selecting previously unselected package libgmpxx4ldbl:arm64. Preparing to unpack .../101-libgmpxx4ldbl_2%3a6.3.0+dfsg-3_arm64.deb ... Unpacking libgmpxx4ldbl:arm64 (2:6.3.0+dfsg-3) ... Selecting previously unselected package libgmp-dev:arm64. Preparing to unpack .../102-libgmp-dev_2%3a6.3.0+dfsg-3_arm64.deb ... Unpacking libgmp-dev:arm64 (2:6.3.0+dfsg-3) ... Selecting previously unselected package ruby3.3-dev:arm64. Preparing to unpack .../103-ruby3.3-dev_3.3.8-1_arm64.deb ... Unpacking ruby3.3-dev:arm64 (3.3.8-1) ... Selecting previously unselected package ruby-all-dev:arm64. Preparing to unpack .../104-ruby-all-dev_1%3a3.3+b1_arm64.deb ... Unpacking ruby-all-dev:arm64 (1:3.3+b1) ... Selecting previously unselected package gem2deb. Preparing to unpack .../105-gem2deb_2.2.5_arm64.deb ... Unpacking gem2deb (2.2.5) ... Selecting previously unselected package racc. Preparing to unpack .../106-racc_1.8.1-1_all.deb ... Unpacking racc (1.8.1-1) ... Selecting previously unselected package ruby-ast. Preparing to unpack .../107-ruby-ast_2.4.3-1_all.deb ... Unpacking ruby-ast (2.4.3-1) ... Selecting previously unselected package ruby-diff-lcs. Preparing to unpack .../108-ruby-diff-lcs_1.5.1-1_all.deb ... Unpacking ruby-diff-lcs (1.5.1-1) ... Selecting previously unselected package ruby-oedipus-lex. Preparing to unpack .../109-ruby-oedipus-lex_2.6.0-2_all.deb ... Unpacking ruby-oedipus-lex (2.6.0-2) ... Selecting previously unselected package ruby-rspec-support. Preparing to unpack .../110-ruby-rspec-support_3.13.0c0e0m0s1-2_all.deb ... Unpacking ruby-rspec-support (3.13.0c0e0m0s1-2) ... Selecting previously unselected package ruby-rspec-core. Preparing to unpack .../111-ruby-rspec-core_3.13.0c0e0m0s1-2_all.deb ... Unpacking ruby-rspec-core (3.13.0c0e0m0s1-2) ... Selecting previously unselected package ruby-rspec-expectations. Preparing to unpack .../112-ruby-rspec-expectations_3.13.0c0e0m0s1-2_all.deb ... Unpacking ruby-rspec-expectations (3.13.0c0e0m0s1-2) ... Selecting previously unselected package ruby-rspec-mocks. Preparing to unpack .../113-ruby-rspec-mocks_3.13.0c0e0m0s1-2_all.deb ... Unpacking ruby-rspec-mocks (3.13.0c0e0m0s1-2) ... Selecting previously unselected package ruby-rspec. Preparing to unpack .../114-ruby-rspec_3.13.0c0e0m0s1-2_all.deb ... Unpacking ruby-rspec (3.13.0c0e0m0s1-2) ... Selecting previously unselected package ruby-whitequark-parser. Preparing to unpack .../115-ruby-whitequark-parser_3.3.4.2-2_all.deb ... Unpacking ruby-whitequark-parser (3.3.4.2-2) ... Setting up media-types (13.0.0) ... Setting up libpipeline1:arm64 (1.5.8-1) ... Setting up wdiff (1.2.2-9) ... Setting up libfile-which-perl (1.27-2) ... Setting up libnpth0t64:arm64 (1.8-3) ... Setting up ruby-ruby2-keywords (0.0.5-1) ... Setting up ruby-oedipus-lex (2.6.0-2) ... Setting up bsdextrautils (2.41-4) ... Setting up libgpg-error0:arm64 (1.51-4) ... Setting up libdynaloader-functions-perl (0.004-2) ... Setting up libclass-method-modifiers-perl (2.15-1) ... Setting up ruby-power-assert (2.0.3-1) ... Setting up libmagic-mgc (1:5.46-5) ... Setting up libclone-perl:arm64 (0.47-1+b1) ... Setting up libarchive-zip-perl (1.68-1) ... Setting up libyaml-0-2:arm64 (0.2.5-2) ... Setting up libhtml-tagset-perl (3.24-1) ... Setting up libdebhelper-perl (13.24.2) ... Setting up liblwp-mediatypes-perl (6.04-2) ... Setting up libmagic1t64:arm64 (1:5.46-5) ... Setting up libtry-tiny-perl (0.32-1) ... Setting up perl-openssl-defaults:arm64 (7+b2) ... Setting up gettext-base (0.23.1-1) ... Setting up m4 (1.4.19-8) ... Setting up libgcrypt20:arm64 (1.11.0-7) ... Setting up libencode-locale-perl (1.05-3) ... Setting up file (1:5.46-5) ... Setting up libelf1t64:arm64 (0.192-4) ... Setting up tzdata (2025b-2) ... Current default time zone: 'Etc/UTC' Local time is now: Sat May 30 01:18:22 UTC 2026. Universal Time is now: Sat May 30 01:18:22 UTC 2026. Run 'dpkg-reconfigure tzdata' if you wish to change it. Setting up ruby-minitest (5.25.4-2) ... Setting up autotools-dev (20240727.1) ... Setting up libgmpxx4ldbl:arm64 (2:6.3.0+dfsg-3) ... Setting up ruby-test-unit (3.6.2-1) ... Setting up ruby-ast (2.4.3-1) ... Setting up ruby-net-telnet (0.2.0-1) ... Setting up ruby-csv (3.3.4-1) ... Setting up libunistring5:arm64 (1.3-2) ... Setting up libio-html-perl (1.004-3) ... Setting up autopoint (0.23.1-1) ... Setting up libb-hooks-op-check-perl:arm64 (0.22-3+b2) ... Setting up autoconf (2.72-3.1) ... Setting up ruby-rspec-support (3.13.0c0e0m0s1-2) ... Setting up libtimedate-perl (2.3300-2) ... Setting up ruby-webrick (1.9.1-1) ... Setting up libffi8:arm64 (3.4.8-2) ... Setting up dwz (0.15-1+b1) ... Setting up sensible-utils (0.0.25) ... Setting up gpgv (2.4.7-15) ... Setting up libuchardet0:arm64 (0.0.8-1+b2) ... Setting up libassuan9:arm64 (3.0.2-2) ... Setting up librole-tiny-perl (2.002004-1) ... Setting up netbase (6.5) ... Setting up libsub-quote-perl (2.006008-1) ... Setting up libclass-xsaccessor-perl (1.19-4+b5) ... Setting up ruby-did-you-mean (1.6.3-2) ... Setting up libfile-dirlist-perl (0.05-3) ... Setting up libfile-homedir-perl (1.006-2) ... Setting up openssl (3.5.0-1) ... Setting up readline-common (8.2-6) ... Setting up ruby-xmlrpc (0.3.3-2) ... Setting up libxml2:arm64 (2.12.7+dfsg+really2.9.14-0.4) ... Setting up liburi-perl (5.30-1) ... Setting up libfile-touch-perl (0.12-2) ... Setting up libnet-ssleay-perl:arm64 (1.94-3) ... Setting up automake (1:1.17-4) ... update-alternatives: using /usr/bin/automake-1.17 to provide /usr/bin/automake (automake) in auto mode Setting up libksba8:arm64 (1.6.7-2+b1) ... Setting up pinentry-curses (1.3.1-2) ... Setting up libfile-stripnondeterminism-perl (1.14.1-2) ... Setting up libhttp-date-perl (6.06-1) ... Setting up gettext (0.23.1-1) ... Setting up libgmp-dev:arm64 (2:6.3.0+dfsg-3) ... Setting up libfile-listing-perl (6.16-1) ... Setting up libtool (2.5.4-4) ... Setting up libnet-http-perl (6.23-1) ... Setting up libdevel-callchecker-perl:arm64 (0.009-2) ... Setting up intltool-debian (0.35.0+20060710.6) ... Setting up dh-autoreconf (20) ... Setting up patchutils (0.4.2-1+b1) ... Setting up ca-certificates (20250419) ... Updating certificates in /etc/ssl/certs... 150 added, 0 removed; done. Setting up libreadline8t64:arm64 (8.2-6) ... Setting up dh-strip-nondeterminism (1.14.1-2) ... Setting up libwww-robotrules-perl (6.02-1) ... Setting up groff-base (1.23.0-7) ... Setting up libhtml-parser-perl:arm64 (3.83-1+b2) ... Setting up gpgconf (2.4.7-15) ... Setting up libpython3.13-stdlib:arm64 (3.13.3-2) ... Setting up libio-socket-ssl-perl (2.089-1) ... Setting up gpg (2.4.7-15) ... Setting up libpython3-stdlib:arm64 (3.13.3-1) ... Setting up libhttp-message-perl (7.00-2) ... Setting up libhttp-negotiate-perl (6.01-2) ... Setting up gpg-agent (2.4.7-15) ... Setting up libhttp-cookies-perl (6.11-1) ... Setting up python3.13 (3.13.3-2) ... Setting up po-debconf (1.0.21+nmu1) ... Setting up libhtml-tree-perl (5.07-3) ... Setting up libparams-classify-perl:arm64 (0.015-2+b4) ... Setting up python3 (3.13.3-1) ... Setting up rubygems-integration (1.19) ... Setting up sopv-gpgv (0.1.4-1) ... update-alternatives: using /usr/bin/sopv-gpgv to provide /usr/bin/sopv (sopv) in auto mode Setting up man-db (2.13.0-1) ... Not building database; man-db/auto-update is not 'true'. Setting up libmodule-runtime-perl (0.018-1) ... Setting up libimport-into-perl (1.002005-2) ... Setting up libmoo-perl (2.005005-1) ... Setting up debhelper (13.24.2) ... Setting up rake (13.2.1-1) ... Setting up liblwp-protocol-https-perl (6.14-1) ... Setting up libwww-perl (6.78-1) ... Setting up libruby3.3:arm64 (3.3.8-1) ... Setting up ruby-rubygems (3.6.7-2) ... Setting up devscripts (2.25.10) ... Setting up ruby3.3-dev:arm64 (3.3.8-1) ... Setting up ruby3.3 (3.3.8-1) ... Setting up libruby:arm64 (1:3.3+b1) ... Setting up ruby-all-dev:arm64 (1:3.3+b1) ... Setting up ruby (1:3.3+b1) ... Setting up racc (1.8.1-1) ... Setting up ruby-rspec-core (3.13.0c0e0m0s1-2) ... Setting up ruby-diff-lcs (1.5.1-1) ... Setting up ruby-whitequark-parser (3.3.4.2-2) ... Setting up gem2deb-test-runner (2.2.5) ... Setting up ruby-rspec-expectations (3.13.0c0e0m0s1-2) ... Setting up ruby-rspec-mocks (3.13.0c0e0m0s1-2) ... Setting up gem2deb (2.2.5) ... Setting up ruby-rspec (3.13.0c0e0m0s1-2) ... Processing triggers for libc-bin (2.41-7) ... Processing triggers for ca-certificates (20250419) ... Updating certificates in /etc/ssl/certs... 0 added, 0 removed; done. Running hooks in /etc/ca-certificates/update.d... done. Reading package lists... Building dependency tree... Reading state information... Reading extended state information... Initializing package states... Writing extended state information... Building tag database... -> Finished parsing the build-deps I: Building the package I: Running cd /build/reproducible-path/ruby-rubocop-ast-1.24.0/ && env PATH="/usr/sbin:/usr/bin:/sbin:/bin:/usr/games" HOME="/nonexistent/first-build" dpkg-buildpackage -us -uc -b && env PATH="/usr/sbin:/usr/bin:/sbin:/bin:/usr/games" HOME="/nonexistent/first-build" dpkg-genchanges -S > ../ruby-rubocop-ast_1.24.0-2_source.changes dpkg-buildpackage: info: source package ruby-rubocop-ast dpkg-buildpackage: info: source version 1.24.0-2 dpkg-buildpackage: info: source distribution unstable dpkg-buildpackage: info: source changed by Lucas Kanashiro dpkg-source --before-build . dpkg-buildpackage: info: host architecture arm64 debian/rules clean dh clean --buildsystem=ruby --with ruby dh_auto_clean -O--buildsystem=ruby dh_ruby --clean W: XS-Ruby-Versions is deprecated, and will be ignored dh_autoreconf_clean -O--buildsystem=ruby dh_clean -O--buildsystem=ruby debian/rules binary dh binary --buildsystem=ruby --with ruby dh_update_autotools_config -O--buildsystem=ruby dh_autoreconf -O--buildsystem=ruby dh_auto_configure -O--buildsystem=ruby dh_ruby --configure debian/rules override_dh_auto_build make[1]: Entering directory '/build/reproducible-path/ruby-rubocop-ast-1.24.0' rake -f tasks/compile.rake generate Generating lib/rubocop/ast/node_pattern/lexer.rex.rb from lib/rubocop/ast/node_pattern/lexer.rex racc -l -v -o lib/rubocop/ast/node_pattern/parser.racc.rb lib/rubocop/ast/node_pattern/parser.y dh_auto_build dh_ruby --build make[1]: Leaving directory '/build/reproducible-path/ruby-rubocop-ast-1.24.0' dh_auto_test -O--buildsystem=ruby dh_ruby --test create-stamp debian/debhelper-build-stamp dh_testroot -O--buildsystem=ruby dh_prep -O--buildsystem=ruby dh_auto_install --destdir=debian/ruby-rubocop-ast/ -O--buildsystem=ruby dh_ruby --install /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast ┌──────────────────────────────────────────────────────────────────────────────┐ │ ruby-rubocop-ast: Installing files and building extensions for ruby3.3 │ └──────────────────────────────────────────────────────────────────────────────┘ /usr/bin/ruby3.3 -S gem build --config-file /dev/null --verbose /tmp/d20260529-2904851-frzkt7/gemspec WARNING: open-ended dependency on parser (>= 3.1.1.0) is not recommended if parser is semantically versioned, use: add_runtime_dependency "parser", "~> 3.1", ">= 3.1.1.0" WARNING: See https://guides.rubygems.org/specification-reference/ for help Successfully built RubyGem Name: rubocop-ast Version: 1.24.0 File: rubocop-ast-1.24.0.gem /usr/bin/ruby3.3 -S gem install --config-file /dev/null --verbose --local --verbose --no-document --ignore-dependencies --install-dir debian/ruby-rubocop-ast/usr/share/rubygems-integration/all /tmp/d20260529-2904851-frzkt7/rubocop-ast-1.24.0.gem /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop-ast.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/builder.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/ext/range.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/ext/range_min_max.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/alias_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/and_asgn_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/and_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/arg_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/args_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/array_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/asgn_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/block_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/break_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/case_match_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/case_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/casgn_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/class_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/const_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/def_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/defined_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/dstr_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/ensure_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/float_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/for_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/forward_args_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/hash_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/if_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/in_pattern_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/index_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/indexasgn_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/int_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/keyword_splat_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/lambda_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/mixin/basic_literal_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/mixin/binary_operator_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/mixin/collection_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/mixin/conditional_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/mixin/descendence.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/mixin/hash_element_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/mixin/method_dispatch_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/mixin/method_identifier_predicates.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/mixin/modifier_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/mixin/numeric_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/mixin/parameterized_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/mixin/predicate_operator_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/module_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/next_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/op_asgn_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/or_asgn_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/or_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/pair_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/procarg0_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/range_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/regexp_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/resbody_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/rescue_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/return_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/self_class_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/send_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/str_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/super_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/symbol_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/until_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/when_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/while_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/yield_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node_pattern.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node_pattern/builder.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node_pattern/comment.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node_pattern/compiler.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node_pattern/compiler/atom_subcompiler.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node_pattern/compiler/binding.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node_pattern/compiler/debug.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node_pattern/compiler/node_pattern_subcompiler.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node_pattern/compiler/sequence_subcompiler.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node_pattern/compiler/subcompiler.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node_pattern/lexer.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node_pattern/lexer.rex.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node_pattern/method_definer.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node_pattern/node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node_pattern/parser.racc.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node_pattern/parser.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node_pattern/sets.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node_pattern/with_meta.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/processed_source.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/rubocop_compatibility.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/sexp.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/token.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/traversal.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/version.rb Successfully installed rubocop-ast-1.24.0 1 gem installed cd debian/ruby-rubocop-ast/usr/share/rubygems-integration/all rm -rf bin rm -rf build_info rm -rf cache rm -rf doc rm -rf extensions rmdir plugins cd gems/rubocop-ast-1.24.0 rm -f chmod 644 lib/rubocop/ast/builder.rb lib/rubocop/ast/ext/range.rb lib/rubocop/ast/ext/range_min_max.rb lib/rubocop/ast/node/alias_node.rb lib/rubocop/ast/node/and_asgn_node.rb lib/rubocop/ast/node/and_node.rb lib/rubocop/ast/node/arg_node.rb lib/rubocop/ast/node/args_node.rb lib/rubocop/ast/node/array_node.rb lib/rubocop/ast/node/asgn_node.rb lib/rubocop/ast/node/block_node.rb lib/rubocop/ast/node/break_node.rb lib/rubocop/ast/node/case_match_node.rb lib/rubocop/ast/node/case_node.rb lib/rubocop/ast/node/casgn_node.rb lib/rubocop/ast/node/class_node.rb lib/rubocop/ast/node/const_node.rb lib/rubocop/ast/node/def_node.rb lib/rubocop/ast/node/defined_node.rb lib/rubocop/ast/node/dstr_node.rb lib/rubocop/ast/node/ensure_node.rb lib/rubocop/ast/node/float_node.rb lib/rubocop/ast/node/for_node.rb lib/rubocop/ast/node/forward_args_node.rb lib/rubocop/ast/node/hash_node.rb lib/rubocop/ast/node/if_node.rb lib/rubocop/ast/node/in_pattern_node.rb lib/rubocop/ast/node/index_node.rb lib/rubocop/ast/node/indexasgn_node.rb lib/rubocop/ast/node/int_node.rb lib/rubocop/ast/node/keyword_splat_node.rb lib/rubocop/ast/node/lambda_node.rb lib/rubocop/ast/node/mixin/basic_literal_node.rb lib/rubocop/ast/node/mixin/binary_operator_node.rb lib/rubocop/ast/node/mixin/collection_node.rb lib/rubocop/ast/node/mixin/conditional_node.rb lib/rubocop/ast/node/mixin/descendence.rb lib/rubocop/ast/node/mixin/hash_element_node.rb lib/rubocop/ast/node/mixin/method_dispatch_node.rb lib/rubocop/ast/node/mixin/method_identifier_predicates.rb lib/rubocop/ast/node/mixin/modifier_node.rb lib/rubocop/ast/node/mixin/numeric_node.rb lib/rubocop/ast/node/mixin/parameterized_node.rb lib/rubocop/ast/node/mixin/predicate_operator_node.rb lib/rubocop/ast/node/module_node.rb lib/rubocop/ast/node/next_node.rb lib/rubocop/ast/node/op_asgn_node.rb lib/rubocop/ast/node/or_asgn_node.rb lib/rubocop/ast/node/or_node.rb lib/rubocop/ast/node/pair_node.rb lib/rubocop/ast/node/procarg0_node.rb lib/rubocop/ast/node/range_node.rb lib/rubocop/ast/node/regexp_node.rb lib/rubocop/ast/node/resbody_node.rb lib/rubocop/ast/node/rescue_node.rb lib/rubocop/ast/node/return_node.rb lib/rubocop/ast/node/self_class_node.rb lib/rubocop/ast/node/send_node.rb lib/rubocop/ast/node/str_node.rb lib/rubocop/ast/node/super_node.rb lib/rubocop/ast/node/symbol_node.rb lib/rubocop/ast/node/until_node.rb lib/rubocop/ast/node/when_node.rb lib/rubocop/ast/node/while_node.rb lib/rubocop/ast/node/yield_node.rb lib/rubocop/ast/node.rb lib/rubocop/ast/node_pattern/builder.rb lib/rubocop/ast/node_pattern/comment.rb lib/rubocop/ast/node_pattern/compiler/atom_subcompiler.rb lib/rubocop/ast/node_pattern/compiler/binding.rb lib/rubocop/ast/node_pattern/compiler/debug.rb lib/rubocop/ast/node_pattern/compiler/node_pattern_subcompiler.rb lib/rubocop/ast/node_pattern/compiler/sequence_subcompiler.rb lib/rubocop/ast/node_pattern/compiler/subcompiler.rb lib/rubocop/ast/node_pattern/compiler.rb lib/rubocop/ast/node_pattern/lexer.rb lib/rubocop/ast/node_pattern/lexer.rex.rb lib/rubocop/ast/node_pattern/method_definer.rb lib/rubocop/ast/node_pattern/node.rb lib/rubocop/ast/node_pattern/parser.racc.rb lib/rubocop/ast/node_pattern/parser.rb lib/rubocop/ast/node_pattern/sets.rb lib/rubocop/ast/node_pattern/with_meta.rb lib/rubocop/ast/node_pattern.rb lib/rubocop/ast/processed_source.rb lib/rubocop/ast/rubocop_compatibility.rb lib/rubocop/ast/sexp.rb lib/rubocop/ast/token.rb lib/rubocop/ast/traversal.rb lib/rubocop/ast/version.rb lib/rubocop/ast.rb lib/rubocop-ast.rb find lib/ -type d -empty -delete cd - cd - dh_installchangelogs -pruby-rubocop-ast /build/reproducible-path/ruby-rubocop-ast-1.24.0/CHANGELOG.md upstream /usr/bin/ruby3.3 /usr/bin/gem2deb-test-runner ┌──────────────────────────────────────────────────────────────────────────────┐ │ Checking Rubygems dependency resolution on ruby3.3 │ └──────────────────────────────────────────────────────────────────────────────┘ RUBYLIB=. GEM_PATH=/build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all:/build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/.debhelper/generated/_source/home/.local/share/gem/ruby/3.3.0:/var/lib/gems/3.3.0:/usr/local/lib/ruby/gems/3.3.0:/usr/lib/ruby/gems/3.3.0:/usr/lib/aarch64-linux-gnu/ruby/gems/3.3.0:/usr/share/rubygems-integration/3.3.0:/usr/share/rubygems-integration/all:/usr/lib/aarch64-linux-gnu/rubygems-integration/3.3.0 ruby3.3 -e gem\ \"rubocop-ast\" ┌──────────────────────────────────────────────────────────────────────────────┐ │ Run tests for ruby3.3 from debian/ruby-tests.rake │ └──────────────────────────────────────────────────────────────────────────────┘ RUBYLIB=. GEM_PATH=/build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all:/build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/.debhelper/generated/_source/home/.local/share/gem/ruby/3.3.0:/var/lib/gems/3.3.0:/usr/local/lib/ruby/gems/3.3.0:/usr/lib/ruby/gems/3.3.0:/usr/lib/aarch64-linux-gnu/ruby/gems/3.3.0:/usr/share/rubygems-integration/3.3.0:/usr/share/rubygems-integration/all:/usr/lib/aarch64-linux-gnu/rubygems-integration/3.3.0 ruby3.3 -S rake --rakelibdir /gem2deb-nonexistent -f debian/ruby-tests.rake /usr/bin/ruby3.3 -ruri -I/usr/share/rubygems-integration/all/gems/rspec-support-3.13.1/lib:/usr/share/rubygems-integration/all/gems/rspec-core-3.13.0/lib /usr/share/rubygems-integration/all/gems/rspec-core-3.13.0/exe/rspec --pattern ./spec/\*\*/\*_spec.rb --format documentation warning: parser/current is loading parser/ruby33, which recognizes 3.3.4-compliant syntax, but you are running 3.3.8. Please see https://github.com/whitequark/parser#compatibility-with-ruby-mri. Randomized with seed 46231 RuboCop::AST::IfNode #branches with an elsif statement is expected to all be literal is expected to eq 3 with an if statement is expected to eq 1 is expected to all be literal with an unless statement is expected to all be literal is expected to eq 1 with a ternary operator is expected to all be literal is expected to eq 2 with an else statement is expected to all be literal is expected to eq 2 #each_branch when passed a block yields all the branches when not passed a block is expected to be a kind of Enumerator #if? with a ternary operator is expected not to be if with an unless statement is expected not to be if with an if statement is expected to be if #unless? with a ternary operator is expected not to be unless with an unless statement is expected to be unless with an if statement is expected not to be unless #if_branch with an if statement is expected to be sym type with a ternary operator is expected to be sym type with an unless statement is expected to be sym type #inverse_keyword? with an if statement is expected to eq "unless" with an unless statement is expected to eq "if" with a ternary operator is expected to eq "" #ternary? with a ternary operator is expected to be ternary with an unless statement is expected not to be ternary with an if statement is expected not to be ternary #nested_conditional? with nested conditionals in elsif clause is expected to be nested conditional with no nested conditionals is expected not to be nested conditional with nested conditionals in if clause is expected to be nested conditional with nested conditionals in else clause is expected to be nested conditional with nested ternary operators when nested in the falsey branch is expected to be nested conditional when nested in the truthy branch is expected to be nested conditional #elsif_conditional? with nested conditionals in else clause is expected not to be elsif conditional with multiple elsif conditionals is expected to be elsif conditional with nested ternary operators when nested in the truthy branch is expected not to be elsif conditional when nested in the falsey branch is expected not to be elsif conditional with nested conditionals in if clause is expected not to be elsif conditional with one elsif conditional is expected to be elsif conditional #else? without an else statement is expected not to be elsif with an elsif statement is expected to be else #modifier_form? with a modifier if statement is expected to be modifier form with a non-modifier if statement is expected not to be modifier form with a modifier unless statement is expected to be modifier form with a non-modifier unless statement is expected not to be modifier form with a ternary operator is expected not to be modifier form #keyword with an unless statement is expected to eq "unless" with a ternary operator is expected to eq "" with an if statement is expected to eq "if" #else_branch with an unless statement is expected to be int type with an if statement is expected to be int type with a ternary operator is expected to be int type .new with a modifier statement is expected to be a kind of RuboCop::AST::IfNode with a regular if statement is expected to be a kind of RuboCop::AST::IfNode with a ternary operator is expected to be a kind of RuboCop::AST::IfNode #elsif? without an elsif statement is expected not to be elsif with an if statement comtaining an elsif is expected not to be elsif with an elsif statement is expected to be elsif RuboCop::AST::AndAsgnNode #operator is expected to eq :"&&" .new is expected to be a kind of RuboCop::AST::AndAsgnNode #name is expected to eq :var #expression is expected to eq s(:send, nil, :value) #assignment_node is expected to be a kind of RuboCop::AST::AsgnNode RuboCop::AST::HashNode #empty? with an empty hash is expected to be empty with a hash containing pairs is expected not to be empty with a hash containing a keyword splat is expected not to be empty #each_value when passed a block yields all the pairs when not passed a block is expected to be a kind of Enumerator #mixed_delimiters? when all pairs are using a hash rocket delimiter is expected not to be mixed delimiters when pairs are using different delimiters is expected to be mixed delimiters when all pairs are using a colon delimiter is expected not to be mixed delimiters #values with a hash with literal values is expected to eq 3 is expected to all be literal with a hash with string keys is expected to eq 2 is expected to all be send type with an empty hash is expected to be empty #pairs_on_same_line? with all pairs on the same line is expected to be pairs on same line with no pairs on the same line is expected not to be pairs on same line with some pairs on the same line is expected to be pairs on same line #keys with a hash with string keys is expected to all be str type is expected to eq 2 with an empty hash is expected to be empty with a hash with symbol keys is expected to eq 3 is expected to all be sym type #each_key when passed a block yields all the pairs when not passed a block is expected to be a kind of Enumerator #braces? as an argument with braces is expected to be braces as an argument with no braces is expected not to be braces with braces is expected to be braces .new is expected to be a kind of RuboCop::AST::HashNode #pairs with an empty hash is expected to be empty with a hash of variables is expected to eq 2 is expected to all be pair type with a hash of literals is expected to eq 3 is expected to all be pair type #each_pair when passed a block yields all the pairs when not passed a block is expected to be a kind of Enumerator RuboCop::AST::AndNode #inverse_operator with a semantic and node is expected to eq "or" with a logical and node is expected to eq "||" .new with a logical and node is expected to be a kind of RuboCop::AST::AndNode with a semantic and node is expected to be a kind of RuboCop::AST::AndNode #lhs with a semantic and node is expected to be sym type with a logical and node is expected to be sym type #operator with a logical and node is expected to eq "&&" with a semantic and node is expected to eq "and" #alternate_operator with a logical and node is expected to eq "and" with a semantic and node is expected to eq "&&" #rhs with a logical and node is expected to be int type with a semantic and node is expected to be int type #semantic_operator? with a semantic and node is expected to be semantic operator with a logical and node is expected not to be semantic operator #logical_operator? with a semantic and node is expected not to be logical operator with a logical and node is expected to be logical operator RuboCop::AST::EnsureNode .new is expected to be a kind of RuboCop::AST::EnsureNode #body is expected to be sym type RuboCop::AST::YieldNode #method_name is expected to eq :yield #block_argument? is expected not to be block argument #command? when argument is a symbol is expected to be command :yield when argument is a string is expected to be command "yield" #block_literal? is expected not to be block literal #splat_argument? with a splat argument is expected to be splat argument with mixed arguments is expected to be splat argument with regular arguments is expected not to be splat argument with no arguments is expected not to be splat argument #bang_method? is expected not to be bang method #first_argument with a single splat argument is expected to be splat type with a single literal argument is expected to be sym type with multiple mixed arguments is expected to be sym type with multiple literal arguments is expected to be sym type with no arguments is expected to be nil #camel_case_method? is expected not to be camel case method #dot? is expected not to be dot #receiver is expected to be nil #last_argument with multiple literal arguments is expected to be sym type with a single splat argument is expected to be splat type with a single literal argument is expected to be sym type with no arguments is expected to be nil with multiple mixed arguments is expected to be splat type #self_receiver? is expected not to be self receiver #double_colon? is expected not to be double colon #operator_method? is expected not to be operator method #setter_method? is expected not to be setter method #const_receiver? is expected not to be const receiver #assignment_method? is expected not to be assignment method #arguments with no arguments is expected to be empty with multiple mixed arguments is expected to eq 2 with a single literal argument is expected to eq 1 with a single splat argument is expected to eq 1 with multiple literal arguments is expected to eq 2 #method? when message matches when argument is a string is expected to be method "yield" when argument is a symbol is expected to be method :yield when message does not match when argument is a symbol is expected not to be method :foo when argument is a string is expected not to be method "foo" #arguments? with no arguments is expected not to be arguments with multiple literal arguments is expected to be arguments with a single literal argument is expected to be arguments with multiple mixed arguments is expected to be arguments with a single splat argument is expected to be arguments #macro? is expected not to be macro #block_node is expected to be nil #parenthesized? with arguments when using parentheses is expected to be parenthesized when not using parentheses is expected not to be parenthesized with no arguments when not using parentheses is expected not to be parenthesized when using parentheses is expected to be parenthesized #comparison_method? is expected not to be comparison method #predicate_method? is expected not to be predicate method .new is expected to be a kind of RuboCop::AST::YieldNode #implicit_call? is expected not to be implicit call RuboCop::AST::ArrayNode .new is expected to be a kind of RuboCop::AST::ArrayNode #values with an array of variables is expected to all be send type is expected to eq 2 with an array of literals is expected to eq 3 is expected to all be literal with an empty array is expected to be empty #percent_literal? with square brackets is expected not to be percent literal :symbol is expected not to be percent literal :string is expected not to be percent literal with a string percent literal is expected to be percent literal :string is expected to be percent literal is expected not to be percent literal :symbol with a symbol percent literal is expected not to be percent literal :string is expected to be percent literal :symbol is expected to be percent literal #bracketed? unbracketed is expected to be nil with square brackets is expected to be bracketed with a percent literal is expected to be bracketed #square_brackets? with a percent literal is expected not to be square brackets with square brackets is expected to be square brackets #each_value without block is expected to be a kind of Enumerator with block is expected to eq ["(int 1)", "(int 2)", "(int 3)"] is expected to be a kind of RuboCop::AST::ArrayNode RuboCop::AST::ReturnNode behaves like wrapped arguments node .new with arguments is expected to be a kind of RuboCop::AST::ReturnNode without arguments is expected to be a kind of RuboCop::AST::ReturnNode #arguments with a single splat argument is expected to eq 1 with a single argument is expected to eq 1 with no arguments is expected to be empty with no arguments and braces is expected to be empty with multiple literal arguments is expected to eq 2 with a single argument and braces is expected to eq 1 RuboCop::AST::RescueNode #branches when there is no else keyword returns only then rescue bodies when there is an else returns all the bodies with an empty else returns all the bodies #else_branch with an else statement is expected to be send type without an else statement is expected to be nil #else? without an else statement is expected not to be else with an else statement is expected to be else #resbody_branches is expected to eq 2 is expected to all be resbody type .new is expected to be a kind of RuboCop::AST::RescueNode #body is expected to be send type RuboCop::AST::RangeNode .new with a beignless range is expected to be range type is expected to be a kind of RuboCop::AST::RangeNode with an exclusive range is expected to be range type is expected to be a kind of RuboCop::AST::RangeNode with an infinite range is expected to be range type is expected to be a kind of RuboCop::AST::RangeNode with an inclusive range is expected to be a kind of RuboCop::AST::RangeNode is expected to be range type RuboCop::AST::SuperNode #implicit_call? is expected not to be implicit call #block_literal? with a block argument is expected not to be block literal with a block literal is expected to be block literal with no block is expected not to be block literal #receiver is expected to be nil #setter_method? is expected not to be setter method #predicate_method? is expected not to be predicate method #assignment_method? is expected not to be assignment method #comparison_method? is expected not to be comparison method #command? when argument is a symbol is expected to be command :super when argument is a string is expected to be command "super" #self_receiver? is expected not to be self receiver #camel_case_method? is expected not to be camel case method #bang_method? is expected not to be bang method #first_argument with a single splat argument is expected to be splat type with multiple mixed arguments is expected to be sym type with a single literal argument is expected to be sym type with multiple literal arguments is expected to be sym type with no arguments is expected to be nil #macro? is expected not to be macro #method? when message does not match when argument is a symbol is expected not to be method :foo when argument is a string is expected not to be method "foo" when message matches when argument is a string is expected to be method "super" when argument is a symbol is expected to be method :super #arguments? with a single splat argument is expected to be arguments with no arguments is expected not to be arguments with multiple mixed arguments is expected to be arguments with multiple literal arguments is expected to be arguments with a single literal argument is expected to be arguments #parenthesized? with arguments when not using parentheses is expected not to be parenthesized when using parentheses is expected to be parenthesized with no arguments when using parentheses is expected to be parenthesized when not using parentheses is expected not to be parenthesized #method_name is expected to eq :super #dot? is expected not to be dot #double_colon? is expected not to be double colon #last_argument with multiple literal arguments is expected to be sym type with no arguments is expected to be nil with a single literal argument is expected to be sym type with a single splat argument is expected to be splat type with multiple mixed arguments is expected to be splat type #splat_argument? with a splat argument is expected to be splat argument with no arguments is expected not to be splat argument with mixed arguments is expected to be splat argument with regular arguments is expected not to be splat argument #operator_method? is expected not to be operator method #const_receiver? is expected not to be const receiver #block_node with a block argument is expected to be nil with a block literal is expected to be block type with no block is expected to be nil #block_argument? with regular arguments is expected not to be block argument with mixed arguments is expected to be block argument with no arguments is expected not to be block argument with a block argument is expected to be block argument #arguments with multiple literal arguments is expected to eq 2 with no arguments is expected to be empty with a single literal argument is expected to eq 1 with multiple mixed arguments is expected to eq 2 with a single splat argument is expected to eq 1 .new with a zsuper node is expected to be a kind of RuboCop::AST::SuperNode with a super node is expected to be a kind of RuboCop::AST::SuperNode Changelog merges correctly parses correctly Changelog::Entry generates correct content RuboCop::AST::Ext::Range #line_span returns the range of lines a range occupies accepts an `exclude_end` keyword argument RuboCop::AST::RegexpNode #options with a regexp with multiple options is expected to eq 3 with a regexp with "o" option is expected to eq 0 with an empty regexp is expected to eq 0 with a regexp without option is expected to eq 0 with a regexp with single option is expected to eq 1 #single_interpolation? with o and other options is expected to be single interpolation with other options is expected not to be single interpolation with no options is expected not to be single interpolation with only o option is expected to be single interpolation #to_regexp with a regexp with option is expected to eq /.+/mix with a multi-line regexp with option is expected to eq / .+ /ix with a regexp without option is expected to eq /.+/ with an empty regexp with option is expected to eq //ix with a regexp with an "u" option is expected to eq "/abc/" with a regexp with an "n" option is expected to eq "/abc/n" with an empty regexp is expected to eq // with a regexp with an "o" option is expected to eq "/abc/i" with a multi-line regexp without option is expected to eq / .+ / #delimiters with %r{-delimiters is expected to eq ["{", "}"] with %r/-delimiters is expected to eq ["/", "/"] with %r<-delimiters is expected to eq ["<", ">"] with multi-line %r{-delimiters is expected to eq ["{", "}"] with /-delimiters is expected to eq ["/", "/"] #no_encoding? with no options is expected not to be no encoding with n and other options is expected to be no encoding with only n option is expected to be no encoding with other options is expected not to be no encoding #content with a multi-line regexp with option is expected to eq "\n.+\n" with a regexp with option is expected to eq ".+" with a multi-line regexp without option is expected to eq "\n.+\n" with a regexp without option is expected to eq ".+" with an empty regexp is expected to eq "" with an empty regexp with option is expected to eq "" #percent_r_literal? with %r<-delimiters is expected to be percent r literal with /-delimiters is expected not to be percent r literal with multi-line %r{-delimiters is expected to be percent r literal with %r{-delimiters is expected to be percent r literal with %r/-delimiters is expected to be percent r literal #regopt with a regexp with option is expected to eq [:i, :m, :x] is expected to be regopt type with a multi-line regexp without option is expected to be empty is expected to be regopt type with a multi-line regexp with option is expected to be regopt type is expected to eq [:i, :m, :x] with a regexp without option is expected to be regopt type is expected to be empty with an empty regexp with option is expected to be regopt type is expected to eq [:i, :x] with an empty regexp is expected to be regopt type is expected to be empty #fixed_encoding? with other options is expected not to be fixed encoding with u and other options is expected to be fixed encoding with only u option is expected to be fixed encoding with no options is expected not to be fixed encoding #multiline_mode? with m and other options is expected to be multiline mode with only m option is expected to be multiline mode with other options is expected not to be multiline mode with no options is expected not to be multiline mode #interpolation? with regexp quote is expected to be interpolation with no interpolation returns false is expected not to be interpolation with direct variable interpoation is expected to be interpolation #delimiter? with multi-line %r{-delimiters is expected not to be delimiter "/" is expected not to be delimiter "%" is expected not to be delimiter "%r/" is expected not to be delimiter "%r" is expected not to be delimiter "r" is expected not to be delimiter "%r{" is expected to be delimiter "}" is expected to be delimiter "{" with /-delimiters is expected not to be delimiter "{" is expected to be delimiter "/" with %r/-delimiters is expected not to be delimiter "%" is expected not to be delimiter "%r" is expected not to be delimiter "{" is expected not to be delimiter "r" is expected not to be delimiter "}" is expected to be delimiter "/" is expected not to be delimiter "%r/" with %r{-delimiters is expected not to be delimiter "%r" is expected not to be delimiter "/" is expected not to be delimiter "%" is expected to be delimiter "}" is expected to be delimiter "{" is expected not to be delimiter "%r{" is expected not to be delimiter "%r/" is expected not to be delimiter "r" with %r<-delimiters is expected not to be delimiter "%r{" is expected to be delimiter "<" is expected to be delimiter ">" is expected not to be delimiter "{" is expected not to be delimiter "r" is expected not to be delimiter "%" is expected not to be delimiter "}" is expected not to be delimiter "%r" is expected not to be delimiter "/" is expected not to be delimiter "%r/" is expected not to be delimiter "%r<" .new is expected to be a kind of RuboCop::AST::RegexpNode #ignore_case? with only i option is expected to be ignore case with i and other options is expected to be ignore case with no options is expected not to be ignore case with other options is expected not to be ignore case #slash_literal? with /-delimiters is expected to be slash literal with %r<-delimiters is expected not to be slash literal with multi-line %r{-delimiters is expected not to be slash literal with %r/-delimiters is expected not to be slash literal with %r{-delimiters is expected not to be slash literal #extended? with x and other options is expected to be extended with no options is expected not to be extended with only x option is expected to be extended with other options is expected not to be extended RuboCop::AST::Traversal knows all current node types for example !/wat/ traverses all nodes for example def String=; end traverses all nodes for example if foo; bar; elsif baz; 1; else 2; end traverses all nodes for example module Bar::Foo; end traverses all nodes for example [*foo] traverses all nodes for example a b{c d}, 1.0r do end traverses all nodes for example m "#{[]}" traverses all nodes for example var = 10; var traverses all nodes for example meth rescue bar traverses all nodes for example proc {_1 = nil} traverses all nodes for example foo.a += m foo traverses all nodes for example [1, *foo] traverses all nodes for example case [__FILE__, __LINE__ + 1, __ENCODING__] in [__FILE__, __LINE__, __ENCODING__] end traverses all nodes for example %q{#@@1} traverses all nodes for example while class << self; tap do end; end; break; end traverses all nodes for example -> { _1 + _9} traverses all nodes for example f{ |*s| } traverses all nodes for example %{a\ b} traverses all nodes for example p <<~E E traverses all nodes for example a b(c(d)), :e do end traverses all nodes for example case foo; in x, y, then nil; end traverses all nodes for example foo === 1 traverses all nodes for example foo ** 1 traverses all nodes for example a b{c(d)}, /x/m do end traverses all nodes for example defined? foo traverses all nodes for example a, *b, c = bar traverses all nodes for example foo = meth rescue bar traverses all nodes for example bar unless foo traverses all nodes for example a b(c(d)), 1.0r do end traverses all nodes for example def foo; end traverses all nodes for example %s{a\ b} traverses all nodes for example def f ((a, *)); end traverses all nodes for example def f *, **; end traverses all nodes for example %W[#@1] traverses all nodes for example :"#@1" traverses all nodes for example fun do end traverses all nodes for example foo.(1) traverses all nodes for example f{ |a, c| } traverses all nodes for example case foo; in (1) then true; end traverses all nodes for example %{#@@1} traverses all nodes for example foo[m bar] traverses all nodes for example super traverses all nodes for example def self.foo; end traverses all nodes for example @var = 10 traverses all nodes for example case foo; in {a: } true ; end traverses all nodes for example foo::fun bar traverses all nodes for example foo < 1 traverses all nodes for example while foo do meth end traverses all nodes for example f{ |*s, &b| } traverses all nodes for example fun(*bar, &baz) traverses all nodes for example case foo; in "#{ 'a' }": 1 then true; end traverses all nodes for example case foo; in [x, y, *] then true; end traverses all nodes for example def f o=1, p, &b; end traverses all nodes for example a b{c d}, 1 do end traverses all nodes for example f{ |a, &b| } traverses all nodes for example $foo traverses all nodes for example def x(_4) end traverses all nodes for example case foo; in A::B then true; end traverses all nodes for example foo.C += raise(bar) rescue nil traverses all nodes for example foo = raise bar rescue nil traverses all nodes for example <<-`HERE` #@@1 HERE traverses all nodes for example case foo; in "#{ %Q{a} }": then true; end traverses all nodes for example unless foo then bar; else baz; end traverses all nodes for example foo::a = 1 traverses all nodes for example yield traverses all nodes for example a += 1 traverses all nodes for example p <<~E x y E traverses all nodes for example foo && bar traverses all nodes for example foo (-1.3).abs traverses all nodes for example begin meth end while foo traverses all nodes for example :foo traverses all nodes for example :'#@@1' traverses all nodes for example case foo; when 'bar'; bar; else baz; end traverses all nodes for example meth while foo traverses all nodes for example (foo, bar) = 1, 2 traverses all nodes for example "#@1" traverses all nodes for example p <<~E x \ y E traverses all nodes for example def foo raise; raise A::B, ''; end traverses all nodes for example m def x(); end; 1.tap do end traverses all nodes for example p begin 1.times do 1 end end traverses all nodes for example %i[foo bar] traverses all nodes for example break(foo) traverses all nodes for example p <<~"E" x #{foo} E traverses all nodes for example foo[0, 1] &&= 2 traverses all nodes for example case foo; in [x, y, *z] then true; end traverses all nodes for example def foo a:b end traverses all nodes for example :"#@@1" traverses all nodes for example def String.foo; end traverses all nodes for example p -> { :hello }, a: 1 do end traverses all nodes for example def f ((*r, p)); end traverses all nodes for example p ->() do a() do end end traverses all nodes for example foo = bar = m foo traverses all nodes for example <<`HERE` foo bar HERE traverses all nodes for example f{ |a, *s| } traverses all nodes for example foo && (a, b = bar) traverses all nodes for example case foo; in 1, "a", [], {} then nil; end traverses all nodes for example foo "#{(1+1).to_i}" do; end traverses all nodes for example { 'foo': 2 } traverses all nodes for example case foo; in {a: 2} false ; end traverses all nodes for example %s{#@@1} traverses all nodes for example /\xa8/n =~ "" traverses all nodes for example p <<~E x y E traverses all nodes for example # coding:utf-8 "\xD0\xBF\xD1\x80\xD0\xBE\xD0\xB2\xD0\xB5\xD1\x80\xD0\xBA\xD0\xB0" traverses all nodes for example foo * 1 traverses all nodes for example a b{c d}, /x/m do end traverses all nodes for example yield foo traverses all nodes for example p <<~`E` x #{foo} E traverses all nodes for example a b(c(d)), 1.0 do end traverses all nodes for example if (bar; a, b = foo); end traverses all nodes for example foo.fun bar traverses all nodes for example meth until foo traverses all nodes for example foo[1, 2] = 3 traverses all nodes for example def f ((*, p)); end traverses all nodes for example case foo; when 'bar' then bar; end traverses all nodes for example foo / 1 traverses all nodes for example p <<~"E" x #{" y"} E traverses all nodes for example def f ((a, *r)); end traverses all nodes for example "#{-> foo {}}" traverses all nodes for example fun(*bar) traverses all nodes for example false ? raise do end : tap do end traverses all nodes for example f{ |o=1, &b| } traverses all nodes for example def m; class << self; class C; end; end; end traverses all nodes for example -> * { } traverses all nodes for example f{ |;a| } traverses all nodes for example unless foo; bar; else baz; end traverses all nodes for example break() traverses all nodes for example foo += m foo traverses all nodes for example def foo(...); bar(...); end traverses all nodes for example `#@@1` traverses all nodes for example foo, bar, baz = 1, 2 traverses all nodes for example `a\ b` traverses all nodes for example -> do _1 + _9 end traverses all nodes for example foo::a += 1 traverses all nodes for example fun (f bar) traverses all nodes for example f(a ? "a":1) traverses all nodes for example def self.m; _1; end traverses all nodes for example fun(f bar) traverses all nodes for example while def self.foo; tap do end; end; break; end traverses all nodes for example def m; class << self; A = nil; end; end traverses all nodes for example @a |= 1 traverses all nodes for example 1.33 traverses all nodes for example f{ |&b| } traverses all nodes for example retry traverses all nodes for example a b{c(d)}, 1.0i do end traverses all nodes for example <<-'HERE' a\ b HERE traverses all nodes for example break foo traverses all nodes for example f{ |*| } traverses all nodes for example module A; _1; end traverses all nodes for example f{ |a| } traverses all nodes for example <<-`HERE` a\ b HERE traverses all nodes for example foo, bar = 1, 2 traverses all nodes for example def f **baz, &b; end traverses all nodes for example foo & 1 traverses all nodes for example return foo traverses all nodes for example class << foo; _1; end traverses all nodes for example def foo(_a, _a); end traverses all nodes for example return fun foo do end traverses all nodes for example foo.a = 1 traverses all nodes for example f{ |*r, p, &b| } traverses all nodes for example f{ |a, *, &b| } traverses all nodes for example case foo; in "#{ 'a' }": then true; end traverses all nodes for example case foo; in a:, b: then true; end traverses all nodes for example def f ((*r)); end traverses all nodes for example fun (1).to_i traverses all nodes for example def f(**); end traverses all nodes for example td (1_500).toString(); td.num do; end traverses all nodes for example super() traverses all nodes for example def f ; end traverses all nodes for example a b(c d), 1 do end traverses all nodes for example ..100 traverses all nodes for example fun(1) traverses all nodes for example foo <= 1 traverses all nodes for example foo[0, 1] += m foo traverses all nodes for example case foo; in "a": 1 then true; end traverses all nodes for example class Foo < Bar; end traverses all nodes for example case foo; in x unless true; nil; end traverses all nodes for example foo.A += m foo traverses all nodes for example def f(**nil); end traverses all nodes for example :'foo' traverses all nodes for example begin; meth; rescue; foo; else; bar; end traverses all nodes for example case foo; in ::A then true; end traverses all nodes for example %I() traverses all nodes for example while def self.foo a = tap do end; end; break; end traverses all nodes for example *, c, d = bar traverses all nodes for example %x{#@1} traverses all nodes for example [1, *foo, 2] traverses all nodes for example def f ((a, *, p)); end traverses all nodes for example [ 1, 2 => 3 ] traverses all nodes for example defined?(foo) traverses all nodes for example a += b += raise :x traverses all nodes for example %W"#{1}" traverses all nodes for example a b(c(d)), 1 do end traverses all nodes for example proc {_1 = nil} traverses all nodes for example f{ |a, o=1, &b| } traverses all nodes for example case foo; in self then true; end traverses all nodes for example true traverses all nodes for example foo[1, 2] traverses all nodes for example case foo; in {} then true; end traverses all nodes for example if foo; bar; end traverses all nodes for example begin ensure end traverses all nodes for example def foo(...); end traverses all nodes for example END { 1 } traverses all nodes for example f{ |foo: 1, &b| } traverses all nodes for example { 1 => 2 } traverses all nodes for example foo.a ||= 1 traverses all nodes for example case foo; in a: 1, b: 2 then true; end traverses all nodes for example Foo = 10 traverses all nodes for example 42i traverses all nodes for example if foo then bar; end traverses all nodes for example case foo; in A(1, 2) then true; end traverses all nodes for example < proc do end, b: proc do end} traverses all nodes for example desc "foo" do end traverses all nodes for example f{ |a, *s, &b| } traverses all nodes for example p <<~E E traverses all nodes for example case foo; in [x, *, y] then true; end traverses all nodes for example f{ |a, o=1, *r, p, &b| } traverses all nodes for example def a; @@var |= 10; end traverses all nodes for example until foo; meth end traverses all nodes for example a b(c d), /x/m do end traverses all nodes for example foo[:baz => 1,] traverses all nodes for example m { |**nil| } traverses all nodes for example %i[] traverses all nodes for example def f o=1, *r, p, &b; end traverses all nodes for example super foo traverses all nodes for example true ? 1.tap do |n| p n end : 0 traverses all nodes for example foo, bar = meth rescue [1, 2] traverses all nodes for example def f o=1, *r, &b; end traverses all nodes for example def f a, &b; end traverses all nodes for example a b(c(d)), /x/ do end traverses all nodes for example begin; meth; rescue Exception; bar; end traverses all nodes for example nil traverses all nodes for example fun (1) traverses all nodes for example foo += meth rescue bar traverses all nodes for example m do _1 + _9 end traverses all nodes for example f (g rescue nil) traverses all nodes for example foo&.bar {} traverses all nodes for example f{ |foo: 1, bar: 2, **baz, &b| } traverses all nodes for example a = b += raise :x traverses all nodes for example case foo; in 1 => a then true; end traverses all nodes for example 1.. traverses all nodes for example def f(foo); end traverses all nodes for example f{ |o=1, *r, p, &b| } traverses all nodes for example fun traverses all nodes for example `#@1` traverses all nodes for example case foo; in A[x:] then true; end traverses all nodes for example m ->(a: ->{_1}) {a} traverses all nodes for example def f foo = 1; end traverses all nodes for example a&.b traverses all nodes for example [/()\1/, ?#] traverses all nodes for example a b{c d}, 1.0i do end traverses all nodes for example 42ri traverses all nodes for example %i[ #@1 ] traverses all nodes for example until foo do meth end traverses all nodes for example foo::Fun bar traverses all nodes for example yield(foo) traverses all nodes for example ->(a; foo, bar) { } traverses all nodes for example if foo..bar; end traverses all nodes for example class Foo end traverses all nodes for example a # # &.foo traverses all nodes for example !foo traverses all nodes for example :'a\ b' traverses all nodes for example `foobar` traverses all nodes for example foo traverses all nodes for example m ->(a = ->{_1}) {a} traverses all nodes for example super(foo) traverses all nodes for example def self::foo; end traverses all nodes for example case foo; in x, y then nil; end traverses all nodes for example fun(1) { } traverses all nodes for example return traverses all nodes for example begin foo!; bar! end traverses all nodes for example while def foo; tap do end; end; break; end traverses all nodes for example %{#@1} traverses all nodes for example $10 traverses all nodes for example /#{1}(?bar)/ =~ 'bar' traverses all nodes for example foo != 1 traverses all nodes for example -2.0 ** 10 traverses all nodes for example %i{a\ b} traverses all nodes for example foo::fun traverses all nodes for example __LINE__ traverses all nodes for example p <<~E " y" x E traverses all nodes for example alias $a $+ traverses all nodes for example def foo(...); bar(...); end traverses all nodes for example %r{#@1} traverses all nodes for example case foo; in 1 | 2 then true; end traverses all nodes for example if foo then bar end traverses all nodes for example let (:a) { m do; end } traverses all nodes for example foo += raise bar rescue nil traverses all nodes for example case foo; in { a: 1, } then true; end traverses all nodes for example f{ |**baz, &b| } traverses all nodes for example %I[#@@1] traverses all nodes for example 'foobar' traverses all nodes for example '#@1' traverses all nodes for example BEGIN { 1 } traverses all nodes for example fun (1 ) traverses all nodes for example case foo; in **nil then true; end traverses all nodes for example bar def foo; self.each do end end traverses all nodes for example a # # .foo traverses all nodes for example foo += raise(bar) rescue nil traverses all nodes for example fun! traverses all nodes for example def _5; end traverses all nodes for example %x{a\ b} traverses all nodes for example a b(c d), /x/ do end traverses all nodes for example foo::a += m foo traverses all nodes for example p <<~E x y E traverses all nodes for example case foo; in ..2 then true; end traverses all nodes for example next foo traverses all nodes for example %w[foo bar] traverses all nodes for example !(foo..bar) traverses all nodes for example %r{#@@1} traverses all nodes for example a b{c d}, :e do end traverses all nodes for example p <<~E x \ y E traverses all nodes for example foo::C ||= raise(bar) rescue nil traverses all nodes when a class defines `on_block_pass` calls it for all block-pass arguments for example p <<~"E" x\n y E traverses all nodes for example a b{c(d)}, 1.0 do end traverses all nodes for example "#@@1" traverses all nodes for example { foo: 2, **bar } traverses all nodes for example while class Foo a = tap do end; end; break; end traverses all nodes for example def self._6; end traverses all nodes for example a b(c d), 1.0i do end traverses all nodes for example next fun foo do end traverses all nodes for example _2 = 1 traverses all nodes for example 1...2 traverses all nodes for example fun (1) {} traverses all nodes for example while not (true) do end traverses all nodes for example %Q{#@1} traverses all nodes for example a b(c d), 1.0r do end traverses all nodes for example m a + b do end traverses all nodes for example { 'foo': 2, 'bar': {}} traverses all nodes for example case foo; in [*x, y] then true; end traverses all nodes for example not(foo) traverses all nodes for example f{ |a, *| } traverses all nodes for example ::A += 1 traverses all nodes for example { foo: 2 } traverses all nodes for example module Foo; end traverses all nodes for example fun() { } traverses all nodes for example def f(&block); end traverses all nodes for example ->{ } traverses all nodes for example fun(foo, :foo => 1) traverses all nodes for example def foo(...); super(...); end traverses all nodes for example %q(foobar) traverses all nodes for example def String; end traverses all nodes for example <<-'HERE' #@1 HERE traverses all nodes for example foo and bar traverses all nodes for example /foo#{bar}baz/ traverses all nodes for example false traverses all nodes for example o = { a: 1 } traverses all nodes for example def f(*foo); end traverses all nodes for example %i[ #@@1 ] traverses all nodes for example foo.C += raise bar rescue nil traverses all nodes for example %Q{a\ b} traverses all nodes for example { 1 => 2, :foo => "bar" } traverses all nodes for example foo[0] += raise(bar) rescue nil traverses all nodes for example foo % 1 traverses all nodes for example class Foo; end traverses all nodes for example foo.m += raise(bar) rescue nil traverses all nodes for example begin; meth; rescue; baz; ensure; bar; end traverses all nodes for example 1... traverses all nodes for example case foo; in ...2 then true; end traverses all nodes for example foo == 1 traverses all nodes for example meth 1 do end::fun bar traverses all nodes for example case foo; in A() then true; end traverses all nodes for example B::A += 1 traverses all nodes for example * = bar traverses all nodes for example %x{#@@1} traverses all nodes for example case foo; in ^foo then nil; end traverses all nodes for example foo[bar,] traverses all nodes for example lambda{|;a|a} traverses all nodes for example m { |foo| } traverses all nodes for example <<-"HERE" a\ b HERE traverses all nodes for example case foo; in a: 1 then true; end traverses all nodes for example for a in foo do p a; end traverses all nodes for example __FILE__ traverses all nodes for example if (a, b = foo); end traverses all nodes for example def f foo: ; end traverses all nodes for example <<-`HERE` #@1 HERE traverses all nodes for example case foo; in "#{ %Q{a} }": 1 then true; end traverses all nodes for example foo >= 1 traverses all nodes for example %W[foo #{bar}] traverses all nodes for example super foo, bar do end traverses all nodes for example /a\ b/ traverses all nodes for example f{ || } traverses all nodes for example case foo; in {a: 1 } false ; end traverses all nodes for example def f o=1, &b; end traverses all nodes for example %W[#@@1] traverses all nodes for example a b{c d}, 1.0 do end traverses all nodes for example f x: -> do meth do end end traverses all nodes for example !(a, b = foo) traverses all nodes for example foo[1, 2] traverses all nodes for example def f (foo: 1, bar: 2, **baz, &b); end traverses all nodes for example if foo then bar; else baz; end traverses all nodes for example self::a, foo = foo traverses all nodes for example case 1; in 2; 3; else; 4; end traverses all nodes for example case foo; in "#{ %q{a} }": then true; end traverses all nodes for example !m foo traverses all nodes for example %W{a\ b} traverses all nodes for example meth 1 do end.fun bar traverses all nodes for example unless foo; bar; end traverses all nodes for example {a: if true then 42 end} traverses all nodes for example case foo; when 1, *baz; bar; when *foo; end traverses all nodes for example def f (((a))); end traverses all nodes for example alias :foo bar traverses all nodes for example meth (-1.3).abs traverses all nodes for example @foo traverses all nodes for example +2.0 ** 10 traverses all nodes for example a b{c d}, "x" do end traverses all nodes for example foo.A = 1 traverses all nodes for example p :foo, {** proc do end, b: proc do end} traverses all nodes for example next(foo) traverses all nodes for example Bar::Foo = 10 traverses all nodes for example break traverses all nodes for example ::Foo = 10 traverses all nodes for example @foo, @@bar = *foo traverses all nodes for example @@var |= 10 traverses all nodes for example if foo...bar; end traverses all nodes for example %Q{#@@1} traverses all nodes for example foo | 1 traverses all nodes for example <<-"HERE" #@@1 HERE traverses all nodes for example while class << self; a = tap do end; end; break; end traverses all nodes for example A += 1 traverses all nodes for example case foo; in ->{ 42 } then true; end traverses all nodes for example case foo; in 1...2 then true; end traverses all nodes for example false ? raise {} : tap {} traverses all nodes for example not m foo traverses all nodes for example ::Foo traverses all nodes for example a &&= 1 traverses all nodes for example # Extracted from `parser` gem. # Add the following code at the beginning of `def assert_parses`: # # File.open('./out.rb', 'a+') do |f| # f << code << "\n\n#----\n" if versions.include? '2.7' # end alias $a $b traverses all nodes for example m "#{}#{()}" traverses all nodes for example foo.fun (1) {} traverses all nodes for example begin meth end until foo traverses all nodes for example "#{1}" traverses all nodes for example defined? @foo traverses all nodes for example begin; rescue LoadError; else; end traverses all nodes for example ((b, )) = foo traverses all nodes for example f{ |a| } traverses all nodes for example def m; class << self; module M; end; end; end traverses all nodes for example foo << 1 traverses all nodes for example begin; meth; rescue => ex; bar; end traverses all nodes for example case foo; in x then x; end traverses all nodes for example case foo; in 1.. then true; end traverses all nodes for example def f ((a, a1)); end traverses all nodes for example f <<-TABLE do TABLE end traverses all nodes for example foo + 1 traverses all nodes for example fun(foo, *bar, &baz) traverses all nodes for example meth 1 do end::fun(bar) traverses all nodes for example /(?bar)/ =~ 'bar'; match traverses all nodes for example foo >> 1 traverses all nodes for example ->(scope) {}; scope traverses all nodes for example /#)/x traverses all nodes for example foo::fun (1) {} traverses all nodes for example def f(foo:); end traverses all nodes for example m { |(foo, bar)| } traverses all nodes for example a b{c(d)}, :e do end traverses all nodes for example a b{c d}, /x/ do end traverses all nodes for example foo or bar traverses all nodes for example case foo; in A[1, 2] then true; end traverses all nodes for example p <<~E x y E traverses all nodes for example 42r traverses all nodes for example foo, bar = m foo traverses all nodes for example fun { } traverses all nodes for example def f(foo: 1); end traverses all nodes for example ...100 traverses all nodes for example a b(c d), 1.0 do end traverses all nodes for example p :foo, {:a => proc do end, b: proc do end} traverses all nodes for example next traverses all nodes for example self.a, self[1, 2] = foo traverses all nodes for example def f(foo, bar); end traverses all nodes for example fun(&bar) traverses all nodes for example module ::Foo; end traverses all nodes for example %q{a\ b} traverses all nodes for example def foo() a:b end traverses all nodes for example !(foo...bar) traverses all nodes for example def f a, o=1, p, &b; end traverses all nodes for example case; when foo; 'foo'; end traverses all nodes for example :"foo#{bar}baz" traverses all nodes for example foo = bar, 1 traverses all nodes for example foo !~ 1 traverses all nodes for example case foo; in *x, y, z then nil; end traverses all nodes for example case foo; in A then true; end traverses all nodes for example while class Foo; tap do end; end; break; end traverses all nodes for example case foo; in [x,] then nil; end traverses all nodes for example foo <=> 1 traverses all nodes for example foo || (a, b = bar) traverses all nodes for example foo > 1 traverses all nodes for example %w[] traverses all nodes for example self::A, foo = foo traverses all nodes for example m1 :k => m2 do; m3() do end; end traverses all nodes for example a = b = raise :x traverses all nodes for example undef foo, :bar, :"foo#{1}" traverses all nodes for example Foo traverses all nodes for example a b{c(d)}, 1.0r do end traverses all nodes for example redo traverses all nodes for example case foo; in "#{ %q{a} }": 1 then true; end traverses all nodes for example case foo; in "a": then true; end traverses all nodes for example f { || a:b } traverses all nodes for example _1 traverses all nodes for example foo =~ 1 traverses all nodes for example 42.1r traverses all nodes for example ->{ } traverses all nodes for example while def foo a = tap do end; end; break; end traverses all nodes for example tap (proc do end) traverses all nodes for example -2 ** 10 traverses all nodes for example a ||= 1 traverses all nodes for example fun(:foo => 1) traverses all nodes for example let () { m(a) do; end } traverses all nodes for example if foo; bar; else baz; end traverses all nodes for example 42 traverses all nodes for example @@var = 10 traverses all nodes for example case foo; in *x then nil; end traverses all nodes for example return(foo) traverses all nodes for example foo ? 1 : 2 traverses all nodes for example t=1;(foo)?t:T traverses all nodes for example foo.fun traverses all nodes for example $+ traverses all nodes for example foo ^ 1 traverses all nodes for example %W[foo #{bar}foo#@baz] traverses all nodes for example foo::m += raise(bar) rescue nil traverses all nodes for example f{ |o=1, *r, &b| } traverses all nodes for example assert do: true traverses all nodes for example case foo; in **a then true; end traverses all nodes for example if (bar); foo; end traverses all nodes for example '#@@1' traverses all nodes for example [1, 2] traverses all nodes for example case foo; in A(x:) then true; end traverses all nodes for example "foo#@a" "bar" traverses all nodes for example yield() traverses all nodes for example foo = baz, *bar traverses all nodes for example -foo traverses all nodes for example p <<~E x E traverses all nodes for example m { _1 + _9 } traverses all nodes for example fun () {} traverses all nodes for example def f foo: -1 ; end traverses all nodes for example case foo; when 'bar'; bar; end traverses all nodes for example <<-'HERE' #@@1 HERE traverses all nodes for example p :foo, {"a": proc do end, b: proc do end} traverses all nodes for example def f &b; end traverses all nodes for example a = 1; a b: 1 traverses all nodes for example foo::m += raise bar rescue nil traverses all nodes for example while foo; meth end traverses all nodes for example fun(:foo => 1, &baz) traverses all nodes for example unless foo then bar; end traverses all nodes for example /source/im traverses all nodes for example begin; meth; rescue foo => ex; bar; end traverses all nodes for example case foo; in [x, *y, z] then true; end traverses all nodes for example /#@@1/ traverses all nodes for example 42.1i traverses all nodes for example f{ |a, o=1, o1=2, *r, &b| } traverses all nodes for example %I{a\ b} traverses all nodes for example traverses all nodes for example fun(foo, :foo => 1, &baz) traverses all nodes for example case; when foo; 'foo'; else 'bar'; end traverses all nodes for example :"a\ b" traverses all nodes for example `foo#{bar}baz` traverses all nodes for example <<~E 1 \ 2 3 E traverses all nodes for example a ? b & '': nil traverses all nodes for example proc {|_3|} traverses all nodes for example ::A, foo = foo traverses all nodes for example def BEGIN; end traverses all nodes for example def f a, o=1, &b; end traverses all nodes for example def foo(_, _); end traverses all nodes for example begin; meth; ensure; bar; end traverses all nodes for example def (foo).foo; end traverses all nodes for example foo::C ||= raise bar rescue nil traverses all nodes for example a b(c(d)), 1.0i do end traverses all nodes for example foo[bar, :baz => 1,] traverses all nodes for example -> (arg={}) {} traverses all nodes for example for a in foo; p a; end traverses all nodes when a class defines on_arg calls it for all arguments for example case foo; in A[] then true; end traverses all nodes for example a @b do |c|;end traverses all nodes for example fun(foo, *bar) traverses all nodes for example def END; end traverses all nodes for example -> do rescue; end traverses all nodes for example a += b = raise :x traverses all nodes for example def f a, *r, p, &b; end traverses all nodes for example bar if foo traverses all nodes for example 'a\ b' traverses all nodes for example Bar::Foo traverses all nodes for example p <<~E x y E traverses all nodes for example foo = *bar traverses all nodes for example def String::foo; end traverses all nodes for example a, *b = bar traverses all nodes for example def f(*); end traverses all nodes for example __ENCODING__ traverses all nodes for example f{ |foo:| } traverses all nodes for example case foo; in ** then true; end traverses all nodes for example foo[1, 2] = 3 traverses all nodes for example assert dogs traverses all nodes for example a, (b, c) = foo traverses all nodes for example foo.a &&= 1 traverses all nodes for example f{ |o=1, p, &b| } traverses all nodes for example f{ |a| } traverses all nodes for example foo.m += raise bar rescue nil traverses all nodes for example %w[ #@@1 ] traverses all nodes for example %s{#@1} traverses all nodes for example def f a, o=1, *r, &b; end traverses all nodes for example m [], 1 do end traverses all nodes for example case foo; in [x] then nil; end traverses all nodes for example f{ |a,| } traverses all nodes for example def f a, o=1, *r, p, &b; end traverses all nodes for example %W() traverses all nodes for example case foo; in x, *y, z then nil; end traverses all nodes for example foo = m foo traverses all nodes for example m = -> *args do end traverses all nodes for example <<'HERE' foo bar HERE traverses all nodes for example %r{a\ b} traverses all nodes for example a b(c d), "x" do end traverses all nodes for example begin end traverses all nodes for example foo || bar traverses all nodes for example class A < B end traverses all nodes when given an unexpected AST with too many children raises debugging error with too few children raises debugging error for example return() traverses all nodes for example case foo; in a: 1, _a:, ** then true; end traverses all nodes for example %I[foo #{bar}] traverses all nodes for example begin; meth; rescue; baz; else foo; ensure; bar end traverses all nodes for example class A; _1; end traverses all nodes for example break fun foo do end traverses all nodes for example begin; meth; rescue Exception, foo; bar; end traverses all nodes for example a&.b &&= 1 traverses all nodes for example *b = bar traverses all nodes for example "foo#{bar}baz" traverses all nodes for example meth 1 do end.fun bar do end traverses all nodes for example /#@1/ traverses all nodes for example case foo; in 1..2 then true; end traverses all nodes for example def f(foo=1, bar=2); end traverses all nodes for example begin; meth; rescue; foo; end traverses all nodes for example def a b: return end traverses all nodes for example -1.33 traverses all nodes for example %w[ #@1 ] traverses all nodes for example def until; end traverses all nodes for example f{ } traverses all nodes for example 1..2 traverses all nodes for example -42 traverses all nodes for example case 1; in 2; 3; else; end traverses all nodes for example next() traverses all nodes for example foo - 1 traverses all nodes for example case foo; in [*, x] then true; end traverses all nodes for example for a, b in foo; p a, b; end traverses all nodes for example :'#@1' traverses all nodes for example def f *r, &b; end traverses all nodes for example ->(**nil) {} traverses all nodes for example case foo; in 1... then true; end traverses all nodes for example class << foo; nil; end traverses all nodes for example <<-E 1 \ 2 3 E traverses all nodes for example a # # &.foo traverses all nodes for example def f a, *r, &b; end traverses all nodes for example self traverses all nodes for example -> do end traverses all nodes for example foo::Fun() traverses all nodes for example %I[#@1] traverses all nodes for example foo.a += 1 traverses all nodes for example $var = 10 traverses all nodes for example 1 in [a]; a traverses all nodes for example "a\ b" traverses all nodes for example begin; meth; rescue => @ex; bar; end traverses all nodes for example @@foo traverses all nodes for example case foo; in [x, y,] then true; end traverses all nodes for example f{ |a, *r, p, &b| } traverses all nodes for example ->(a) { } traverses all nodes for example a b(c(d)), /x/m do end traverses all nodes for example def f(**foo); end traverses all nodes for example case foo; in * then nil; end traverses all nodes for example a # # .foo traverses all nodes for example foo = raise(bar) rescue nil traverses all nodes for example { } traverses all nodes for example foo[0, 1] ||= 2 traverses all nodes for example case foo; in { a: 1 } then true; end traverses all nodes for example self.A, foo = foo traverses all nodes for example not foo traverses all nodes for example a&.b = 1 traverses all nodes for example case foo; in a: then true; end traverses all nodes for example meth 1 do end.fun(bar) traverses all nodes for example def f *r, p, &b; end traverses all nodes for example f{ |; a | } traverses all nodes for example super do end traverses all nodes for example case foo; in x if true; nil; end traverses all nodes for example *b, c = bar traverses all nodes for example class Foo < a:b; end traverses all nodes for example def x; ::A ||= 1; end traverses all nodes for example case foo; in x, then nil; end traverses all nodes for example a b{c(d)}, /x/ do end traverses all nodes for example p <<~E x y E traverses all nodes for example if /wat/; end traverses all nodes for example p :foo, {a: proc do end, b: proc do end} traverses all nodes for example %w{a\ b} traverses all nodes for example %q{#@1} traverses all nodes for example foo[0, 1] += 2 traverses all nodes for example a b{c(d)}, "x" do end traverses all nodes for example def foo =begin =end end traverses all nodes for example "#@a #@@a #$a" traverses all nodes for example f{ |*, &b| } traverses all nodes for example case foo; in [x, y] then true; end traverses all nodes for example case foo; when 'bar', 'baz'; bar; end traverses all nodes for example meth 1 do end.fun {} traverses all nodes for example p p{p(p);p p}, tap do end traverses all nodes for example m [] do end traverses all nodes for example f{ |a, o=1, p, &b| } traverses all nodes for example foo::A = 1 traverses all nodes for example a, * = bar traverses all nodes for example -> a: 1 { } traverses all nodes for example foo::A += m foo traverses all nodes for example meth[] {} traverses all nodes for example meth 1 do end.fun(bar) {} traverses all nodes for example a b{c(d)}, 1 do end traverses all nodes for example def f ((*)); end traverses all nodes for example a b(c d), :e do end traverses all nodes for example meth do; foo; rescue; bar; end traverses all nodes for example -> a: { } traverses all nodes for example ?a traverses all nodes for example 42.1ri traverses all nodes for example case foo; in 1; end traverses all nodes for example ~foo traverses all nodes for example foo.A += 1 traverses all nodes for example f{ | | } traverses all nodes for example [ 1 => 2 ] traverses all nodes for example foo[0] += raise bar rescue nil traverses all nodes for example foo::(1) traverses all nodes for example case foo; in {Foo: 42 } false ; end traverses all nodes for example %I[foo#{bar}] traverses all nodes for example () traverses all nodes for example a, *, c = bar traverses all nodes for example def x; self::A ||= 1; end traverses all nodes for example def f ((a, *r, p)); end traverses all nodes for example a b(c(d)), "x" do end traverses all nodes for example __ENCODING__ traverses all nodes for example def f (foo: 1, &b); end traverses all nodes for example p <<~E x y E traverses all nodes for example -> (a) { } traverses all nodes for example <<~FOO baz\ qux FOO traverses all nodes for example a, b = *foo, bar traverses all nodes for example +42 traverses all nodes for example f{ |a, b,| } traverses all nodes for example +foo traverses all nodes for example <<-"HERE" #@1 HERE traverses all nodes for example case foo; in a: {b:}, c: p c ; end traverses all nodes RuboCop::AST::NodePattern negation on square brackets with a node which meets all requirements of [] behaves like nonmatching doesn't match with a node which meets only 1 requirement of [] is expected to match code 1 on a string with a matching string behaves like nonmatching doesn't match with a non-matching symbol is expected to match code s(:str, "bar") and :upcase when nested in complex ways with (send str :+ (send str :to_i)) is expected to match code s(:str, "abc"), :+, and s(:send, s(:str, "1"), :to_i) with (send str :<< str) behaves like nonmatching doesn't match with (send int :- int) is expected to match code s(:int, 1), :-, and s(:int, 1) on a set with a matching value behaves like nonmatching doesn't match with a non-matching value is expected to match code :@a and s(:int, 3) on a symbol with a matching symbol behaves like nonmatching doesn't match with a non-matching symbol, but too many children behaves like nonmatching doesn't match with a non-matching symbol is expected to match code s(:send, nil, :obj) and :xyz on a sequence with a node with non-matching children is expected to match code :@b and s(:int, 1) with a node of different type is expected to match code :@@a and s(:int, 1) with a matching node behaves like nonmatching doesn't match bad syntax with negated closing curly behaves like invalid is invalid with unmatched closing paren behaves like invalid is invalid with unmatched closing curly behaves like invalid is invalid with doubled comma in arg list behaves like invalid is invalid with unmatched opening paren behaves like invalid is invalid with empty intersection behaves like invalid is invalid with negated closing paren behaves like invalid is invalid with leading comma in arg list behaves like invalid is invalid with empty parentheses behaves like invalid is invalid with empty union behaves like invalid is invalid with doubled ellipsis is expected to match code "foo" with unmatched opening curly behaves like invalid is invalid with variadic unions where not supported behaves like invalid is invalid with empty union subsequence in seq head behaves like invalid is invalid with negated ellipsis behaves like invalid is invalid with unsupported subsequence in seq head within union behaves like invalid is invalid with unmatched opening paren and `...` behaves like invalid is invalid descend with an immediate match behaves like single capture returns captured values if there is no block yields captured value(s) and returns true if there is a block with a literal match is expected to match code s(:int, 1) and s(:array, s(:array, s(:int, 2), s(:int, 3), s(:array, s(:array, s(:int, 5)))), s(:int, 4)) with a match multiple levels, depth first behaves like single capture returns captured values if there is no block yields captured value(s) and returns true if there is a block without match behaves like nonmatching doesn't match nested behaves like single capture yields captured value(s) and returns true if there is a block returns captured values if there is no block sequence with trailing ... on a node with the same type and exact number of children is expected to match code s(:int, 1) and :blah on a node with the same type and fewer children behaves like nonmatching doesn't match on a node with fewer children, with a wildcard preceding behaves like nonmatching doesn't match on a node with the same type and more children with 1 child more is expected to match code s(:int, 1), :blah, and s(:int, 1) with 2 children more is expected to match code s(:int, 1), :blah, s(:int, 1), and s(:sym, :something) on a node with non-matching children behaves like nonmatching doesn't match on a node with a different type behaves like nonmatching doesn't match captures which also perform a match on a literal behaves like single capture returns captured values if there is no block yields captured value(s) and returns true if there is a block when nested behaves like multiple capture returns captured values if there is no block yields captured value(s) and returns true if there is a block on a node type behaves like single capture yields captured value(s) and returns true if there is a block returns captured values if there is no block on a set behaves like single capture returns captured values if there is no block yields captured value(s) and returns true if there is a block on [] behaves like single capture returns captured values if there is no block yields captured value(s) and returns true if there is a block on a sequence behaves like single capture yields captured value(s) and returns true if there is a block returns captured values if there is no block repeated using ? with zero match behaves like single capture yields captured value(s) and returns true if there is a block returns captured values if there is no block with too many matching children behaves like nonmatching doesn't match behaves like repeated pattern at beginning of sequence behaves like invalid is invalid with one match behaves like single capture yields captured value(s) and returns true if there is a block returns captured values if there is no block with an ellipsis in the same sequence is expected to match code "[:hello, 1, 2, 3]" using + behaves like repeated pattern at beginning of sequence behaves like invalid is invalid with an ellipsis in the same sequence is expected to match code "[:hello, 1, 2, 3]" with one match behaves like single capture yields captured value(s) and returns true if there is a block returns captured values if there is no block with zero match behaves like nonmatching doesn't match with matching children behaves like single capture returns captured values if there is no block yields captured value(s) and returns true if there is a block using * behaves like repeated pattern with an ellipsis in the same sequence is expected to match code "[:hello, 1, 2, 3]" at beginning of sequence behaves like invalid is invalid with one match behaves like single capture returns captured values if there is no block yields captured value(s) and returns true if there is a block nested with multiple subcaptures behaves like multiple capture yields captured value(s) and returns true if there is a block returns captured values if there is no block with multiple subcaptures behaves like multiple capture yields captured value(s) and returns true if there is a block returns captured values if there is no block with zero match behaves like single capture returns captured values if there is no block yields captured value(s) and returns true if there is a block without capture is expected to match code s(:sym, :hello), s(:int, 1), s(:int, 2), and s(:int, 3) with matching children behaves like single capture yields captured value(s) and returns true if there is a block returns captured values if there is no block with no match behaves like nonmatching doesn't match bare node type #pattern returns the pattern yaml compatibility is expected to match code s(:send, nil, :obj) and :method #== returns true iff the patterns are similar on a node with the same type is expected to match code s(:send, nil, :obj) and :method on a node with a matching, hyphenated type is expected to match code s(:lvasgn, :a), :+, and s(:int, 1) #to_s is instructive marshal compatibility is expected to match code s(:send, nil, :obj) and :method on a node with a different type behaves like nonmatching doesn't match #dup is expected to match code s(:send, nil, :obj) and :method captures on ... with a remaining [] at the end behaves like single capture returns captured values if there is no block yields captured value(s) and returns true if there is a block with a remaining set at the end behaves like single capture yields captured value(s) and returns true if there is a block returns captured values if there is no block after a child behaves like single capture returns captured values if there is no block yields captured value(s) and returns true if there is a block with a remaining capture at the end behaves like multiple capture yields captured value(s) and returns true if there is a block returns captured values if there is no block with a remaining wildcard at the end behaves like single capture yields captured value(s) and returns true if there is a block returns captured values if there is no block with remaining patterns at the end behaves like single capture returns captured values if there is no block yields captured value(s) and returns true if there is a block at the very beginning of a sequence behaves like single capture yields captured value(s) and returns true if there is a block returns captured values if there is no block with a remaining sequence at the end behaves like single capture yields captured value(s) and returns true if there is a block returns captured values if there is no block with a remaining node type at the end behaves like single capture yields captured value(s) and returns true if there is a block returns captured values if there is no block with no remaining pattern at the end behaves like single capture returns captured values if there is no block yields captured value(s) and returns true if there is a block with a remaining literal at the end behaves like single capture returns captured values if there is no block yields captured value(s) and returns true if there is a block node type in seq head on a node with the same type is expected to match code s(:ivar, :@ivar), :+, and s(:int, 2) on a child with a different type behaves like nonmatching doesn't match for a child on a child with a different type behaves like nonmatching doesn't match on a child with the same type is expected to match code s(:send, nil, :foo) and :bar on a child litteral behaves like nonmatching doesn't match captures within union on simple subpatterns behaves like single capture yields captured value(s) and returns true if there is a block returns captured values if there is no block within nested sequences behaves like multiple capture yields captured value(s) and returns true if there is a block returns captured values if there is no block with a different number of captures in each branch behaves like invalid is invalid with complex nesting behaves like multiple capture yields captured value(s) and returns true if there is a block returns captured values if there is no block predicates when captured behaves like single capture yields captured value(s) and returns true if there is a block returns captured values if there is no block applied to an integer for which the predicate is true is expected to match code s(:int, 1) and :inc with multiple arguments for which the predicate is false behaves like nonmatching doesn't match for which the predicate is true is expected to match code s(:str, "c"), "a", and "d" at head position of a sequence is expected to match code s(:int, 1) and :inc when in last-child position, but all children have already been matched behaves like nonmatching doesn't match with a named argument for which the predicate is false behaves like nonmatching doesn't match for which the predicate is true is expected to match code s(:send, s(:int, 1), :+, s(:int, 2)) and {:param=>1} when not given raises an error with extra arguments raises an error with one extra argument for which the predicate is true is expected to match code s(:send, s(:int, 1), :+, s(:int, 2)) and 1 for which the predicate is false behaves like nonmatching doesn't match with an expression argument for which the predicate is true is expected to match code s(:int, 2), :+, and s(:float, 2.0) for which the predicate is false behaves like nonmatching doesn't match with a constant argument for which the predicate is true is expected to match code s(:int, 1), :+, and s(:int, 2) for which the predicate is false behaves like nonmatching doesn't match applied to an integer for which the predicate is false behaves like nonmatching doesn't match when negated is expected to match code s(:int, 1) and :inc in root position is expected to match code s(:int, 1) and :inc with name containing a numeral is expected to match code s(:int, 1) and :inc macros with a pattern without captures def_node_matcher returns the method name when called on matching code is expected to match code :hello when called on non-matching code behaves like nonmatching doesn't match when it errors raises an error with the right location def_node_search returns the method name with a predicate name when called on matching code is expected to match code nil, :foo, s(:sym, :hello), and s(:sym, :world) when called on non-matching code behaves like nonmatching doesn't match when it errors raises an error with the right location without a predicate name when called on non-matching code returns an enumerator yielding nothing when it errors raises an error with the right location when called on matching code returns an enumerator yielding the matches with a pattern with a constant is expected to match code :hello when the value is not in the set behaves like nonmatching doesn't match with a pattern with a namespaced call is expected to match code :hello when the value is not in the set behaves like nonmatching doesn't match with a pattern with captures def_node_search without a predicate name when it errors raises an error with the right location when called on matching code returns an enumerator yielding the captures when the pattern contains keyword_params returns an enumerator yielding the captures when helper is called with default keyword_params is overridden when calling the matcher and no value is given to the matcher uses the defaults some defaults are not params raises an error when called on non-matching code returns an enumerator yielding nothing with a predicate name when called on matching code is expected to match code nil, :foo, s(:sym, :hello), and s(:sym, :world) when called on non-matching code behaves like nonmatching doesn't match when it errors raises an error with the right location def_node_matcher when called on matching code is expected to eq :hello when called on non-matching code behaves like nonmatching doesn't match when it errors raises an error with the right location funcalls without extra arguments is expected to match code :a and s(:int, 1) with one argument is expected to match code s(:str, "foo") and "foo" with multiple arguments is expected to match code s(:str, "c"), "a", and "d" regexp matches symbols or strings comments behaves like single capture yields captured value(s) and returns true if there is a block returns captured values if there is no block nil against a node pattern (bug #5470) behaves like nonmatching doesn't match nil value in AST behaves like nonmatching doesn't match nil literals is expected to match code nil value in AST, use nil? method is expected to match code nil and :foo unions with a nested sequence is expected to match code s(:const, nil, :Const) and :method nested inside a sequence is expected to match code s(:const, nil, :Const) and :method variadic with fixed terms works for cases with fixed arity before and after union works for cases with variadic terms after union works for cases with variadic terms before and after union with variadic terms works for cases with variadic terms after union works for cases with fixed arity before and after union works for cases with variadic terms before and after union multiple works for complex cases at the top level containing string literals is expected to match code s(:str, "a") and :upcase containing mixed node and literals is expected to match code nil and :obj containing integer literals is expected to match code s(:int, 10) and :abs containing symbol literals when the AST has a matching symbol is expected to match code s(:send, nil, :obj) and :b when the AST does not have a matching symbol behaves like nonmatching doesn't match containing multiple [] on a node which meets all requirements of the first [] is expected to match code 3 on a node which meets all requirements of the second [] is expected to match code 2.4 on a node which meets some requirements but not all behaves like nonmatching doesn't match simple sequence on a node with a different type behaves like nonmatching doesn't match on a node with the same type and matching children is expected to match code s(:int, 1), :+, and s(:int, 1) on a node with the same type and non-matching children with non-matching receiver type behaves like nonmatching doesn't match with non-matching selector behaves like nonmatching doesn't match on a node with too many children behaves like nonmatching doesn't match with a nested sequence in non-head position is expected to match code s(:send, s(:send, nil, :obj), :a) and :b with a nested sequence in head position behaves like invalid is invalid ellipsis with a nested sequence at the end, but no remaining child behaves like nonmatching doesn't match preceding a capture behaves like single capture yields captured value(s) and returns true if there is a block returns captured values if there is no block with a set at the end, but no remaining child to match it behaves like nonmatching doesn't match preceding multiple captures behaves like multiple capture yields captured value(s) and returns true if there is a block returns captured values if there is no block with a wildcard at the end, but no remaining child to match it behaves like nonmatching doesn't match at the very beginning of a sequence is expected to match code s(:int, 10), :*, and s(:int, 1) with a nodetype at the end, but no remaining child to match it behaves like nonmatching doesn't match with [] at the end, but no remaining child to match it behaves like nonmatching doesn't match commas with commas randomly strewn around behaves like invalid is invalid in any order invalid doubled with ellipsis behaves like multiple capture yields captured value(s) and returns true if there is a block returns captured values if there is no block doubled with ellipsis in wrong order behaves like nonmatching doesn't match nested behaves like invalid is invalid at the beginning of a sequence behaves like invalid is invalid containing ellipsis not at the end behaves like invalid is invalid with an ellipsis inside and outside behaves like multiple capture yields captured value(s) and returns true if there is a block returns captured values if there is no block captured without ellipsis behaves like single capture yields captured value(s) and returns true if there is a block returns captured values if there is no block with an ellipsis behaves like single capture returns captured values if there is no block yields captured value(s) and returns true if there is a block doubled separated by fixed argument behaves like multiple capture returns captured values if there is no block yields captured value(s) and returns true if there is a block separated by an ellipsis behaves like multiple capture returns captured values if there is no block yields captured value(s) and returns true if there is a block with a captured ellipsis nested behaves like multiple capture yields captured value(s) and returns true if there is a block returns captured values if there is no block matching non sequential children behaves like single capture returns captured values if there is no block yields captured value(s) and returns true if there is a block matching all children behaves like single capture returns captured values if there is no block yields captured value(s) and returns true if there is a block without ellipsis with too many children behaves like nonmatching doesn't match with matching children behaves like multiple capture returns captured values if there is no block yields captured value(s) and returns true if there is a block with too few children behaves like nonmatching doesn't match wildcards unnamed wildcards within a sequence is expected to match code nil and :Const in head position of a sequence is expected to match code s(:int, 1), :+, and s(:send, nil, :a) within a sequence with other patterns intervening is expected to match code :@abc and s(:int, 22) negated behaves like nonmatching doesn't match at the root level is expected to match code s(:sclass, s(:self), s(:def, :something, s(:args), s(:int, 1))) and :freeze named wildcards within a sequence with values which can be unified is expected to match code s(:int, 5), :+, and s(:int, 5) unifying the node type with an argument is expected to match code s(:send, nil, :obj) and :send with values which cannot be unified behaves like nonmatching doesn't match within a union with a succeeding unifying constraint with all branches with the wildcard that can not be unified behaves like nonmatching doesn't match matching another branch is expected to match code s(:array, s(:int, 2), s(:int, 1)) and s(:int, 2) matching the first branch is expected to match code s(:array, s(:int, 1), s(:int, 2)) and s(:int, 2) with branches without the wildcard encountered first behaves like invalid is invalid encountered after behaves like invalid is invalid confined to the union without unification is expected to match code s(:int, 2) and s(:int, 1) with partial unification that can not be unified behaves like nonmatching doesn't match matching the unified branch is expected to match code s(:int, 5) and s(:int, 5) matching the free branch is expected to match code s(:int, 2) and s(:int, 1) with a preceding unifying constraint that can not be unified behaves like nonmatching doesn't match matching a branch is expected to match code s(:int, 2) and s(:array, s(:int, 2), s(:int, 1)) at the root level is expected to match code s(:sclass, s(:self), s(:def, :something, s(:args), s(:int, 1))) and :freeze in head position of a sequence is expected to match code s(:int, 1), :+, and s(:send, nil, :a) within a sequence with other patterns intervening is expected to match code :@abc and s(:int, 22) params when preceded by $... behaves like single capture yields captured value(s) and returns true if there is a block returns captured values if there is no block as named parameters when extra are provided raises an ArgumentError when not provided raises an ArgumentError when provided as argument to match is expected to match code s(:int, 10) and {:foo=>#} param number zero in a position which matches original target node is expected to match code 1 in a position which does not match original target node behaves like nonmatching doesn't match when negated, with a matching value behaves like nonmatching doesn't match when negated, with a nonmatching value is expected to match code s(:const, s(:const, nil, :Namespace), :B) and :A without explicit number is expected to match code s(:const, s(:const, nil, :Namespace), :A), :A, and s(:const, nil, :Namespace) when captured behaves like single capture returns captured values if there is no block yields captured value(s) and returns true if there is a block when inside a union, with a matching value is expected to match code s(:int, 10) and 10 when inside a union, with a nonmatching value behaves like nonmatching doesn't match when inside an intersection is expected to match code s(:int, 20), 10, and 20 in a nested sequence is expected to match code s(:send, s(:send, s(:int, 5), :dec), :inc), :inc, and :dec when preceded by ... is expected to match code s(:send, s(:int, 1), :+, s(:int, 10)) and s(:int, 10) in root position is expected to match code s(:int, 10) and s(:int, 10) in root position is expected to match code s(:int, 10) and # captures on a wildcard nested in any child behaves like multiple capture yields captured value(s) and returns true if there is a block returns captured values if there is no block in head position in a sequence against literal (bug #5470) behaves like nonmatching doesn't match in head position in a sequence behaves like single capture yields captured value(s) and returns true if there is a block returns captured values if there is no block at the root level behaves like single capture yields captured value(s) and returns true if there is a block returns captured values if there is no block in non-head position in a sequence behaves like single capture yields captured value(s) and returns true if there is a block returns captured values if there is no block in a nested sequence behaves like single capture returns captured values if there is no block yields captured value(s) and returns true if there is a block in head position in a sequence against nil (bug #5470) behaves like nonmatching doesn't match .descend yields the given argument if it is not a Node yields all children depth first literals double quoted string literals is expected to match code "foo" bare literal on a node behaves like nonmatching doesn't match on a matching literal is expected to match code :bar symbol literals is expected to match code :foo negative integer literals is expected to match code -100 single quoted string literals is expected to match code "foo" negative float literals is expected to match code -2.5 positive float literals is expected to match code 1.0 caret (ascend) inside a union is expected to match code "abc" using unification to match self within parent with self in the wrong position behaves like nonmatching doesn't match with self in the right position is expected to match code 2 inside an intersection is expected to match code 1 repeated twice is expected to match code 1 within sequence not in head is expected to match code s(:int, 1) and :inc of a sequence is expected to match code s(:int, 1) and :inc in head is expected to match code 1 of a sequence is expected to match code 1 used with a node type which matches is expected to match code 1 which doesn't match behaves like nonmatching doesn't match RuboCop::AST::StrNode #heredoc? with a heredoc is expected to be heredoc with a string with interpolation is expected not to be heredoc with a normal string is expected not to be heredoc #character_literal? with a character literal is expected to be character literal with a normal string literal is expected not to be character literal with a heredoc is expected not to be character literal .new with a normal string is expected to be a kind of RuboCop::AST::StrNode with a heredoc is expected to be a kind of RuboCop::AST::StrNode with a string with interpolation is expected to be a kind of RuboCop::AST::StrNode RuboCop::AST::DefNode #method_name with a setter method is expected to eq :foo= with a unary method is expected to eq :-@ with a plain method is expected to eq :foo with an operator method is expected to eq :== when using Ruby 2.7 or newer #argument_forwarding? is expected to be argument forwarding #first_argument with a single rest argument is expected to be restarg type with a single regular argument is expected to be arg type with a single keyword argument is expected to be kwoptarg type with no arguments is expected to be nil with multiple regular arguments is expected to be arg type with multiple mixed arguments is expected to be arg type #block_argument? with a block argument is expected to be block argument with regular arguments is expected not to be block argument with mixed arguments is expected to be block argument with no arguments is expected not to be block argument #method? when message does not match when argument is a string is expected not to be method "foo" when argument is a symbol is expected not to be method :foo when message matches when argument is a symbol is expected to be method :bar when argument is a string is expected to be method "bar" #endless? with standard method definition is expected not to be endless with endless method definition is expected to be endless #comparison_method? with a comparison method is expected to be comparison method with a regular method is expected not to be comparison method #self_receiver? with a singleton method definition is expected not to be self receiver with an instance method definition is expected not to be self receiver with a class method definition is expected to be self receiver #const_receiver? with a class method definition is expected not to be const receiver with an instance method definition is expected not to be const receiver with a singleton method definition is expected to be const receiver #arguments? with no arguments is expected not to be arguments with multiple regular arguments is expected to be arguments with a single regular argument is expected to be arguments with multiple mixed arguments is expected to be arguments with a single rest argument is expected to be arguments with a single keyword argument is expected to be arguments #body with a multi-expression body is expected to be begin type with no body is expected to be nil with a single expression body is expected to be send type #operator_method? with a binary operator method is expected to be operator method with a setter method is expected not to be operator method with a regular method is expected not to be operator method with a unary operator method is expected to be operator method #camel_case_method? with a regular method is expected not to be camel case method with a camel case method is expected to be camel case method #rest_argument? with mixed arguments is expected to be rest argument with regular arguments is expected not to be rest argument with a rest argument is expected to be rest argument with no arguments is expected not to be rest argument .new with a def node is expected to be a kind of RuboCop::AST::DefNode with a defs node is expected to be a kind of RuboCop::AST::DefNode #bang_method? with a predicate method is expected not to be bang method with a bang method is expected to be bang method with a regular method is expected not to be bang method #arguments with multiple mixed arguments is expected to eq 2 with no arguments is expected to be empty with multiple regular arguments is expected to eq 2 with argument forwarding is expected to eq 1 with a single rest argument is expected to eq 1 with a single regular argument is expected to eq 1 #assignment_method? with a bracket assignment method is expected to be assignment method with a comparison method is expected not to be assignment method with an assignment method is expected to be assignment method with a regular method is expected not to be assignment method #predicate_method? with a bang method is expected not to be predicate method with a predicate method is expected to be predicate method with a regular method is expected not to be predicate method #void_context? with a bracket assignment method is expected to be void context with an initializer method is expected to be void context with a regular method is expected not to be void context with a regular assignment method is expected to be void context with a comparison method is expected not to be void context #last_argument with a single regular argument is expected to be arg type with multiple mixed arguments is expected to be restarg type with a single rest argument is expected to be restarg type with a single keyword argument is expected to be kwoptarg type with no arguments is expected to be nil with multiple regular arguments is expected to be arg type #receiver with an instance method definition is expected to be nil with a class method definition is expected to be self type with a singleton method definition is expected to be const type RuboCop::AST::ArgNode .new with a keyword argument is expected to be a kind of RuboCop::AST::ArgNode with a lambda literal is expected to be a kind of RuboCop::AST::ArgNode with a double splatted argument is expected to be a kind of RuboCop::AST::ArgNode with a block argument is expected to be a kind of RuboCop::AST::ArgNode with a block is expected to be a kind of RuboCop::AST::ArgNode with an optional argument is expected to be a kind of RuboCop::AST::ArgNode with a shadow argument is expected to be a kind of RuboCop::AST::ArgNode with argument forwarding with Ruby >= 3.0 is expected to be a kind of RuboCop::AST::ArgNode with Ruby >= 2.7 is expected to be a kind of RuboCop::AST::ArgNode with a splatted argument is expected to be a kind of RuboCop::AST::ArgNode with an optional keyword argument is expected to be a kind of RuboCop::AST::ArgNode with a method definition is expected to be a kind of RuboCop::AST::ArgNode #default? with a splatted argument is expected to equal false with an optional argument is expected to equal true with a regular argument is expected to equal false with a double splatted argument is expected to equal false with a shadow argument is expected to equal false with a block argument is expected to equal false with an optional keyword argument is expected to equal true with argument forwarding with Ruby >= 3.0 is expected to equal false with Ruby >= 2.7 is expected to equal false with a block is expected to equal false #name with a regular argument is expected to eq :x with a block argument is expected to eq :x with a block is expected to eq :x with an optional argument is expected to eq :x with a keyword argument is expected to eq :x with an optional keyword argument is expected to eq :x with a splatted argument is expected to eq :x with a shadow argument is expected to eq :x with a nameless splatted argument is expected to be nil with a double splatted argument is expected to eq :x with argument forwarding with Ruby >= 2.7 is expected to be nil with Ruby >= 3.0 is expected to be nil with a nameless double splatted argument is expected to be nil #default_value with a block argument is expected to be nil with an optional argument is expected to eq s(:int, 42) with a block is expected to be nil with a double splatted argument is expected to be nil with a regular argument is expected to be nil with a shadow argument is expected to be nil with a splatted argument is expected to be nil with an optional keyword argument is expected to eq s(:int, 42) with argument forwarding with Ruby >= 3.0 is expected to be nil with Ruby >= 2.7 is expected to be nil RuboCop::AST::CaseMatchNode when using Ruby 2.7 or newer #in_pattern_branches is expected to all be in pattern type is expected to eq 3 #each_in_pattern when not passed a block is expected to be a kind of Enumerator when passed a block yields all the conditions #keyword is expected to eq "case" #else_branch #else? with an else statement is expected to be sym type without an else statement is expected to be nil with an empty else statement is expected to be empty else type #else? without an else statement is expected not to be else with an else statement is expected to be else .new is expected to be a kind of RuboCop::AST::CaseMatchNode #branches when there is an else with else body returns all the bodies with empty else returns all the bodies when there is no else keyword returns only then when bodies RuboCop::AST::WhileNode #inverse_keyword is expected to eq "until" #loop_keyword? with a statement while is expected to be loop keyword with a modifier while is expected to be loop keyword #do? without a do keyword is expected not to be do with a do keyword is expected to be do #post_condition_loop? with a modifier while is expected to be post condition loop with a statement while is expected not to be post condition loop #keyword is expected to eq "while" .new with a statement while is expected to be a kind of RuboCop::AST::WhileNode with a modifier while is expected to be a kind of RuboCop::AST::WhileNode RuboCop::AST::InPatternNode when using Ruby 2.7 or newer #pattern with a variable pattern is expected to be match var type with a pin operator is expected to be pin type with an array pattern is expected to be array pattern type with an alternative pattern is expected to be match alt type with a hash pattern is expected to be hash pattern type with a value pattern is expected to be int type with an as pattern is expected to be match as type #branch_index is expected to eq 0 is expected to eq 2 is expected to eq 1 .new is expected to be a kind of RuboCop::AST::InPatternNode #then? with a then keyword is expected to be then without a then keyword is expected not to be then #body without a then keyword is expected to be array type with a then keyword is expected to be sym type RuboCop::AST::BreakNode behaves like wrapped arguments node #arguments with multiple literal arguments is expected to eq 2 with a single splat argument is expected to eq 1 with a single argument and braces is expected to eq 1 with no arguments and braces is expected to be empty with a single argument is expected to eq 1 with no arguments is expected to be empty .new without arguments is expected to be a kind of RuboCop::AST::BreakNode with arguments is expected to be a kind of RuboCop::AST::BreakNode RuboCop::AST::KeywordSplatNode #value is expected to eq s(:kwsplat, s(:send, nil, :foo)) #hash_rocket? is expected not to be hash rocket .new is expected to be a kind of RuboCop::AST::KeywordSplatNode #colon? is expected not to be colon #key is expected to eq s(:kwsplat, s(:send, nil, :foo)) #value_delta when using hash rocket delimiters when keyword splat is behind is expected to eq 0 when keyword splat is ahead is expected to eq 0 when keyword splat is on the same line is expected to eq 0 when keyword splat is left aligned is expected to eq 0 when using colon delimiters when keyword splat is behind is expected to eq 0 when keyword splat is on the same line is expected to eq 0 when keyword splat is ahead is expected to eq 0 when keyword splat is left aligned is expected to eq 0 #key_delta with alignment set to :right when using hash rocket delimiters when keyword splat is behind is expected to eq 0 when keyword splat is aligned is expected to eq 0 when keyword splat is on the same line is expected to eq 0 when keyword splat is ahead is expected to eq 0 when using colon delimiters when keyword splat is behind is expected to eq 0 when keyword splat is aligned is expected to eq 0 when keyword splat is ahead is expected to eq 0 when keyword splat is on the same line is expected to eq 0 with alignment set to :left when using colon delimiters when keyword splat is behind is expected to eq -2 when keyword splat is aligned is expected to eq 0 when keyword splat is on the same line is expected to eq 0 when keyword splat is ahead is expected to eq 2 when using hash rocket delimiters when keyword splat is aligned is expected to eq 0 when keyword splat is on the same line is expected to eq 0 when keyword splat is behind is expected to eq -2 when keyword splat is ahead is expected to eq 2 #operator is expected to eq "**" #same_line? when both pairs are on the same line is expected to be same line s(:kwsplat, s(:send, nil, :foo)) when a multiline pair shares the same line is expected to be same line s(:pair, s(:sym, :a), s(:begin)) is expected to be same line s(:kwsplat, s(:send, nil, :foo)) when pairs are on separate lines is expected not to be same line s(:kwsplat, s(:send, nil, :foo)) RuboCop::AST::AliasNode #old_identifier is expected to eq :bar is expected to be sym type .new is expected to be a kind of RuboCop::AST::AliasNode #new_identifier is expected to be sym type is expected to eq :foo RuboCop::AST::LambdaNode #method_name is expected to eq :lambda #arguments is expected to eq 2 #receiver is expected to be nil RuboCop::AST::ProcessedSource with heavily commented source #comment_at_line returns the comment at the given line number returns nil if line has no comment #line_with_comment? returns false for lines without comments returns true for lines with comments #contains_comment? provided source_range on line with comment is expected to equal true provided source_range on line without comment is expected to equal false provided source_range on comment line is expected to equal true provided a multiline source_range with at least one line with comment is expected to equal true #comments_before_line returns comments on or before given line #find_comment yields nil when there is no match yields correct comment #each_comment_in_lines yields the comments #each_comment yields all comments #blank? with source with content returns false with source of no content returns true #path is the path passed to .new #preceding_line returns source of line before token #first_token_of accepts Node as an argument returns first token for node #lines contains lines as string without linefeed has same number of elements as line count is an array #[] when start index and length are passed returns the array of lines when a range is passed returns the array of lines when an index is passed returns the line #file_path returns file path #comments is an array of comments when the source is invalid returns [] #last_token_of accepts Node as an argument returns last token for node .from_file raises a Errno::ENOENT when the file does not exist when the file exists returns an instance of ProcessedSource sets the file path to the instance's #path #tokens has an array of tokens #start_with? with present source returns false when passed string that does not start source returns true when passed string that starts source with blank source returns false #buffer is a source buffer token enumerables #find_token yields correct token yields nil when there is no match #each_token yields all tokens #tokens_within accepts Node as an argument returns tokens for node when heredoc as argument is present returns tokens for heredoc node returns tokens for node after heredoc returns tokens for node before heredoc #following_line returns source of line after token #parser_error when the source could not be parsed due to encoding error returns the error when the source was properly parsed is nil when the source lacks encoding comment and is really utf-8 encoded but has been read as US-ASCII is nil #ast is the root node of AST valid_syntax? when the source could not be parsed due to encoding error returns false when the source is valid but has some warning diagnostics returns true when the source itself is valid encoding but includes strange encoding literals that are accepted by MRI returns true when the source is invalid returns false when the source is completely valid returns true when a line starts with an integer literal tokenizes the source correctly RuboCop::AST::WhenNode #branch_index is expected to eq 1 is expected to eq 2 is expected to eq 0 #body with a then keyword is expected to be sym type without a then keyword is expected to be array type #then? with a then keyword is expected to be then without a then keyword is expected not to be then .new is expected to be a kind of RuboCop::AST::WhenNode #each_condition when passed a block yields all the conditions when not passed a block is expected to be a kind of Enumerator #conditions with a multiple conditions is expected to all be literal is expected to eq 3 with a single condition is expected to eq 1 is expected to all be literal RuboCop::AST::AsgnNode .new with a `cvasgn` node is expected to be a kind of RuboCop::AST::AsgnNode with a `gvasgn` node is expected to be a kind of RuboCop::AST::AsgnNode with a `lvasgn` node is expected to be a kind of RuboCop::AST::AsgnNode with a `ivasgn` node is expected to be a kind of RuboCop::AST::AsgnNode #name with a `cvasgn` node is expected to eq :@@var with a `lvasgn` node is expected to eq :var with a `ivasgn` node is expected to eq :@var with a `gvasgn` node is expected to eq :$var #expression with a `cvasgn` node is expected to eq s(:send, nil, :value) with a `gvasgn` node is expected to eq s(:send, nil, :value) with a `ivasgn` node is expected to eq s(:send, nil, :value) with a `lvasgn` node is expected to eq s(:send, nil, :value) RuboCop::AST::ForNode #void_context? without a do keyword is expected to be void context with a do keyword is expected to be void context #collection is expected to be sym type #body is expected to be sym type .new is expected to be a kind of RuboCop::AST::ForNode #variable is expected to be lvasgn type #loop_keyword? is expected to be loop keyword #keyword is expected to eq "for" #do? with a do keyword is expected to be do without a do keyword is expected not to be do #post_condition_loop? is expected not to be post condition loop RuboCop::AST::Node #parent_module_name when node on singleton class is expected to eq "Foo::#" when node nested in an unknown block is expected to be nil when node on class in singleton class is expected to eq "Foo::#::Bar" when node nested in a class << exp is expected to be nil when node on module is expected to eq "Foo" when node on top level is expected to eq "Object" #struct_constructor? struct definition without block does not match ::Struct matches struct definition with a block matches #numeric_type? when rational literal is true when string literal is true when integer literal is true when complex literal whose imaginary part is a rational is true when complex literal is true when float literal is true #value_used? within a while node is true only for the condition at the end of a block is always true at the top level is false within a module definition node is always true within an array literal at the top level is always false assigned to an ivar is always true within a singleton class node is always true within a method call node is always true within an if...else..end node at the top level is true only for the condition nested in a method call is always true within a class definition node is always true sibling_access returns trivial values for a root node for a node with siblings returns the expected values for a single child returns the expected values #module_definition? nested modules matches namespaced modules matches with ::ModuleName matches using module keyword matches prepend Module.new matches included module definition matches with Module.new matches when using numbered parameter matches #argument_type? method arguments returns true for all argument types block arguments returns true for all argument types #recursive_basic_literal? behaves like literal returns true for `!true` behaves like literal returns true for `{ :a => 1, :b => 2 }` behaves like literal returns true for `{ a: 1, b: 2 }` behaves like non literal returns false for `{ :sym => some_method_call }` behaves like non literal returns false for `/.#{some_method_call}/` behaves like literal returns true for `1` behaves like literal returns true for `[1, 2, 3]` behaves like literal returns true for `/./` behaves like literal returns true for `'str'` behaves like literal returns true for `(1)` behaves like literal returns true for `(false && true)` behaves like non literal returns false for `some_method_call` behaves like literal returns true for `(false <=> true)` behaves like non literal returns false for `(x or false)` behaves like non literal returns false for `%r{abx#{foo}}ixo` behaves like non literal returns false for `(x && false)` behaves like literal returns true for `%r{abx}ixo` behaves like literal returns true for `"#{2}"` behaves like non literal returns false for `{ some_method_call => :sym }` behaves like literal returns true for `nil` behaves like non literal returns false for `[some_method_call]` behaves like non literal returns false for `some_method_call(x, y)` behaves like non literal returns false for `(x == false)` behaves like literal returns true for `(false or true)` behaves like literal returns true for `1.0` behaves like literal returns true for `false` #class_constructor? class definition does not match class definition on outer scope matches class definition with a block matches module definition with a block matches #class_definition? with Struct matches when using numbered parameter matches constant defined as Struct without block does not match with self singleton class matches namespaced class matches with Class.new matches when using numbered parameter matches with ::ClassName matches with inheritance matches with object singleton class matches without inheritance matches #conditional? when `case` node is true when `case_match` node is true when `while` node is true when post condition loop node is false when `until` node is true when `if` node is true #pure? for a method call returns false for a cvar assignment returns false for a hash literal which contains a method call returns false with only literal children returns true for a class definition returns false for an lvar assignment returns false for a nested if where the innermost descendants are local vars and literals returns true where one branch contains a method call returns false where one branch contains an assignment statement returns false for an array literal which contains a method call returns false with only literal children returns true for a gvar assignment returns false for a module definition returns false for an ivar assignment returns false for a regexp with options returns true with interpolated segments returns false with no interpolation returns true for an integer literal returns true RuboCop::AST::FloatNode #value is expected to eq 1.5 #sign? explicit positive float is expected to be sign explicit negative float is expected to be sign .new is expected to be a kind of RuboCop::AST::FloatNode RuboCop::AST::SendNode #nonmutating_unary_operator_method? with a nonmutating unary operator method is expected to be nonmutating unary operator method with a regular method is expected not to be nonmutating unary operator method #non_bare_access_modifier? when node is a non-bare `module_function` is expected to be non bare access modifier when node does not have an argument is expected not to be non bare access modifier when node is not an access modifier is expected not to be non bare access modifier #nonmutating_array_method? with a regular method is expected not to be nonmutating array method with a mutating Array method is expected not to be nonmutating array method with a nonmutating Array method is expected to be nonmutating array method #negation_method? with prefix `not` is expected to be negation method with a non-negated method is expected not to be negation method with suffix `not` is expected not to be negation method with prefix bang is expected to be negation method #const_receiver? with a constant receiver is expected to be const receiver with a non-constant receiver is expected not to be const receiver with a self receiver is expected not to be const receiver #nonmutating_binary_operator_method? with a regular method is expected not to be nonmutating binary operator method with a nonmutating binary operator method is expected to be nonmutating binary operator method with a mutating binary operator method is expected not to be nonmutating binary operator method #command? when argument is a symbol with an implicit receiver is expected to be command :bar with an explicit receiver is expected not to be command :bar when argument is a string with an explicit receiver is expected not to be command "bar" with an implicit receiver is expected to be command "bar" #self_receiver? with a non-self receiver is expected not to be self receiver with a self receiver is expected to be self receiver with an implicit receiver is expected not to be self receiver .new with a safe navigation method send is expected to be a kind of RuboCop::AST::SendNode with a regular method send is expected to be a kind of RuboCop::AST::SendNode #binary_operation?? with a unary operation is expected not to be binary operation with a regular method call is expected not to be binary operation with an implicit call method is expected not to be binary operation with a binary operation is expected to be binary operation #arithmetic_operation? with a unary numeric operation is expected not to be arithmetic operation with a binary arithmetic operation is expected to be arithmetic operation with a regular method call is expected not to be arithmetic operation #lambda_literal? with a lambda method is expected not to be lambda literal with a non-lambda method is expected not to be lambda with `a.() {}` style method is expected not to be lambda with a stabby lambda is expected to be lambda literal #unary_operation? with a unary operation is expected to be unary operation with an implicit call method is expected not to be unary operation with a binary operation is expected not to be unary operation with a regular method call is expected not to be unary operation #last_argument with a single splat argument is expected to be splat type with multiple mixed arguments is expected to be splat type with multiple literal arguments is expected to be sym type with no arguments is expected to be nil with a single literal argument is expected to be sym type #block_argument? with no arguments is expected not to be block argument with mixed arguments is expected to be block argument with regular arguments is expected not to be block argument with a block argument is expected to be block argument #camel_case_method? with a camel case method is expected to be camel case method with a regular method is expected not to be camel case method #nonmutating_hash_method? with a mutating Hash method is expected not to be nonmutating hash method with a regular method is expected not to be nonmutating hash method with a nonmutating Hash method is expected to be nonmutating hash method #arguments with a single literal argument is expected to eq 1 with multiple literal arguments is expected to eq 2 with multiple mixed arguments is expected to eq 2 with a single splat argument is expected to eq 1 with no arguments is expected to be empty #prefix_not? with keyword `not` is expected to be prefix not with a bang method is expected not to be prefix not with a non-negated method is expected not to be prefix not #implicit_call? with an explicit call method is expected not to be implicit call with an implicit call method is expected to be implicit call with a regular method is expected not to be implicit call #lambda? with a non-lambda method is expected not to be lambda with a lambda method is expected to be lambda with a stabby lambda method is expected to be lambda with a method named lambda in a class is expected not to be lambda #bang_method? with a predicate method is expected not to be bang method with a regular method is expected not to be bang method with a bang method is expected to be bang method #def_modifier? with a block containing a method definition is expected not to be def modifier with several prefixed def modifiers is expected to be def modifier with a prefixed def modifier is expected to be def modifier #def_modifier with a prefixed def modifier is expected to eq :bar with call with no argument is expected to be nil with a block containing a method definition is expected to be nil with several prefixed def modifiers is expected to eq :qux #macro? with a receiver when parent is a module is expected not to be macro when parent is a class is expected not to be macro without a receiver when parent is a block in a macro scope is expected to be macro when parent is a class constructor is expected to be macro when parent is a struct constructor is expected to be macro when parent is a keyword begin inside of an class is expected to be macro when in the global scope is expected to be macro when parent is a block not in a macro scope is expected not to be macro when in an if is expected to be macro without a parent is expected to be macro when parent is a begin without a parent is expected to be macro when parent is a class is expected to be macro with Ruby >= 2.7 when parent is a numblock in a macro scope is expected to be macro when the condition of an if is expected not to be macro when parent is a singleton class is expected to be macro when parent is a module is expected to be macro when parent is a method definition is expected not to be macro #method_name with an operator method is expected to eq :== with an implicit call method is expected to eq :call with a setter method is expected to eq :bar= with a plain method is expected to eq :bar #prefix_bang? with a non-negated method is expected not to be prefix bang with a bang method is expected to be prefix bang with keyword `not` is expected not to be prefix bang #loop_keyword? is expected not to be loop keyword #assignment_method? with a bracket assignment method is expected to be assignment method with a regular method is expected not to be assignment method with a comparison method is expected not to be assignment method with an assignment method is expected to be assignment method #bare_access_modifier? when node is a bare `module_function` is expected to be bare access modifier when node has an argument is expected not to be bare access modifier with Ruby >= 2.7 when node is access modifier in block is expected to be bare access modifier when node is access modifier in numblock is expected to be bare access modifier when node is not an access modifier is expected not to be bare access modifier #splat_argument? with no arguments is expected not to be splat argument with a splat argument is expected to be splat argument with mixed arguments is expected to be splat argument with regular arguments is expected not to be splat argument #double_colon? with a double colon is expected to be double colon with a dot is expected not to be double colon without a dot is expected not to be double colon with a unary method is expected not to be double colon #attribute_accessor? with an accessor returns the accessor method and Array] with a call without arguments is expected to be nil #receiver with a variable receiver is expected to be send type with a literal receiver is expected to be str type with no receiver is expected to be nil #predicate_method? with a regular method is expected not to be predicate method with a predicate method is expected to be predicate method with a bang method is expected not to be predicate method #access_modifier? when node is not an access modifier is expected not to be bare access modifier when node is a bare `module_function` is expected to be access modifier when node is a non-bare `module_function` is expected to be access modifier #nonmutating_string_method? with a regular method is expected not to be nonmutating string method with a mutating String method is expected not to be nonmutating string method with a nonmutating String method is expected to be nonmutating string method #first_argument with a single literal argument is expected to be sym type with a single splat argument is expected to be splat type with multiple literal arguments is expected to be sym type with multiple mixed arguments is expected to be sym type with no arguments is expected to be nil #parenthesized? with no arguments when not using parentheses is expected not to be parenthesized when using parentheses is expected to be parenthesized with arguments when using parentheses is expected to be parenthesized when not using parentheses is expected not to be parenthesized #method? when message matches when argument is a symbol is expected to be method :bar when argument is a string is expected to be method "bar" when message does not match when argument is a string is expected not to be method "foo" when argument is a symbol is expected not to be method :foo #block_node with no block is expected to be nil with a block literal is expected to be block type with a block argument is expected to be nil with Ruby >= 2.7 with a numblock literal is expected to be numblock type #enumerable_method? with an enumerable method is expected to be enumerable method with a regular method is expected not to be enumerable method #comparison_method? with a negation method is expected not to be comparison method with a regular method is expected not to be comparison method with a comparison method is expected to be comparison method #post_condition_loop? is expected not to be post condition loop #operator_method? with a regular method is expected not to be operator method with a unary operator method is expected to be operator method with a binary operator method is expected to be operator method with a setter method is expected not to be operator method #dot? without a dot is expected not to be dot with a unary method is expected not to be dot with a double colon is expected not to be dot with a dot is expected to be dot #nonmutating_operator_method? with a nonmutating binary operator method is expected to be nonmutating operator method with a nonmutating unary operator method is expected to be nonmutating operator method with a mutating binary operator method is expected not to be nonmutating operator method with a regular method is expected not to be nonmutating operator method #arguments? with multiple mixed arguments is expected to be arguments with no arguments is expected not to be arguments with a single literal argument is expected to be arguments with multiple literal arguments is expected to be arguments with a single splat argument is expected to be arguments #block_literal? with no block is expected not to be block literal with a block literal is expected to be block literal with Ruby >= 2.7 with a numblock literal is expected to be block literal with a block argument is expected not to be block literal #setter_method? with a regular method is expected not to be setter method with an operator method is expected not to be setter method with an indexed setter method is expected to be setter method with a setter method is expected to be setter method RuboCop::AST::DefinedNode #receiver is expected to be nil #arguments is expected to all be sym type is expected to eq 1 #method_name is expected to eq :defined? .new with a defined? node is expected to be a kind of RuboCop::AST::DefinedNode RuboCop::AST::OpAsgnNode #expression is expected to eq s(:send, nil, :value) #assignment_node is expected to be a kind of RuboCop::AST::AsgnNode .new with an `op_asgn_node` node is expected to be a kind of RuboCop::AST::OpAsgnNode #name is expected to eq :var #operator with -= is expected to eq :- with |= is expected to eq :| with **= is expected to eq :** with *= is expected to eq :* with %= is expected to eq :% with /= is expected to eq :/ with += is expected to eq :+ with &= is expected to eq :& RuboCop::AST::IntNode #value is expected to eq 10 #sign? explicit positive int is expected to be sign explicit negative int is expected to be sign .new is expected to be a kind of RuboCop::AST::IntNode RuboCop::AST::SelfClassNode .new is expected to be a kind of RuboCop::AST::SelfClassNode #body with a single expression body is expected to be send type with a multi-expression body is expected to be begin type with an empty body is expected to be nil #identifier is expected to be self type RuboCop::AST::ForwardArgsNode when using Ruby 2.7 or newer #to_a is expected to contain exactly (be forward arg type) RuboCop::AST::DstrNode #value with a multiline string is expected to eq "this is a multiline string" with implicit concatenation is expected to eq "foo bar baz" with interpolation is expected to eq "foo \#{bar} baz" RuboCop::AST::OrAsgnNode .new is expected to be a kind of RuboCop::AST::OrAsgnNode #expression is expected to eq s(:send, nil, :value) #assignment_node is expected to be a kind of RuboCop::AST::AsgnNode #operator is expected to eq :"||" #name is expected to eq :var RuboCop::AST::NextNode behaves like wrapped arguments node #arguments with no arguments and braces is expected to be empty with multiple literal arguments is expected to eq 2 with no arguments is expected to be empty with a single splat argument is expected to eq 1 with a single argument and braces is expected to eq 1 with a single argument is expected to eq 1 .new with arguments is expected to be a kind of RuboCop::AST::NextNode without arguments is expected to be a kind of RuboCop::AST::NextNode RuboCop::AST::ArgsNode #empty_and_without_delimiters? with delimiters with a lambda literal is expected to equal false with a block is expected to equal false with a method definition is expected to equal false with arguments with a lambda literal is expected to equal false with a method definition is expected to equal false with empty arguments with a lambda literal is expected to equal true with a block is expected to equal true with a method definition is expected to equal true #argument_list is expected to eq [s(:arg, :a), s(:optarg, :b, s(:int, 42)), s(:arg, :c), s(:restarg, :d), s(:kwarg, :e), s(:kwoptarg, :f, s(:int, 42)), s(:kwrestarg, :g), s(:blockarg, :h), s(:shadowarg, :i)] when using Ruby 2.7 or newer with argument forwarding is expected to eq [s(:forward_arg)] .new with a block is expected to be a kind of RuboCop::AST::ArgsNode with a method definition is expected to be a kind of RuboCop::AST::ArgsNode with a lambda literal is expected to be a kind of RuboCop::AST::ArgsNode RuboCop::AST::SymbolNode #value is expected to eq :foo .new with a symbol node is expected to be a kind of RuboCop::AST::SymbolNode RuboCop::AST::Token #end_pos returns index of last char in token range of entire source #begin_pos returns index of first char in token range of entire source .from_parser_token returns a #to_s useful for debugging sets parser token's range to rubocop token's pos sets parser token's type to rubocop token's type sets parser token's text to rubocop token's text #space_after returns truthy MatchData when there is a space after token returns nil when there is not a space after token type predicates #left_ref_bracket? returns false for non left_ref_bracket tokens returns true for left_ref_bracket tokens #dot? returns true for dot tokens returns false for non dot tokens #equals_sign? returns true for equals sign tokens returns false for non equals sign tokens #comment? returns false for non comment tokens returns true for comment tokens #end? returns true for end tokens returns false for non end tokens #new_line? returns false for non new line tokens returns true for new line tokens #right_bracket? returns true for all right_bracket tokens returns false for non right_bracket tokens with braces & parens #left_parens? returns true for left parens tokens returns false for non left parens tokens #right_curly_brace? returns true for all right brace tokens returns false for non right brace tokens #right_parens? returns false for non right parens tokens returns true for right parens tokens #left_brace? returns true for left hash brace tokens returns false for non left hash brace tokens #left_curly_brace? returns true for left block brace tokens returns false for non left block brace tokens #regexp_dots? returns true for regexp tokens returns false for non comma tokens #semicolon? returns false for non semicolon tokens returns true for semicolon tokens #left_array_bracket? returns true for left_array_bracket tokens returns false for non left_array_bracket tokens #left_brace? returns true for right_bracket tokens returns false for non right_bracket tokens #rescue_modifier? returns true for rescue modifier tokens returns false for non rescue modifier tokens #left_bracket? returns false for non left_bracket tokens returns true for all left_bracket tokens #comma? returns false for non comma tokens returns true for comma tokens #to_s returns string of token data #line returns line of token #column returns index of first char in token range on that line #space_before returns nil when it is on the first line returns nil when there is not a space before token returns truthy MatchData when there is a space before token RuboCop::AST::CaseNode #when_branches is expected to all be when type is expected to eq 3 #branches when there is an else returns all the bodies with an empty else returns all the bodies when compared to an IfNode returns the same when there is no else keyword returns only then when bodies #keyword is expected to eq "case" .new is expected to be a kind of RuboCop::AST::CaseNode #else? without an else statement is expected not to be else with an else statement is expected to be else #else_branch #else? with an else statement is expected to be sym type with an empty else statement is expected to be nil without an else statement is expected to be nil #each_when when passed a block yields all the conditions when not passed a block is expected to be a kind of Enumerator RuboCop::AST::CasgnNode #name is expected to eq :VAR #expression is expected to eq s(:send, nil, :value) .new with a `casgn` node is expected to be a kind of RuboCop::AST::CasgnNode #namespace when the parent is a `cbase` is expected to eq s(:cbase) when the parent is a `const` is expected to eq s(:const, nil, :FOO) when there is no parent is expected to be nil RuboCop::AST::ModuleNode #body with a single expression body is expected to be send type with a multi-expression body is expected to be begin type with an empty body is expected to be nil #identifier is expected to be const type .new is expected to be a kind of RuboCop::AST::ModuleNode RuboCop::AST::NodePattern::Parser sequences parses unions of literals as a set parses capture vs repetition with correct priority parses simple sequences properly expands ... in sequence head deep inside unions generates specialized nodes parses function calls Set#=== tests for inclusion RuboCop::AST::NodePattern::Lexer provides tokens via next_token when given a regexp /test/ round trips when given a regexp /back\\slash/ round trips with $type+ is parsed as `$ int + x` when given arithmetic symbols is parsed as `:&` when given node types and constants distinguishes them when given a regexp ending with a backslash does not lexes it properly when given a regexp /[abc]+\/()?/x round trips RuboCop::AST::ConstNode #module_name? is expected not to be module name with a constant with a lowercase letter is expected to be module name #each_path yields all parts of the namespace #short_name is expected to eq :BAZ #namespace is expected to eq "::Foo::Bar" #absolute? is expected to be absolute with a non-namespaced constant is expected not to be absolute with a constant not starting with :: is expected not to be absolute #relative? with a non-namespaced constant is expected to be relative RuboCop::AST::BlockNode #braces? when enclosed in do-end keywords is expected not to be braces when enclosed in braces is expected to be braces #void_context? when block method is tap is expected to be void context when block method is not each is expected not to be void context when block method is each is expected to be void context #arguments? with a single argument is expected to be arguments with multiple mixed arguments is expected to be arguments with no arguments is expected not to be arguments with a single splat argument is expected to be arguments >= Ruby 2.7 using numbered parameters is expected not to be arguments with destructuring arguments is expected to be arguments #arguments >= Ruby 2.7 using numbered parameters is expected to be empty with destructured arguments is expected to eq 2 with no arguments is expected to be empty with a single literal argument is expected to eq 1 with multiple mixed arguments is expected to eq 2 with a single splat argument is expected to eq 1 #multiline? when block is on a single line is expected not to be multiline when block is on several lines is expected to be multiline #closing_delimiter when enclosed in do-end keywords is expected to eq "end" when enclosed in braces is expected to eq "}" .new is expected to be a kind of RuboCop::AST::BlockNode #argument_list with no arguments is expected to be empty all argument types is expected to eq [:a, :b, :c, :d, :e, :f, :g, :h, :i] >= Ruby 2.7 using numbered parameters with skipped params is expected to eq [:_1, :_2, :_3, :_4, :_5, :_6, :_7] with sequential params is expected to eq [:_1, :_2] #delimiters when enclosed in do-end keywords is expected to eq ["do", "end"] when enclosed in braces is expected to eq ["{", "}"] #opening_delimiter when enclosed in braces is expected to eq "{" when enclosed in do-end keywords is expected to eq "do" #keywords? when enclosed in do-end keywords is expected to be keywords when enclosed in braces is expected not to be keywords #single_line? when block is on several lines is expected not to be single line when block is on a single line is expected to be single line #lambda? when block belongs to a method lambda is expected to be lambda when block belongs to a stabby lambda is expected to be lambda when block belongs to a non-lambda method is expected not to be lambda #receiver with dot operator call is expected to eq "foo" with safe navigation operator call is expected to eq "foo" RuboCop::AST::RuboCopCompatibility when ran from a compatible version of Rubocop issues a warning when ran from an incompatible version of Rubocop issues a warning RuboCop::AST::OrNode #inverse_operator with a semantic or node is expected to eq "and" with a logical or node is expected to eq "&&" .new with a semantic or node is expected to be a kind of RuboCop::AST::OrNode with a logical or node is expected to be a kind of RuboCop::AST::OrNode #logical_operator? with a semantic or node is expected not to be logical operator with a logical or node is expected to be logical operator #semantic_operator? with a logical or node is expected not to be semantic operator with a semantic or node is expected to be semantic operator #lhs with a logical or node is expected to be sym type with a semantic or node is expected to be sym type #rhs with a semantic or node is expected to be int type with a logical or node is expected to be int type #alternate_operator with a semantic or node is expected to eq "||" with a logical or node is expected to eq "or" #operator with a logical or node is expected to eq "||" with a semantic or node is expected to eq "or" RuboCop::AST::UntilNode #do? with a do keyword is expected to be do without a do keyword is expected not to be do #keyword is expected to eq "until" #loop_keyword? with a statement until is expected to be loop keyword with a modifier until is expected to be loop keyword #post_condition_loop? with a statement until is expected not to be post condition loop with a modifier until is expected to be post condition loop .new with a modifier until is expected to be a kind of RuboCop::AST::UntilNode with a statement until is expected to be a kind of RuboCop::AST::UntilNode #inverse_keyword is expected to eq "while" RuboCop::AST::ClassNode #parent_class when no parent class is specified is expected to be nil when a parent class is specified is expected to be const type #identifier is expected to be const type .new is expected to be a kind of RuboCop::AST::ClassNode #body with an empty body is expected to be nil with a multi-expression body is expected to be begin type with a single expression body is expected to be send type RuboCop::AST::Procarg0Node #name is expected to eq :x .new with a block is expected to be a kind of RuboCop::AST::ArgNode RuboCop::AST::NodePattern::Sets is expected not to eq "::RuboCop::AST::NodePattern::Sets::SET_1_2_3_ETC_2" is expected to eq "::RuboCop::AST::NodePattern::Sets::SET_1_2_3_ETC" is expected to eq "::RuboCop::AST::NodePattern::Sets::SET_1_2_3_ETC" creates a constant with the right value RuboCop::AST::PairNode #value_delta when using hash rocket delimiters when values are aligned when both pairs are explicit pairs is expected to eq 0 when second pair is a keyword splat is expected to eq 0 when receiver value is ahead is expected to eq 2 when receiver value is behind is expected to eq -2 when both pairs are on the same line is expected to eq 0 when using colon delimiters when receiver value is ahead is expected to eq 2 when both pairs are on the same line is expected to eq 0 when values are aligned when both pairs are explicit pairs is expected to eq 0 when second pair is a keyword splat is expected to eq 0 when receiver value is behind is expected to eq -2 #key when using a string key is expected to be str type when using a symbol key is expected to be sym type #key_delta with alignment set to :right when using hash rocket delimiters when keys are aligned when second key is a keyword splat is expected to eq 0 when both keys are explicit keys is expected to eq 0 when both keys are on the same line when both pairs are explicit pairs is expected to eq 0 when second pair is a keyword splat is expected to eq 0 when receiver key is ahead when second pair is a keyword splat is expected to eq 0 when both pairs are explicit pairs is expected to eq 2 when receiver key is behind when second pair is a keyword splat is expected to eq 0 when both pairs are explicit pairs is expected to eq -2 when using colon delimiters when receiver key is ahead when second pair is a keyword splat is expected to eq 0 when both pairs are explicit pairs is expected to eq 2 when both keys are on the same line when both pairs are explicit pairs is expected to eq 0 when second pair is a keyword splat is expected to eq 0 when keys are aligned when second pair is a keyword splat is expected to eq 0 when both pairs are explicit pairs is expected to eq 0 when receiver key is behind when both pairs are reail pairs is expected to eq -2 when second pair is a keyword splat is expected to eq 0 with alignment set to :left when using hash rocket delimiters when receiver key is behind when both pairs are explicit pairs is expected to eq -2 when second pair is a keyword splat is expected to eq -2 when keys are aligned when second key is a keyword splat is expected to eq 0 when both keys are explicit keys is expected to eq 0 when receiver key is ahead when second pair is a keyword splat is expected to eq 2 when both pairs are explicit pairs is expected to eq 2 when both keys are on the same line when second pair is a keyword splat is expected to eq 0 when both pairs are explicit pairs is expected to eq 0 when using colon delimiters when keys are aligned when both pairs are explicit pairs is expected to eq 0 when second pair is a keyword splat is expected to eq 0 when receiver key is ahead when both pairs are explicit pairs is expected to eq 2 when second pair is a keyword splat is expected to eq 2 when receiver key is behind when both pairs are reail pairs is expected to eq -2 when second pair is a keyword splat is expected to eq -2 when both keys are on the same line when second pair is a keyword splat is expected to eq 0 when both pairs are explicit pairs is expected to eq 0 #inverse_delimiter when using a hash rocket delimiter is expected to eq ":" is expected to eq ": " when using a colon delimiter is expected to eq "=>" is expected to eq " => " #value is expected to be int type #colon? when using a hash rocket delimiter is expected not to be colon when using a colon delimiter is expected to be colon #delimiter when using a colon delimiter is expected to eq ":" is expected to eq ": " when using a hash rocket delimiter is expected to eq " => " is expected to eq "=>" #value_omission? when using hash value omission is expected to be value omission when not using hash value omission is expected not to be value omission #hash_rocket? when using a colon delimiter is expected not to be hash rocket when using a hash rocket delimiter is expected to be hash rocket #same_line? when pairs are on separate lines when both pairs are explicit pairs is expected not to be same line s(:pair, s(:sym, :b), s(:int, 2)) when last pair is a keyword splat is expected not to be same line s(:kwsplat, s(:send, nil, :foo)) when a multiline pair shares the same line when last pair is a keyword splat is expected to be same line s(:kwsplat, s(:send, nil, :foo)) is expected to be same line s(:pair, s(:sym, :a), s(:begin)) when both pairs are explicit pairs is expected to be same line s(:pair, s(:sym, :b), s(:int, 2)) is expected to be same line s(:pair, s(:sym, :a), s(:begin)) when both pairs are on the same line when both pairs are explicit pairs is expected to be same line s(:pair, s(:sym, :b), s(:int, 2)) when both pair is a keyword splat is expected to be same line s(:kwsplat, s(:send, nil, :foo)) #value_on_new_line? when pair is on a single line is expected not to be value on new line when value spans multiple lines is expected not to be value on new line when value starts on a new line is expected to be value on new line .new is expected to be a kind of RuboCop::AST::PairNode RuboCop::AST::ResbodyNode #exceptions with multiple exceptions is expected to all be const type is expected to eq 2 without exception is expected to eq 0 with a single exception is expected to all be const type is expected to eq 1 #branch_index is expected to eq 2 is expected to eq 1 is expected to eq 0 #body is expected to be sym type #exception_variable when an exception variable is not given is expected to be nil for an explicit rescue is expected to eq "ex" for an implicit rescue is expected to eq "ex" .new is expected to be a kind of RuboCop::AST::ResbodyNode Finished in 3.21 seconds (files took 1.19 seconds to load) 2392 examples, 0 failures Randomized with seed 46231 ┌──────────────────────────────────────────────────────────────────────────────┐ │ dh_ruby --install finished │ └──────────────────────────────────────────────────────────────────────────────┘ dh_installdocs -O--buildsystem=ruby dh_ruby_fixdocs -O--buildsystem=ruby debian/rules override_dh_installchangelogs make[1]: Entering directory '/build/reproducible-path/ruby-rubocop-ast-1.24.0' dh_installchangelogs CHANGELOG.md make[1]: Leaving directory '/build/reproducible-path/ruby-rubocop-ast-1.24.0' dh_installsystemduser -O--buildsystem=ruby dh_perl -O--buildsystem=ruby dh_link -O--buildsystem=ruby dh_strip_nondeterminism -O--buildsystem=ruby dh_compress -X.rb -O--buildsystem=ruby dh_fixperms -O--buildsystem=ruby dh_missing -O--buildsystem=ruby dh_ruby_fixdepends -O--buildsystem=ruby dh_installdeb -O--buildsystem=ruby dh_gencontrol -O--buildsystem=ruby dpkg-gencontrol: warning: Depends field of package ruby-rubocop-ast: substitution variable ${shlibs:Depends} used, but is not defined dpkg-gencontrol: warning: package ruby-rubocop-ast: substitution variable ${ruby:Versions} used, but is not defined dh_md5sums -O--buildsystem=ruby dh_builddeb -O--buildsystem=ruby dpkg-deb: building package 'ruby-rubocop-ast' in '../ruby-rubocop-ast_1.24.0-2_all.deb'. dpkg-genbuildinfo --build=binary -O../ruby-rubocop-ast_1.24.0-2_arm64.buildinfo dpkg-genchanges --build=binary -O../ruby-rubocop-ast_1.24.0-2_arm64.changes dpkg-genchanges: info: binary-only upload (no source code included) dpkg-source --after-build . dpkg-buildpackage: info: binary-only upload (no source included) dpkg-genchanges: info: not including original source code in upload I: copying local configuration I: unmounting dev/ptmx filesystem I: unmounting dev/pts filesystem I: unmounting dev/shm filesystem I: unmounting proc filesystem I: unmounting sys filesystem I: cleaning the build env I: removing directory /srv/workspace/pbuilder/2893848 and its subdirectories I: Current time: Fri May 29 13:18:44 -12 2026 I: pbuilder-time-stamp: 1780103924 Sat May 30 01:18:44 UTC 2026 I: Signing ./b1/ruby-rubocop-ast_1.24.0-2_arm64.buildinfo as ruby-rubocop-ast_1.24.0-2_arm64.buildinfo.asc Sat May 30 01:18:44 UTC 2026 I: Signed ./b1/ruby-rubocop-ast_1.24.0-2_arm64.buildinfo as ./b1/ruby-rubocop-ast_1.24.0-2_arm64.buildinfo.asc Sat May 30 01:18:44 UTC 2026 - build #1 for ruby-rubocop-ast/unstable/arm64 on codethink03-arm64 done. Starting cleanup. All cleanup done. Sat May 30 01:18:44 UTC 2026 - reproducible_build.sh stopped running as /tmp/jenkins-script-2MS0dRsm, removing. /srv/reproducible-results/rbuild-debian/r-b-build.XpjqCx9r: total 16 drwxr-xr-x 2 jenkins jenkins 4096 Apr 26 18:55 b1 drwxr-xr-x 2 jenkins jenkins 4096 Apr 26 18:55 b2 -rw------- 1 jenkins jenkins 3401 Apr 26 18:55 rbuildlog.1anVNAM -rw-r--r-- 1 jenkins jenkins 2224 Dec 21 2022 ruby-rubocop-ast_1.24.0-2.dsc /srv/reproducible-results/rbuild-debian/r-b-build.XpjqCx9r/b1: total 332 -rw-r--r-- 1 jenkins jenkins 244846 Apr 26 18:55 build.log -rw-r--r-- 1 jenkins jenkins 3600 Apr 26 18:55 ruby-rubocop-ast_1.24.0-2.debian.tar.xz -rw-r--r-- 1 jenkins jenkins 2224 Apr 26 18:55 ruby-rubocop-ast_1.24.0-2.dsc -rw-r--r-- 1 jenkins jenkins 53520 Apr 26 18:55 ruby-rubocop-ast_1.24.0-2_all.deb -rw-r--r-- 1 jenkins jenkins 7668 Apr 26 18:55 ruby-rubocop-ast_1.24.0-2_arm64.buildinfo -rw-r--r-- 1 jenkins jenkins 8550 Apr 26 18:55 ruby-rubocop-ast_1.24.0-2_arm64.buildinfo.asc -rw-r--r-- 1 jenkins jenkins 1128 Apr 26 18:55 ruby-rubocop-ast_1.24.0-2_arm64.changes -rw-r--r-- 1 jenkins jenkins 1308 Apr 26 18:55 ruby-rubocop-ast_1.24.0-2_source.changes /srv/reproducible-results/rbuild-debian/r-b-build.XpjqCx9r/b2: total 0 Sat Apr 26 18:55:45 UTC 2025 I: Deleting $TMPDIR on codethink03-arm64.debian.net. I: pbuilder: network access will be disabled during build I: Current time: Fri May 29 13:18:02 -12 2026 I: pbuilder-time-stamp: 1780103882 I: Building the build Environment I: extracting base tarball [/var/cache/pbuilder/unstable-reproducible-base.tgz] I: copying local configuration W: --override-config is not set; not updating apt.conf Read the manpage for details. I: mounting /proc filesystem I: mounting /sys filesystem I: creating /{dev,run}/shm I: mounting /dev/pts filesystem I: redirecting /dev/ptmx to /dev/pts/ptmx I: policy-rc.d already exists I: Copying source file I: copying [ruby-rubocop-ast_1.24.0-2.dsc] I: copying [./ruby-rubocop-ast_1.24.0.orig.tar.gz] I: copying [./ruby-rubocop-ast_1.24.0-2.debian.tar.xz] I: Extracting source dpkg-source: warning: cannot verify inline signature for ./ruby-rubocop-ast_1.24.0-2.dsc: unsupported subcommand dpkg-source: info: extracting ruby-rubocop-ast in ruby-rubocop-ast-1.24.0 dpkg-source: info: unpacking ruby-rubocop-ast_1.24.0.orig.tar.gz dpkg-source: info: unpacking ruby-rubocop-ast_1.24.0-2.debian.tar.xz dpkg-source: info: using patch list from debian/patches/series dpkg-source: info: applying 0001-gemspec-drop-git-usage.patch dpkg-source: info: applying 0002-Fix-compile-task.patch I: Not using root during the build. I: Installing the build-deps I: user script /srv/workspace/pbuilder/2893848/tmp/hooks/D02_print_environment starting I: set BUILDDIR='/build/reproducible-path' BUILDUSERGECOS='first user,first room,first work-phone,first home-phone,first other' BUILDUSERNAME='pbuilder1' BUILD_ARCH='arm64' DEBIAN_FRONTEND='noninteractive' DEB_BUILD_OPTIONS='buildinfo=+all reproducible=+all parallel=12 ' DISTRIBUTION='unstable' HOME='/root' HOST_ARCH='arm64' IFS=' ' INVOCATION_ID='d8c94ffce52c47cb84cc1da279b6dc62' LANG='C' LANGUAGE='en_US:en' LC_ALL='C' MAIL='/var/mail/root' OPTIND='1' PATH='/usr/sbin:/usr/bin:/sbin:/bin:/usr/games' PBCURRENTCOMMANDLINEOPERATION='build' PBUILDER_OPERATION='build' PBUILDER_PKGDATADIR='/usr/share/pbuilder' PBUILDER_PKGLIBDIR='/usr/lib/pbuilder' PBUILDER_SYSCONFDIR='/etc' PPID='2893848' PS1='# ' PS2='> ' PS4='+ ' PWD='/' SHELL='/bin/bash' SHLVL='2' SUDO_COMMAND='/usr/bin/timeout -k 18.1h 18h /usr/bin/ionice -c 3 /usr/bin/nice /usr/sbin/pbuilder --build --configfile /srv/reproducible-results/rbuild-debian/r-b-build.XpjqCx9r/pbuilderrc_uiMP --distribution unstable --hookdir /etc/pbuilder/first-build-hooks --debbuildopts -b --basetgz /var/cache/pbuilder/unstable-reproducible-base.tgz --buildresult /srv/reproducible-results/rbuild-debian/r-b-build.XpjqCx9r/b1 --logfile b1/build.log ruby-rubocop-ast_1.24.0-2.dsc' SUDO_GID='109' SUDO_UID='104' SUDO_USER='jenkins' TERM='unknown' TZ='/usr/share/zoneinfo/Etc/GMT+12' USER='root' _='/usr/bin/systemd-run' http_proxy='http://192.168.101.4:3128' I: uname -a Linux codethink03-arm64 6.1.0-33-cloud-arm64 #1 SMP Debian 6.1.133-1 (2025-04-10) aarch64 GNU/Linux I: ls -l /bin lrwxrwxrwx 1 root root 7 Mar 4 2025 /bin -> usr/bin I: user script /srv/workspace/pbuilder/2893848/tmp/hooks/D02_print_environment finished -> Attempting to satisfy build-dependencies -> Creating pbuilder-satisfydepends-dummy package Package: pbuilder-satisfydepends-dummy Version: 0.invalid.0 Architecture: arm64 Maintainer: Debian Pbuilder Team Description: Dummy package to satisfy dependencies with aptitude - created by pbuilder This package was created automatically by pbuilder to satisfy the build-dependencies of the package being currently built. Depends: debhelper-compat (= 13), gem2deb (>= 1), racc, rake, ruby-oedipus-lex, ruby-rspec, ruby-whitequark-parser (>= 3.1.1.0) dpkg-deb: building package 'pbuilder-satisfydepends-dummy' in '/tmp/satisfydepends-aptitude/pbuilder-satisfydepends-dummy.deb'. Selecting previously unselected package pbuilder-satisfydepends-dummy. (Reading database ... 19953 files and directories currently installed.) Preparing to unpack .../pbuilder-satisfydepends-dummy.deb ... Unpacking pbuilder-satisfydepends-dummy (0.invalid.0) ... dpkg: pbuilder-satisfydepends-dummy: dependency problems, but configuring anyway as you requested: pbuilder-satisfydepends-dummy depends on debhelper-compat (= 13); however: Package debhelper-compat is not installed. pbuilder-satisfydepends-dummy depends on gem2deb (>= 1); however: Package gem2deb is not installed. pbuilder-satisfydepends-dummy depends on racc; however: Package racc is not installed. pbuilder-satisfydepends-dummy depends on rake; however: Package rake is not installed. pbuilder-satisfydepends-dummy depends on ruby-oedipus-lex; however: Package ruby-oedipus-lex is not installed. pbuilder-satisfydepends-dummy depends on ruby-rspec; however: Package ruby-rspec is not installed. pbuilder-satisfydepends-dummy depends on ruby-whitequark-parser (>= 3.1.1.0); however: Package ruby-whitequark-parser is not installed. Setting up pbuilder-satisfydepends-dummy (0.invalid.0) ... Reading package lists... Building dependency tree... Reading state information... Initializing package states... Writing extended state information... Building tag database... pbuilder-satisfydepends-dummy is already installed at the requested version (0.invalid.0) pbuilder-satisfydepends-dummy is already installed at the requested version (0.invalid.0) The following NEW packages will be installed: autoconf{a} automake{a} autopoint{a} autotools-dev{a} bsdextrautils{a} ca-certificates{a} debhelper{a} devscripts{a} dh-autoreconf{a} dh-strip-nondeterminism{a} dwz{a} file{a} gem2deb{a} gem2deb-test-runner{a} gettext{a} gettext-base{a} gpg{a} gpg-agent{a} gpgconf{a} gpgv{a} groff-base{a} intltool-debian{a} libarchive-zip-perl{a} libassuan9{a} libb-hooks-op-check-perl{a} libclass-method-modifiers-perl{a} libclass-xsaccessor-perl{a} libclone-perl{a} libdebhelper-perl{a} libdevel-callchecker-perl{a} libdynaloader-functions-perl{a} libelf1t64{a} libencode-locale-perl{a} libexpat1{a} libffi8{a} libfile-dirlist-perl{a} libfile-homedir-perl{a} libfile-listing-perl{a} libfile-stripnondeterminism-perl{a} libfile-touch-perl{a} libfile-which-perl{a} libgcrypt20{a} libgmp-dev{a} libgmpxx4ldbl{a} libgpg-error0{a} libhtml-parser-perl{a} libhtml-tagset-perl{a} libhtml-tree-perl{a} libhttp-cookies-perl{a} libhttp-date-perl{a} libhttp-message-perl{a} libhttp-negotiate-perl{a} libimport-into-perl{a} libio-html-perl{a} libio-socket-ssl-perl{a} libksba8{a} liblwp-mediatypes-perl{a} liblwp-protocol-https-perl{a} libmagic-mgc{a} libmagic1t64{a} libmodule-runtime-perl{a} libmoo-perl{a} libnet-http-perl{a} libnet-ssleay-perl{a} libnpth0t64{a} libparams-classify-perl{a} libpipeline1{a} libpython3-stdlib{a} libpython3.13-minimal{a} libpython3.13-stdlib{a} libreadline8t64{a} librole-tiny-perl{a} libruby{a} libruby3.3{a} libsub-quote-perl{a} libtimedate-perl{a} libtool{a} libtry-tiny-perl{a} libuchardet0{a} libunistring5{a} liburi-perl{a} libwww-perl{a} libwww-robotrules-perl{a} libxml2{a} libyaml-0-2{a} m4{a} man-db{a} media-types{a} netbase{a} openssl{a} patchutils{a} perl-openssl-defaults{a} pinentry-curses{a} po-debconf{a} python3{a} python3-minimal{a} python3.13{a} python3.13-minimal{a} racc{a} rake{a} readline-common{a} ruby{a} ruby-all-dev{a} ruby-ast{a} ruby-csv{a} ruby-did-you-mean{a} ruby-diff-lcs{a} ruby-minitest{a} ruby-net-telnet{a} ruby-oedipus-lex{a} ruby-power-assert{a} ruby-rspec{a} ruby-rspec-core{a} ruby-rspec-expectations{a} ruby-rspec-mocks{a} ruby-rspec-support{a} ruby-ruby2-keywords{a} ruby-rubygems{a} ruby-test-unit{a} ruby-webrick{a} ruby-whitequark-parser{a} ruby-xmlrpc{a} ruby3.3{a} ruby3.3-dev{a} rubygems-integration{a} sensible-utils{a} sopv-gpgv{a} tzdata{a} wdiff{a} The following packages are RECOMMENDED but will NOT be installed: apt-file curl dctrl-tools debian-keyring dput dput-ng dupload equivs fonts-lato gnupg libarchive-cpio-perl libdata-dump-perl libdistro-info-perl libgit-wrapper-perl libgitlab-api-v4-perl libgpg-error-l10n libhtml-form-perl libhtml-format-perl libhttp-daemon-perl libio-compress-brotli-perl libjs-jquery libjson-perl liblist-compare-perl libltdl-dev libmail-sendmail-perl libmailtools-perl libnamespace-clean-perl libsoap-lite-perl libstring-shellquote-perl libxstring-perl licensecheck lintian lynx lzip pristine-tar python3-apt python3-argcomplete python3-debian python3-magic python3-requests python3-unidiff python3-xdg ruby-sdbm ruby3.3-doc sopv-doc strace unzip wget zip 0 packages upgraded, 129 newly installed, 0 to remove and 0 not upgraded. Need to get 35.0 MB of archives. After unpacking 148 MB will be used. Writing extended state information... Get: 1 http://deb.debian.org/debian unstable/main arm64 libpython3.13-minimal arm64 3.13.3-2 [855 kB] Get: 2 http://deb.debian.org/debian unstable/main arm64 libexpat1 arm64 2.7.1-1 [93.3 kB] Get: 3 http://deb.debian.org/debian unstable/main arm64 python3.13-minimal arm64 3.13.3-2 [1998 kB] Get: 4 http://deb.debian.org/debian unstable/main arm64 python3-minimal arm64 3.13.3-1 [27.2 kB] Get: 5 http://deb.debian.org/debian unstable/main arm64 media-types all 13.0.0 [29.3 kB] Get: 6 http://deb.debian.org/debian unstable/main arm64 netbase all 6.5 [12.4 kB] Get: 7 http://deb.debian.org/debian unstable/main arm64 tzdata all 2025b-2 [260 kB] Get: 8 http://deb.debian.org/debian unstable/main arm64 libffi8 arm64 3.4.8-2 [21.3 kB] Get: 9 http://deb.debian.org/debian unstable/main arm64 readline-common all 8.2-6 [69.4 kB] Get: 10 http://deb.debian.org/debian unstable/main arm64 libreadline8t64 arm64 8.2-6 [159 kB] Get: 11 http://deb.debian.org/debian unstable/main arm64 libpython3.13-stdlib arm64 3.13.3-2 [1890 kB] Get: 12 http://deb.debian.org/debian unstable/main arm64 python3.13 arm64 3.13.3-2 [751 kB] Get: 13 http://deb.debian.org/debian unstable/main arm64 libpython3-stdlib arm64 3.13.3-1 [10.2 kB] Get: 14 http://deb.debian.org/debian unstable/main arm64 python3 arm64 3.13.3-1 [28.2 kB] Get: 15 http://deb.debian.org/debian unstable/main arm64 sensible-utils all 0.0.25 [25.0 kB] Get: 16 http://deb.debian.org/debian unstable/main arm64 openssl arm64 3.5.0-1 [1454 kB] Get: 17 http://deb.debian.org/debian unstable/main arm64 ca-certificates all 20250419 [162 kB] Get: 18 http://deb.debian.org/debian unstable/main arm64 libmagic-mgc arm64 1:5.46-5 [338 kB] Get: 19 http://deb.debian.org/debian unstable/main arm64 libmagic1t64 arm64 1:5.46-5 [103 kB] Get: 20 http://deb.debian.org/debian unstable/main arm64 file arm64 1:5.46-5 [43.7 kB] Get: 21 http://deb.debian.org/debian unstable/main arm64 gettext-base arm64 0.23.1-1 [241 kB] Get: 22 http://deb.debian.org/debian unstable/main arm64 libuchardet0 arm64 0.0.8-1+b2 [69.2 kB] Get: 23 http://deb.debian.org/debian unstable/main arm64 groff-base arm64 1.23.0-7 [1129 kB] Get: 24 http://deb.debian.org/debian unstable/main arm64 bsdextrautils arm64 2.41-4 [93.9 kB] Get: 25 http://deb.debian.org/debian unstable/main arm64 libpipeline1 arm64 1.5.8-1 [40.2 kB] Get: 26 http://deb.debian.org/debian unstable/main arm64 man-db arm64 2.13.0-1 [1404 kB] Get: 27 http://deb.debian.org/debian unstable/main arm64 m4 arm64 1.4.19-8 [285 kB] Get: 28 http://deb.debian.org/debian unstable/main arm64 autoconf all 2.72-3.1 [494 kB] Get: 29 http://deb.debian.org/debian unstable/main arm64 autotools-dev all 20240727.1 [60.2 kB] Get: 30 http://deb.debian.org/debian unstable/main arm64 automake all 1:1.17-4 [862 kB] Get: 31 http://deb.debian.org/debian unstable/main arm64 autopoint all 0.23.1-1 [770 kB] Get: 32 http://deb.debian.org/debian unstable/main arm64 libdebhelper-perl all 13.24.2 [90.9 kB] Get: 33 http://deb.debian.org/debian unstable/main arm64 libtool all 2.5.4-4 [539 kB] Get: 34 http://deb.debian.org/debian unstable/main arm64 dh-autoreconf all 20 [17.1 kB] Get: 35 http://deb.debian.org/debian unstable/main arm64 libarchive-zip-perl all 1.68-1 [104 kB] Get: 36 http://deb.debian.org/debian unstable/main arm64 libfile-stripnondeterminism-perl all 1.14.1-2 [19.7 kB] Get: 37 http://deb.debian.org/debian unstable/main arm64 dh-strip-nondeterminism all 1.14.1-2 [8620 B] Get: 38 http://deb.debian.org/debian unstable/main arm64 libelf1t64 arm64 0.192-4 [189 kB] Get: 39 http://deb.debian.org/debian unstable/main arm64 dwz arm64 0.15-1+b1 [102 kB] Get: 40 http://deb.debian.org/debian unstable/main arm64 libunistring5 arm64 1.3-2 [453 kB] Get: 41 http://deb.debian.org/debian unstable/main arm64 libxml2 arm64 2.12.7+dfsg+really2.9.14-0.4 [629 kB] Get: 42 http://deb.debian.org/debian unstable/main arm64 gettext arm64 0.23.1-1 [1610 kB] Get: 43 http://deb.debian.org/debian unstable/main arm64 intltool-debian all 0.35.0+20060710.6 [22.9 kB] Get: 44 http://deb.debian.org/debian unstable/main arm64 po-debconf all 1.0.21+nmu1 [248 kB] Get: 45 http://deb.debian.org/debian unstable/main arm64 debhelper all 13.24.2 [919 kB] Get: 46 http://deb.debian.org/debian unstable/main arm64 libgpg-error0 arm64 1.51-4 [78.5 kB] Get: 47 http://deb.debian.org/debian unstable/main arm64 libassuan9 arm64 3.0.2-2 [59.1 kB] Get: 48 http://deb.debian.org/debian unstable/main arm64 libgcrypt20 arm64 1.11.0-7 [742 kB] Get: 49 http://deb.debian.org/debian unstable/main arm64 gpgconf arm64 2.4.7-15 [121 kB] Get: 50 http://deb.debian.org/debian unstable/main arm64 libksba8 arm64 1.6.7-2+b1 [125 kB] Get: 51 http://deb.debian.org/debian unstable/main arm64 libnpth0t64 arm64 1.8-3 [22.9 kB] Get: 52 http://deb.debian.org/debian unstable/main arm64 gpg arm64 2.4.7-15 [577 kB] Get: 53 http://deb.debian.org/debian unstable/main arm64 pinentry-curses arm64 1.3.1-2 [83.5 kB] Get: 54 http://deb.debian.org/debian unstable/main arm64 gpg-agent arm64 2.4.7-15 [248 kB] Get: 55 http://deb.debian.org/debian unstable/main arm64 libfile-dirlist-perl all 0.05-3 [7600 B] Get: 56 http://deb.debian.org/debian unstable/main arm64 libfile-which-perl all 1.27-2 [15.1 kB] Get: 57 http://deb.debian.org/debian unstable/main arm64 libfile-homedir-perl all 1.006-2 [42.4 kB] Get: 58 http://deb.debian.org/debian unstable/main arm64 libfile-touch-perl all 0.12-2 [8816 B] Get: 59 http://deb.debian.org/debian unstable/main arm64 libclass-method-modifiers-perl all 2.15-1 [18.0 kB] Get: 60 http://deb.debian.org/debian unstable/main arm64 libclass-xsaccessor-perl arm64 1.19-4+b5 [34.9 kB] Get: 61 http://deb.debian.org/debian unstable/main arm64 libb-hooks-op-check-perl arm64 0.22-3+b2 [10.6 kB] Get: 62 http://deb.debian.org/debian unstable/main arm64 libdynaloader-functions-perl all 0.004-2 [12.2 kB] Get: 63 http://deb.debian.org/debian unstable/main arm64 libdevel-callchecker-perl arm64 0.009-2 [15.7 kB] Get: 64 http://deb.debian.org/debian unstable/main arm64 libparams-classify-perl arm64 0.015-2+b4 [22.3 kB] Get: 65 http://deb.debian.org/debian unstable/main arm64 libmodule-runtime-perl all 0.018-1 [17.8 kB] Get: 66 http://deb.debian.org/debian unstable/main arm64 libimport-into-perl all 1.002005-2 [11.3 kB] Get: 67 http://deb.debian.org/debian unstable/main arm64 librole-tiny-perl all 2.002004-1 [21.4 kB] Get: 68 http://deb.debian.org/debian unstable/main arm64 libsub-quote-perl all 2.006008-1 [21.8 kB] Get: 69 http://deb.debian.org/debian unstable/main arm64 libmoo-perl all 2.005005-1 [58.0 kB] Get: 70 http://deb.debian.org/debian unstable/main arm64 libencode-locale-perl all 1.05-3 [12.9 kB] Get: 71 http://deb.debian.org/debian unstable/main arm64 libtimedate-perl all 2.3300-2 [39.3 kB] Get: 72 http://deb.debian.org/debian unstable/main arm64 libhttp-date-perl all 6.06-1 [10.7 kB] Get: 73 http://deb.debian.org/debian unstable/main arm64 libfile-listing-perl all 6.16-1 [12.4 kB] Get: 74 http://deb.debian.org/debian unstable/main arm64 libhtml-tagset-perl all 3.24-1 [14.7 kB] Get: 75 http://deb.debian.org/debian unstable/main arm64 liburi-perl all 5.30-1 [105 kB] Get: 76 http://deb.debian.org/debian unstable/main arm64 libhtml-parser-perl arm64 3.83-1+b2 [97.5 kB] Get: 77 http://deb.debian.org/debian unstable/main arm64 libhtml-tree-perl all 5.07-3 [211 kB] Get: 78 http://deb.debian.org/debian unstable/main arm64 libclone-perl arm64 0.47-1+b1 [13.7 kB] Get: 79 http://deb.debian.org/debian unstable/main arm64 libio-html-perl all 1.004-3 [16.2 kB] Get: 80 http://deb.debian.org/debian unstable/main arm64 liblwp-mediatypes-perl all 6.04-2 [20.2 kB] Get: 81 http://deb.debian.org/debian unstable/main arm64 libhttp-message-perl all 7.00-2 [79.8 kB] Get: 82 http://deb.debian.org/debian unstable/main arm64 libhttp-cookies-perl all 6.11-1 [19.1 kB] Get: 83 http://deb.debian.org/debian unstable/main arm64 libhttp-negotiate-perl all 6.01-2 [13.1 kB] Get: 84 http://deb.debian.org/debian unstable/main arm64 perl-openssl-defaults arm64 7+b2 [6712 B] Get: 85 http://deb.debian.org/debian unstable/main arm64 libnet-ssleay-perl arm64 1.94-3 [323 kB] Get: 86 http://deb.debian.org/debian unstable/main arm64 libio-socket-ssl-perl all 2.089-1 [223 kB] Get: 87 http://deb.debian.org/debian unstable/main arm64 libnet-http-perl all 6.23-1 [23.9 kB] Get: 88 http://deb.debian.org/debian unstable/main arm64 liblwp-protocol-https-perl all 6.14-1 [10.8 kB] Get: 89 http://deb.debian.org/debian unstable/main arm64 libtry-tiny-perl all 0.32-1 [22.9 kB] Get: 90 http://deb.debian.org/debian unstable/main arm64 libwww-robotrules-perl all 6.02-1 [12.9 kB] Get: 91 http://deb.debian.org/debian unstable/main arm64 libwww-perl all 6.78-1 [183 kB] Get: 92 http://deb.debian.org/debian unstable/main arm64 patchutils arm64 0.4.2-1+b1 [71.3 kB] Get: 93 http://deb.debian.org/debian unstable/main arm64 gpgv arm64 2.4.7-15 [219 kB] Get: 94 http://deb.debian.org/debian unstable/main arm64 sopv-gpgv all 0.1.4-1 [11.3 kB] Get: 95 http://deb.debian.org/debian unstable/main arm64 wdiff arm64 1.2.2-9 [122 kB] Get: 96 http://deb.debian.org/debian unstable/main arm64 devscripts all 2.25.10 [1062 kB] Get: 97 http://deb.debian.org/debian unstable/main arm64 rubygems-integration all 1.19 [5488 B] Get: 98 http://deb.debian.org/debian unstable/main arm64 ruby-csv all 3.3.4-1 [42.2 kB] Get: 99 http://deb.debian.org/debian unstable/main arm64 ruby-did-you-mean all 1.6.3-2 [20.9 kB] Get: 100 http://deb.debian.org/debian unstable/main arm64 ruby-minitest all 5.25.4-2 [66.2 kB] Get: 101 http://deb.debian.org/debian unstable/main arm64 ruby-net-telnet all 0.2.0-1 [13.1 kB] Get: 102 http://deb.debian.org/debian unstable/main arm64 ruby-ruby2-keywords all 0.0.5-1 [4300 B] Get: 103 http://deb.debian.org/debian unstable/main arm64 ruby-power-assert all 2.0.3-1 [11.8 kB] Get: 104 http://deb.debian.org/debian unstable/main arm64 ruby-test-unit all 3.6.2-1 [79.1 kB] Get: 105 http://deb.debian.org/debian unstable/main arm64 ruby-webrick all 1.9.1-1 [59.6 kB] Get: 106 http://deb.debian.org/debian unstable/main arm64 ruby-xmlrpc all 0.3.3-2 [24.4 kB] Get: 107 http://deb.debian.org/debian unstable/main arm64 libyaml-0-2 arm64 0.2.5-2 [49.2 kB] Get: 108 http://deb.debian.org/debian unstable/main arm64 libruby3.3 arm64 3.3.8-1 [6140 kB] Get: 109 http://deb.debian.org/debian unstable/main arm64 ruby3.3 arm64 3.3.8-1 [834 kB] Get: 110 http://deb.debian.org/debian unstable/main arm64 libruby arm64 1:3.3+b1 [5436 B] Get: 111 http://deb.debian.org/debian unstable/main arm64 ruby-rubygems all 3.6.7-2 [407 kB] Get: 112 http://deb.debian.org/debian unstable/main arm64 ruby arm64 1:3.3+b1 [6560 B] Get: 113 http://deb.debian.org/debian unstable/main arm64 rake all 13.2.1-1 [65.2 kB] Get: 114 http://deb.debian.org/debian unstable/main arm64 gem2deb-test-runner arm64 2.2.5 [17.9 kB] Get: 115 http://deb.debian.org/debian unstable/main arm64 libgmpxx4ldbl arm64 2:6.3.0+dfsg-3 [329 kB] Get: 116 http://deb.debian.org/debian unstable/main arm64 libgmp-dev arm64 2:6.3.0+dfsg-3 [621 kB] Get: 117 http://deb.debian.org/debian unstable/main arm64 ruby3.3-dev arm64 3.3.8-1 [1045 kB] Get: 118 http://deb.debian.org/debian unstable/main arm64 ruby-all-dev arm64 1:3.3+b1 [6496 B] Get: 119 http://deb.debian.org/debian unstable/main arm64 gem2deb arm64 2.2.5 [48.0 kB] Get: 120 http://deb.debian.org/debian unstable/main arm64 racc all 1.8.1-1 [75.4 kB] Get: 121 http://deb.debian.org/debian unstable/main arm64 ruby-ast all 2.4.3-1 [10.7 kB] Get: 122 http://deb.debian.org/debian unstable/main arm64 ruby-diff-lcs all 1.5.1-1 [28.1 kB] Get: 123 http://deb.debian.org/debian unstable/main arm64 ruby-oedipus-lex all 2.6.0-2 [19.1 kB] Get: 124 http://deb.debian.org/debian unstable/main arm64 ruby-rspec-support all 3.13.0c0e0m0s1-2 [28.5 kB] Get: 125 http://deb.debian.org/debian unstable/main arm64 ruby-rspec-core all 3.13.0c0e0m0s1-2 [164 kB] Get: 126 http://deb.debian.org/debian unstable/main arm64 ruby-rspec-expectations all 3.13.0c0e0m0s1-2 [90.2 kB] Get: 127 http://deb.debian.org/debian unstable/main arm64 ruby-rspec-mocks all 3.13.0c0e0m0s1-2 [81.3 kB] Get: 128 http://deb.debian.org/debian unstable/main arm64 ruby-rspec all 3.13.0c0e0m0s1-2 [5184 B] Get: 129 http://deb.debian.org/debian unstable/main arm64 ruby-whitequark-parser all 3.3.4.2-2 [507 kB] Fetched 35.0 MB in 0s (95.9 MB/s) Preconfiguring packages ... Selecting previously unselected package libpython3.13-minimal:arm64. (Reading database ... (Reading database ... 5% (Reading database ... 10% (Reading database ... 15% (Reading database ... 20% (Reading database ... 25% (Reading database ... 30% (Reading database ... 35% (Reading database ... 40% (Reading database ... 45% (Reading database ... 50% (Reading database ... 55% (Reading database ... 60% (Reading database ... 65% (Reading database ... 70% (Reading database ... 75% (Reading database ... 80% (Reading database ... 85% (Reading database ... 90% (Reading database ... 95% (Reading database ... 100% (Reading database ... 19953 files and directories currently installed.) Preparing to unpack .../libpython3.13-minimal_3.13.3-2_arm64.deb ... Unpacking libpython3.13-minimal:arm64 (3.13.3-2) ... Selecting previously unselected package libexpat1:arm64. Preparing to unpack .../libexpat1_2.7.1-1_arm64.deb ... Unpacking libexpat1:arm64 (2.7.1-1) ... Selecting previously unselected package python3.13-minimal. Preparing to unpack .../python3.13-minimal_3.13.3-2_arm64.deb ... Unpacking python3.13-minimal (3.13.3-2) ... Setting up libpython3.13-minimal:arm64 (3.13.3-2) ... Setting up libexpat1:arm64 (2.7.1-1) ... Setting up python3.13-minimal (3.13.3-2) ... Selecting previously unselected package python3-minimal. (Reading database ... (Reading database ... 5% (Reading database ... 10% (Reading database ... 15% (Reading database ... 20% (Reading database ... 25% (Reading database ... 30% (Reading database ... 35% (Reading database ... 40% (Reading database ... 45% (Reading database ... 50% (Reading database ... 55% (Reading database ... 60% (Reading database ... 65% (Reading database ... 70% (Reading database ... 75% (Reading database ... 80% (Reading database ... 85% (Reading database ... 90% (Reading database ... 95% (Reading database ... 100% (Reading database ... 20287 files and directories currently installed.) Preparing to unpack .../0-python3-minimal_3.13.3-1_arm64.deb ... Unpacking python3-minimal (3.13.3-1) ... Selecting previously unselected package media-types. Preparing to unpack .../1-media-types_13.0.0_all.deb ... Unpacking media-types (13.0.0) ... Selecting previously unselected package netbase. Preparing to unpack .../2-netbase_6.5_all.deb ... Unpacking netbase (6.5) ... Selecting previously unselected package tzdata. Preparing to unpack .../3-tzdata_2025b-2_all.deb ... Unpacking tzdata (2025b-2) ... Selecting previously unselected package libffi8:arm64. Preparing to unpack .../4-libffi8_3.4.8-2_arm64.deb ... Unpacking libffi8:arm64 (3.4.8-2) ... Selecting previously unselected package readline-common. Preparing to unpack .../5-readline-common_8.2-6_all.deb ... Unpacking readline-common (8.2-6) ... Selecting previously unselected package libreadline8t64:arm64. Preparing to unpack .../6-libreadline8t64_8.2-6_arm64.deb ... Adding 'diversion of /lib/aarch64-linux-gnu/libhistory.so.8 to /lib/aarch64-linux-gnu/libhistory.so.8.usr-is-merged by libreadline8t64' Adding 'diversion of /lib/aarch64-linux-gnu/libhistory.so.8.2 to /lib/aarch64-linux-gnu/libhistory.so.8.2.usr-is-merged by libreadline8t64' Adding 'diversion of /lib/aarch64-linux-gnu/libreadline.so.8 to /lib/aarch64-linux-gnu/libreadline.so.8.usr-is-merged by libreadline8t64' Adding 'diversion of /lib/aarch64-linux-gnu/libreadline.so.8.2 to /lib/aarch64-linux-gnu/libreadline.so.8.2.usr-is-merged by libreadline8t64' Unpacking libreadline8t64:arm64 (8.2-6) ... Selecting previously unselected package libpython3.13-stdlib:arm64. Preparing to unpack .../7-libpython3.13-stdlib_3.13.3-2_arm64.deb ... Unpacking libpython3.13-stdlib:arm64 (3.13.3-2) ... Selecting previously unselected package python3.13. Preparing to unpack .../8-python3.13_3.13.3-2_arm64.deb ... Unpacking python3.13 (3.13.3-2) ... Selecting previously unselected package libpython3-stdlib:arm64. Preparing to unpack .../9-libpython3-stdlib_3.13.3-1_arm64.deb ... Unpacking libpython3-stdlib:arm64 (3.13.3-1) ... Setting up python3-minimal (3.13.3-1) ... Selecting previously unselected package python3. (Reading database ... (Reading database ... 5% (Reading database ... 10% (Reading database ... 15% (Reading database ... 20% (Reading database ... 25% (Reading database ... 30% (Reading database ... 35% (Reading database ... 40% (Reading database ... 45% (Reading database ... 50% (Reading database ... 55% (Reading database ... 60% (Reading database ... 65% (Reading database ... 70% (Reading database ... 75% (Reading database ... 80% (Reading database ... 85% (Reading database ... 90% (Reading database ... 95% (Reading database ... 100% (Reading database ... 21299 files and directories currently installed.) Preparing to unpack .../000-python3_3.13.3-1_arm64.deb ... Unpacking python3 (3.13.3-1) ... Selecting previously unselected package sensible-utils. Preparing to unpack .../001-sensible-utils_0.0.25_all.deb ... Unpacking sensible-utils (0.0.25) ... Selecting previously unselected package openssl. Preparing to unpack .../002-openssl_3.5.0-1_arm64.deb ... Unpacking openssl (3.5.0-1) ... Selecting previously unselected package ca-certificates. Preparing to unpack .../003-ca-certificates_20250419_all.deb ... Unpacking ca-certificates (20250419) ... Selecting previously unselected package libmagic-mgc. Preparing to unpack .../004-libmagic-mgc_1%3a5.46-5_arm64.deb ... Unpacking libmagic-mgc (1:5.46-5) ... Selecting previously unselected package libmagic1t64:arm64. Preparing to unpack .../005-libmagic1t64_1%3a5.46-5_arm64.deb ... Unpacking libmagic1t64:arm64 (1:5.46-5) ... Selecting previously unselected package file. Preparing to unpack .../006-file_1%3a5.46-5_arm64.deb ... Unpacking file (1:5.46-5) ... Selecting previously unselected package gettext-base. Preparing to unpack .../007-gettext-base_0.23.1-1_arm64.deb ... Unpacking gettext-base (0.23.1-1) ... Selecting previously unselected package libuchardet0:arm64. Preparing to unpack .../008-libuchardet0_0.0.8-1+b2_arm64.deb ... Unpacking libuchardet0:arm64 (0.0.8-1+b2) ... Selecting previously unselected package groff-base. Preparing to unpack .../009-groff-base_1.23.0-7_arm64.deb ... Unpacking groff-base (1.23.0-7) ... Selecting previously unselected package bsdextrautils. Preparing to unpack .../010-bsdextrautils_2.41-4_arm64.deb ... Unpacking bsdextrautils (2.41-4) ... Selecting previously unselected package libpipeline1:arm64. Preparing to unpack .../011-libpipeline1_1.5.8-1_arm64.deb ... Unpacking libpipeline1:arm64 (1.5.8-1) ... Selecting previously unselected package man-db. Preparing to unpack .../012-man-db_2.13.0-1_arm64.deb ... Unpacking man-db (2.13.0-1) ... Selecting previously unselected package m4. Preparing to unpack .../013-m4_1.4.19-8_arm64.deb ... Unpacking m4 (1.4.19-8) ... Selecting previously unselected package autoconf. Preparing to unpack .../014-autoconf_2.72-3.1_all.deb ... Unpacking autoconf (2.72-3.1) ... Selecting previously unselected package autotools-dev. Preparing to unpack .../015-autotools-dev_20240727.1_all.deb ... Unpacking autotools-dev (20240727.1) ... Selecting previously unselected package automake. Preparing to unpack .../016-automake_1%3a1.17-4_all.deb ... Unpacking automake (1:1.17-4) ... Selecting previously unselected package autopoint. Preparing to unpack .../017-autopoint_0.23.1-1_all.deb ... Unpacking autopoint (0.23.1-1) ... Selecting previously unselected package libdebhelper-perl. Preparing to unpack .../018-libdebhelper-perl_13.24.2_all.deb ... Unpacking libdebhelper-perl (13.24.2) ... Selecting previously unselected package libtool. Preparing to unpack .../019-libtool_2.5.4-4_all.deb ... Unpacking libtool (2.5.4-4) ... Selecting previously unselected package dh-autoreconf. Preparing to unpack .../020-dh-autoreconf_20_all.deb ... Unpacking dh-autoreconf (20) ... Selecting previously unselected package libarchive-zip-perl. Preparing to unpack .../021-libarchive-zip-perl_1.68-1_all.deb ... Unpacking libarchive-zip-perl (1.68-1) ... Selecting previously unselected package libfile-stripnondeterminism-perl. Preparing to unpack .../022-libfile-stripnondeterminism-perl_1.14.1-2_all.deb ... Unpacking libfile-stripnondeterminism-perl (1.14.1-2) ... Selecting previously unselected package dh-strip-nondeterminism. Preparing to unpack .../023-dh-strip-nondeterminism_1.14.1-2_all.deb ... Unpacking dh-strip-nondeterminism (1.14.1-2) ... Selecting previously unselected package libelf1t64:arm64. Preparing to unpack .../024-libelf1t64_0.192-4_arm64.deb ... Unpacking libelf1t64:arm64 (0.192-4) ... Selecting previously unselected package dwz. Preparing to unpack .../025-dwz_0.15-1+b1_arm64.deb ... Unpacking dwz (0.15-1+b1) ... Selecting previously unselected package libunistring5:arm64. Preparing to unpack .../026-libunistring5_1.3-2_arm64.deb ... Unpacking libunistring5:arm64 (1.3-2) ... Selecting previously unselected package libxml2:arm64. Preparing to unpack .../027-libxml2_2.12.7+dfsg+really2.9.14-0.4_arm64.deb ... Unpacking libxml2:arm64 (2.12.7+dfsg+really2.9.14-0.4) ... Selecting previously unselected package gettext. Preparing to unpack .../028-gettext_0.23.1-1_arm64.deb ... Unpacking gettext (0.23.1-1) ... Selecting previously unselected package intltool-debian. Preparing to unpack .../029-intltool-debian_0.35.0+20060710.6_all.deb ... Unpacking intltool-debian (0.35.0+20060710.6) ... Selecting previously unselected package po-debconf. Preparing to unpack .../030-po-debconf_1.0.21+nmu1_all.deb ... Unpacking po-debconf (1.0.21+nmu1) ... Selecting previously unselected package debhelper. Preparing to unpack .../031-debhelper_13.24.2_all.deb ... Unpacking debhelper (13.24.2) ... Selecting previously unselected package libgpg-error0:arm64. Preparing to unpack .../032-libgpg-error0_1.51-4_arm64.deb ... Unpacking libgpg-error0:arm64 (1.51-4) ... Selecting previously unselected package libassuan9:arm64. Preparing to unpack .../033-libassuan9_3.0.2-2_arm64.deb ... Unpacking libassuan9:arm64 (3.0.2-2) ... Selecting previously unselected package libgcrypt20:arm64. Preparing to unpack .../034-libgcrypt20_1.11.0-7_arm64.deb ... Unpacking libgcrypt20:arm64 (1.11.0-7) ... Selecting previously unselected package gpgconf. Preparing to unpack .../035-gpgconf_2.4.7-15_arm64.deb ... Unpacking gpgconf (2.4.7-15) ... Selecting previously unselected package libksba8:arm64. Preparing to unpack .../036-libksba8_1.6.7-2+b1_arm64.deb ... Unpacking libksba8:arm64 (1.6.7-2+b1) ... Selecting previously unselected package libnpth0t64:arm64. Preparing to unpack .../037-libnpth0t64_1.8-3_arm64.deb ... Unpacking libnpth0t64:arm64 (1.8-3) ... Selecting previously unselected package gpg. Preparing to unpack .../038-gpg_2.4.7-15_arm64.deb ... Unpacking gpg (2.4.7-15) ... Selecting previously unselected package pinentry-curses. Preparing to unpack .../039-pinentry-curses_1.3.1-2_arm64.deb ... Unpacking pinentry-curses (1.3.1-2) ... Selecting previously unselected package gpg-agent. Preparing to unpack .../040-gpg-agent_2.4.7-15_arm64.deb ... Unpacking gpg-agent (2.4.7-15) ... Selecting previously unselected package libfile-dirlist-perl. Preparing to unpack .../041-libfile-dirlist-perl_0.05-3_all.deb ... Unpacking libfile-dirlist-perl (0.05-3) ... Selecting previously unselected package libfile-which-perl. Preparing to unpack .../042-libfile-which-perl_1.27-2_all.deb ... Unpacking libfile-which-perl (1.27-2) ... Selecting previously unselected package libfile-homedir-perl. Preparing to unpack .../043-libfile-homedir-perl_1.006-2_all.deb ... Unpacking libfile-homedir-perl (1.006-2) ... Selecting previously unselected package libfile-touch-perl. Preparing to unpack .../044-libfile-touch-perl_0.12-2_all.deb ... Unpacking libfile-touch-perl (0.12-2) ... Selecting previously unselected package libclass-method-modifiers-perl. Preparing to unpack .../045-libclass-method-modifiers-perl_2.15-1_all.deb ... Unpacking libclass-method-modifiers-perl (2.15-1) ... Selecting previously unselected package libclass-xsaccessor-perl. Preparing to unpack .../046-libclass-xsaccessor-perl_1.19-4+b5_arm64.deb ... Unpacking libclass-xsaccessor-perl (1.19-4+b5) ... Selecting previously unselected package libb-hooks-op-check-perl:arm64. Preparing to unpack .../047-libb-hooks-op-check-perl_0.22-3+b2_arm64.deb ... Unpacking libb-hooks-op-check-perl:arm64 (0.22-3+b2) ... Selecting previously unselected package libdynaloader-functions-perl. Preparing to unpack .../048-libdynaloader-functions-perl_0.004-2_all.deb ... Unpacking libdynaloader-functions-perl (0.004-2) ... Selecting previously unselected package libdevel-callchecker-perl:arm64. Preparing to unpack .../049-libdevel-callchecker-perl_0.009-2_arm64.deb ... Unpacking libdevel-callchecker-perl:arm64 (0.009-2) ... Selecting previously unselected package libparams-classify-perl:arm64. Preparing to unpack .../050-libparams-classify-perl_0.015-2+b4_arm64.deb ... Unpacking libparams-classify-perl:arm64 (0.015-2+b4) ... Selecting previously unselected package libmodule-runtime-perl. Preparing to unpack .../051-libmodule-runtime-perl_0.018-1_all.deb ... Unpacking libmodule-runtime-perl (0.018-1) ... Selecting previously unselected package libimport-into-perl. Preparing to unpack .../052-libimport-into-perl_1.002005-2_all.deb ... Unpacking libimport-into-perl (1.002005-2) ... Selecting previously unselected package librole-tiny-perl. Preparing to unpack .../053-librole-tiny-perl_2.002004-1_all.deb ... Unpacking librole-tiny-perl (2.002004-1) ... Selecting previously unselected package libsub-quote-perl. Preparing to unpack .../054-libsub-quote-perl_2.006008-1_all.deb ... Unpacking libsub-quote-perl (2.006008-1) ... Selecting previously unselected package libmoo-perl. Preparing to unpack .../055-libmoo-perl_2.005005-1_all.deb ... Unpacking libmoo-perl (2.005005-1) ... Selecting previously unselected package libencode-locale-perl. Preparing to unpack .../056-libencode-locale-perl_1.05-3_all.deb ... Unpacking libencode-locale-perl (1.05-3) ... Selecting previously unselected package libtimedate-perl. Preparing to unpack .../057-libtimedate-perl_2.3300-2_all.deb ... Unpacking libtimedate-perl (2.3300-2) ... Selecting previously unselected package libhttp-date-perl. Preparing to unpack .../058-libhttp-date-perl_6.06-1_all.deb ... Unpacking libhttp-date-perl (6.06-1) ... Selecting previously unselected package libfile-listing-perl. Preparing to unpack .../059-libfile-listing-perl_6.16-1_all.deb ... Unpacking libfile-listing-perl (6.16-1) ... Selecting previously unselected package libhtml-tagset-perl. Preparing to unpack .../060-libhtml-tagset-perl_3.24-1_all.deb ... Unpacking libhtml-tagset-perl (3.24-1) ... Selecting previously unselected package liburi-perl. Preparing to unpack .../061-liburi-perl_5.30-1_all.deb ... Unpacking liburi-perl (5.30-1) ... Selecting previously unselected package libhtml-parser-perl:arm64. Preparing to unpack .../062-libhtml-parser-perl_3.83-1+b2_arm64.deb ... Unpacking libhtml-parser-perl:arm64 (3.83-1+b2) ... Selecting previously unselected package libhtml-tree-perl. Preparing to unpack .../063-libhtml-tree-perl_5.07-3_all.deb ... Unpacking libhtml-tree-perl (5.07-3) ... Selecting previously unselected package libclone-perl:arm64. Preparing to unpack .../064-libclone-perl_0.47-1+b1_arm64.deb ... Unpacking libclone-perl:arm64 (0.47-1+b1) ... Selecting previously unselected package libio-html-perl. Preparing to unpack .../065-libio-html-perl_1.004-3_all.deb ... Unpacking libio-html-perl (1.004-3) ... Selecting previously unselected package liblwp-mediatypes-perl. Preparing to unpack .../066-liblwp-mediatypes-perl_6.04-2_all.deb ... Unpacking liblwp-mediatypes-perl (6.04-2) ... Selecting previously unselected package libhttp-message-perl. Preparing to unpack .../067-libhttp-message-perl_7.00-2_all.deb ... Unpacking libhttp-message-perl (7.00-2) ... Selecting previously unselected package libhttp-cookies-perl. Preparing to unpack .../068-libhttp-cookies-perl_6.11-1_all.deb ... Unpacking libhttp-cookies-perl (6.11-1) ... Selecting previously unselected package libhttp-negotiate-perl. Preparing to unpack .../069-libhttp-negotiate-perl_6.01-2_all.deb ... Unpacking libhttp-negotiate-perl (6.01-2) ... Selecting previously unselected package perl-openssl-defaults:arm64. Preparing to unpack .../070-perl-openssl-defaults_7+b2_arm64.deb ... Unpacking perl-openssl-defaults:arm64 (7+b2) ... Selecting previously unselected package libnet-ssleay-perl:arm64. Preparing to unpack .../071-libnet-ssleay-perl_1.94-3_arm64.deb ... Unpacking libnet-ssleay-perl:arm64 (1.94-3) ... Selecting previously unselected package libio-socket-ssl-perl. Preparing to unpack .../072-libio-socket-ssl-perl_2.089-1_all.deb ... Unpacking libio-socket-ssl-perl (2.089-1) ... Selecting previously unselected package libnet-http-perl. Preparing to unpack .../073-libnet-http-perl_6.23-1_all.deb ... Unpacking libnet-http-perl (6.23-1) ... Selecting previously unselected package liblwp-protocol-https-perl. Preparing to unpack .../074-liblwp-protocol-https-perl_6.14-1_all.deb ... Unpacking liblwp-protocol-https-perl (6.14-1) ... Selecting previously unselected package libtry-tiny-perl. Preparing to unpack .../075-libtry-tiny-perl_0.32-1_all.deb ... Unpacking libtry-tiny-perl (0.32-1) ... Selecting previously unselected package libwww-robotrules-perl. Preparing to unpack .../076-libwww-robotrules-perl_6.02-1_all.deb ... Unpacking libwww-robotrules-perl (6.02-1) ... Selecting previously unselected package libwww-perl. Preparing to unpack .../077-libwww-perl_6.78-1_all.deb ... Unpacking libwww-perl (6.78-1) ... Selecting previously unselected package patchutils. Preparing to unpack .../078-patchutils_0.4.2-1+b1_arm64.deb ... Unpacking patchutils (0.4.2-1+b1) ... Selecting previously unselected package gpgv. Preparing to unpack .../079-gpgv_2.4.7-15_arm64.deb ... Unpacking gpgv (2.4.7-15) ... Selecting previously unselected package sopv-gpgv. Preparing to unpack .../080-sopv-gpgv_0.1.4-1_all.deb ... Unpacking sopv-gpgv (0.1.4-1) ... Selecting previously unselected package wdiff. Preparing to unpack .../081-wdiff_1.2.2-9_arm64.deb ... Unpacking wdiff (1.2.2-9) ... Selecting previously unselected package devscripts. Preparing to unpack .../082-devscripts_2.25.10_all.deb ... Unpacking devscripts (2.25.10) ... Selecting previously unselected package rubygems-integration. Preparing to unpack .../083-rubygems-integration_1.19_all.deb ... Unpacking rubygems-integration (1.19) ... Selecting previously unselected package ruby-csv. Preparing to unpack .../084-ruby-csv_3.3.4-1_all.deb ... Unpacking ruby-csv (3.3.4-1) ... Selecting previously unselected package ruby-did-you-mean. Preparing to unpack .../085-ruby-did-you-mean_1.6.3-2_all.deb ... Unpacking ruby-did-you-mean (1.6.3-2) ... Selecting previously unselected package ruby-minitest. Preparing to unpack .../086-ruby-minitest_5.25.4-2_all.deb ... Unpacking ruby-minitest (5.25.4-2) ... Selecting previously unselected package ruby-net-telnet. Preparing to unpack .../087-ruby-net-telnet_0.2.0-1_all.deb ... Unpacking ruby-net-telnet (0.2.0-1) ... Selecting previously unselected package ruby-ruby2-keywords. Preparing to unpack .../088-ruby-ruby2-keywords_0.0.5-1_all.deb ... Unpacking ruby-ruby2-keywords (0.0.5-1) ... Selecting previously unselected package ruby-power-assert. Preparing to unpack .../089-ruby-power-assert_2.0.3-1_all.deb ... Unpacking ruby-power-assert (2.0.3-1) ... Selecting previously unselected package ruby-test-unit. Preparing to unpack .../090-ruby-test-unit_3.6.2-1_all.deb ... Unpacking ruby-test-unit (3.6.2-1) ... Selecting previously unselected package ruby-webrick. Preparing to unpack .../091-ruby-webrick_1.9.1-1_all.deb ... Unpacking ruby-webrick (1.9.1-1) ... Selecting previously unselected package ruby-xmlrpc. Preparing to unpack .../092-ruby-xmlrpc_0.3.3-2_all.deb ... Unpacking ruby-xmlrpc (0.3.3-2) ... Selecting previously unselected package libyaml-0-2:arm64. Preparing to unpack .../093-libyaml-0-2_0.2.5-2_arm64.deb ... Unpacking libyaml-0-2:arm64 (0.2.5-2) ... Selecting previously unselected package libruby3.3:arm64. Preparing to unpack .../094-libruby3.3_3.3.8-1_arm64.deb ... Unpacking libruby3.3:arm64 (3.3.8-1) ... Selecting previously unselected package ruby3.3. Preparing to unpack .../095-ruby3.3_3.3.8-1_arm64.deb ... Unpacking ruby3.3 (3.3.8-1) ... Selecting previously unselected package libruby:arm64. Preparing to unpack .../096-libruby_1%3a3.3+b1_arm64.deb ... Unpacking libruby:arm64 (1:3.3+b1) ... Selecting previously unselected package ruby-rubygems. Preparing to unpack .../097-ruby-rubygems_3.6.7-2_all.deb ... Unpacking ruby-rubygems (3.6.7-2) ... Selecting previously unselected package ruby. Preparing to unpack .../098-ruby_1%3a3.3+b1_arm64.deb ... Unpacking ruby (1:3.3+b1) ... Selecting previously unselected package rake. Preparing to unpack .../099-rake_13.2.1-1_all.deb ... Unpacking rake (13.2.1-1) ... Selecting previously unselected package gem2deb-test-runner. Preparing to unpack .../100-gem2deb-test-runner_2.2.5_arm64.deb ... Unpacking gem2deb-test-runner (2.2.5) ... Selecting previously unselected package libgmpxx4ldbl:arm64. Preparing to unpack .../101-libgmpxx4ldbl_2%3a6.3.0+dfsg-3_arm64.deb ... Unpacking libgmpxx4ldbl:arm64 (2:6.3.0+dfsg-3) ... Selecting previously unselected package libgmp-dev:arm64. Preparing to unpack .../102-libgmp-dev_2%3a6.3.0+dfsg-3_arm64.deb ... Unpacking libgmp-dev:arm64 (2:6.3.0+dfsg-3) ... Selecting previously unselected package ruby3.3-dev:arm64. Preparing to unpack .../103-ruby3.3-dev_3.3.8-1_arm64.deb ... Unpacking ruby3.3-dev:arm64 (3.3.8-1) ... Selecting previously unselected package ruby-all-dev:arm64. Preparing to unpack .../104-ruby-all-dev_1%3a3.3+b1_arm64.deb ... Unpacking ruby-all-dev:arm64 (1:3.3+b1) ... Selecting previously unselected package gem2deb. Preparing to unpack .../105-gem2deb_2.2.5_arm64.deb ... Unpacking gem2deb (2.2.5) ... Selecting previously unselected package racc. Preparing to unpack .../106-racc_1.8.1-1_all.deb ... Unpacking racc (1.8.1-1) ... Selecting previously unselected package ruby-ast. Preparing to unpack .../107-ruby-ast_2.4.3-1_all.deb ... Unpacking ruby-ast (2.4.3-1) ... Selecting previously unselected package ruby-diff-lcs. Preparing to unpack .../108-ruby-diff-lcs_1.5.1-1_all.deb ... Unpacking ruby-diff-lcs (1.5.1-1) ... Selecting previously unselected package ruby-oedipus-lex. Preparing to unpack .../109-ruby-oedipus-lex_2.6.0-2_all.deb ... Unpacking ruby-oedipus-lex (2.6.0-2) ... Selecting previously unselected package ruby-rspec-support. Preparing to unpack .../110-ruby-rspec-support_3.13.0c0e0m0s1-2_all.deb ... Unpacking ruby-rspec-support (3.13.0c0e0m0s1-2) ... Selecting previously unselected package ruby-rspec-core. Preparing to unpack .../111-ruby-rspec-core_3.13.0c0e0m0s1-2_all.deb ... Unpacking ruby-rspec-core (3.13.0c0e0m0s1-2) ... Selecting previously unselected package ruby-rspec-expectations. Preparing to unpack .../112-ruby-rspec-expectations_3.13.0c0e0m0s1-2_all.deb ... Unpacking ruby-rspec-expectations (3.13.0c0e0m0s1-2) ... Selecting previously unselected package ruby-rspec-mocks. Preparing to unpack .../113-ruby-rspec-mocks_3.13.0c0e0m0s1-2_all.deb ... Unpacking ruby-rspec-mocks (3.13.0c0e0m0s1-2) ... Selecting previously unselected package ruby-rspec. Preparing to unpack .../114-ruby-rspec_3.13.0c0e0m0s1-2_all.deb ... Unpacking ruby-rspec (3.13.0c0e0m0s1-2) ... Selecting previously unselected package ruby-whitequark-parser. Preparing to unpack .../115-ruby-whitequark-parser_3.3.4.2-2_all.deb ... Unpacking ruby-whitequark-parser (3.3.4.2-2) ... Setting up media-types (13.0.0) ... Setting up libpipeline1:arm64 (1.5.8-1) ... Setting up wdiff (1.2.2-9) ... Setting up libfile-which-perl (1.27-2) ... Setting up libnpth0t64:arm64 (1.8-3) ... Setting up ruby-ruby2-keywords (0.0.5-1) ... Setting up ruby-oedipus-lex (2.6.0-2) ... Setting up bsdextrautils (2.41-4) ... Setting up libgpg-error0:arm64 (1.51-4) ... Setting up libdynaloader-functions-perl (0.004-2) ... Setting up libclass-method-modifiers-perl (2.15-1) ... Setting up ruby-power-assert (2.0.3-1) ... Setting up libmagic-mgc (1:5.46-5) ... Setting up libclone-perl:arm64 (0.47-1+b1) ... Setting up libarchive-zip-perl (1.68-1) ... Setting up libyaml-0-2:arm64 (0.2.5-2) ... Setting up libhtml-tagset-perl (3.24-1) ... Setting up libdebhelper-perl (13.24.2) ... Setting up liblwp-mediatypes-perl (6.04-2) ... Setting up libmagic1t64:arm64 (1:5.46-5) ... Setting up libtry-tiny-perl (0.32-1) ... Setting up perl-openssl-defaults:arm64 (7+b2) ... Setting up gettext-base (0.23.1-1) ... Setting up m4 (1.4.19-8) ... Setting up libgcrypt20:arm64 (1.11.0-7) ... Setting up libencode-locale-perl (1.05-3) ... Setting up file (1:5.46-5) ... Setting up libelf1t64:arm64 (0.192-4) ... Setting up tzdata (2025b-2) ... Current default time zone: 'Etc/UTC' Local time is now: Sat May 30 01:18:22 UTC 2026. Universal Time is now: Sat May 30 01:18:22 UTC 2026. Run 'dpkg-reconfigure tzdata' if you wish to change it. Setting up ruby-minitest (5.25.4-2) ... Setting up autotools-dev (20240727.1) ... Setting up libgmpxx4ldbl:arm64 (2:6.3.0+dfsg-3) ... Setting up ruby-test-unit (3.6.2-1) ... Setting up ruby-ast (2.4.3-1) ... Setting up ruby-net-telnet (0.2.0-1) ... Setting up ruby-csv (3.3.4-1) ... Setting up libunistring5:arm64 (1.3-2) ... Setting up libio-html-perl (1.004-3) ... Setting up autopoint (0.23.1-1) ... Setting up libb-hooks-op-check-perl:arm64 (0.22-3+b2) ... Setting up autoconf (2.72-3.1) ... Setting up ruby-rspec-support (3.13.0c0e0m0s1-2) ... Setting up libtimedate-perl (2.3300-2) ... Setting up ruby-webrick (1.9.1-1) ... Setting up libffi8:arm64 (3.4.8-2) ... Setting up dwz (0.15-1+b1) ... Setting up sensible-utils (0.0.25) ... Setting up gpgv (2.4.7-15) ... Setting up libuchardet0:arm64 (0.0.8-1+b2) ... Setting up libassuan9:arm64 (3.0.2-2) ... Setting up librole-tiny-perl (2.002004-1) ... Setting up netbase (6.5) ... Setting up libsub-quote-perl (2.006008-1) ... Setting up libclass-xsaccessor-perl (1.19-4+b5) ... Setting up ruby-did-you-mean (1.6.3-2) ... Setting up libfile-dirlist-perl (0.05-3) ... Setting up libfile-homedir-perl (1.006-2) ... Setting up openssl (3.5.0-1) ... Setting up readline-common (8.2-6) ... Setting up ruby-xmlrpc (0.3.3-2) ... Setting up libxml2:arm64 (2.12.7+dfsg+really2.9.14-0.4) ... Setting up liburi-perl (5.30-1) ... Setting up libfile-touch-perl (0.12-2) ... Setting up libnet-ssleay-perl:arm64 (1.94-3) ... Setting up automake (1:1.17-4) ... update-alternatives: using /usr/bin/automake-1.17 to provide /usr/bin/automake (automake) in auto mode Setting up libksba8:arm64 (1.6.7-2+b1) ... Setting up pinentry-curses (1.3.1-2) ... Setting up libfile-stripnondeterminism-perl (1.14.1-2) ... Setting up libhttp-date-perl (6.06-1) ... Setting up gettext (0.23.1-1) ... Setting up libgmp-dev:arm64 (2:6.3.0+dfsg-3) ... Setting up libfile-listing-perl (6.16-1) ... Setting up libtool (2.5.4-4) ... Setting up libnet-http-perl (6.23-1) ... Setting up libdevel-callchecker-perl:arm64 (0.009-2) ... Setting up intltool-debian (0.35.0+20060710.6) ... Setting up dh-autoreconf (20) ... Setting up patchutils (0.4.2-1+b1) ... Setting up ca-certificates (20250419) ... Updating certificates in /etc/ssl/certs... 150 added, 0 removed; done. Setting up libreadline8t64:arm64 (8.2-6) ... Setting up dh-strip-nondeterminism (1.14.1-2) ... Setting up libwww-robotrules-perl (6.02-1) ... Setting up groff-base (1.23.0-7) ... Setting up libhtml-parser-perl:arm64 (3.83-1+b2) ... Setting up gpgconf (2.4.7-15) ... Setting up libpython3.13-stdlib:arm64 (3.13.3-2) ... Setting up libio-socket-ssl-perl (2.089-1) ... Setting up gpg (2.4.7-15) ... Setting up libpython3-stdlib:arm64 (3.13.3-1) ... Setting up libhttp-message-perl (7.00-2) ... Setting up libhttp-negotiate-perl (6.01-2) ... Setting up gpg-agent (2.4.7-15) ... Setting up libhttp-cookies-perl (6.11-1) ... Setting up python3.13 (3.13.3-2) ... Setting up po-debconf (1.0.21+nmu1) ... Setting up libhtml-tree-perl (5.07-3) ... Setting up libparams-classify-perl:arm64 (0.015-2+b4) ... Setting up python3 (3.13.3-1) ... Setting up rubygems-integration (1.19) ... Setting up sopv-gpgv (0.1.4-1) ... update-alternatives: using /usr/bin/sopv-gpgv to provide /usr/bin/sopv (sopv) in auto mode Setting up man-db (2.13.0-1) ... Not building database; man-db/auto-update is not 'true'. Setting up libmodule-runtime-perl (0.018-1) ... Setting up libimport-into-perl (1.002005-2) ... Setting up libmoo-perl (2.005005-1) ... Setting up debhelper (13.24.2) ... Setting up rake (13.2.1-1) ... Setting up liblwp-protocol-https-perl (6.14-1) ... Setting up libwww-perl (6.78-1) ... Setting up libruby3.3:arm64 (3.3.8-1) ... Setting up ruby-rubygems (3.6.7-2) ... Setting up devscripts (2.25.10) ... Setting up ruby3.3-dev:arm64 (3.3.8-1) ... Setting up ruby3.3 (3.3.8-1) ... Setting up libruby:arm64 (1:3.3+b1) ... Setting up ruby-all-dev:arm64 (1:3.3+b1) ... Setting up ruby (1:3.3+b1) ... Setting up racc (1.8.1-1) ... Setting up ruby-rspec-core (3.13.0c0e0m0s1-2) ... Setting up ruby-diff-lcs (1.5.1-1) ... Setting up ruby-whitequark-parser (3.3.4.2-2) ... Setting up gem2deb-test-runner (2.2.5) ... Setting up ruby-rspec-expectations (3.13.0c0e0m0s1-2) ... Setting up ruby-rspec-mocks (3.13.0c0e0m0s1-2) ... Setting up gem2deb (2.2.5) ... Setting up ruby-rspec (3.13.0c0e0m0s1-2) ... Processing triggers for libc-bin (2.41-7) ... Processing triggers for ca-certificates (20250419) ... Updating certificates in /etc/ssl/certs... 0 added, 0 removed; done. Running hooks in /etc/ca-certificates/update.d... done. Reading package lists... Building dependency tree... Reading state information... Reading extended state information... Initializing package states... Writing extended state information... Building tag database... -> Finished parsing the build-deps I: Building the package I: Running cd /build/reproducible-path/ruby-rubocop-ast-1.24.0/ && env PATH="/usr/sbin:/usr/bin:/sbin:/bin:/usr/games" HOME="/nonexistent/first-build" dpkg-buildpackage -us -uc -b && env PATH="/usr/sbin:/usr/bin:/sbin:/bin:/usr/games" HOME="/nonexistent/first-build" dpkg-genchanges -S > ../ruby-rubocop-ast_1.24.0-2_source.changes dpkg-buildpackage: info: source package ruby-rubocop-ast dpkg-buildpackage: info: source version 1.24.0-2 dpkg-buildpackage: info: source distribution unstable dpkg-buildpackage: info: source changed by Lucas Kanashiro dpkg-source --before-build . dpkg-buildpackage: info: host architecture arm64 debian/rules clean dh clean --buildsystem=ruby --with ruby dh_auto_clean -O--buildsystem=ruby dh_ruby --clean W: XS-Ruby-Versions is deprecated, and will be ignored dh_autoreconf_clean -O--buildsystem=ruby dh_clean -O--buildsystem=ruby debian/rules binary dh binary --buildsystem=ruby --with ruby dh_update_autotools_config -O--buildsystem=ruby dh_autoreconf -O--buildsystem=ruby dh_auto_configure -O--buildsystem=ruby dh_ruby --configure debian/rules override_dh_auto_build make[1]: Entering directory '/build/reproducible-path/ruby-rubocop-ast-1.24.0' rake -f tasks/compile.rake generate Generating lib/rubocop/ast/node_pattern/lexer.rex.rb from lib/rubocop/ast/node_pattern/lexer.rex racc -l -v -o lib/rubocop/ast/node_pattern/parser.racc.rb lib/rubocop/ast/node_pattern/parser.y dh_auto_build dh_ruby --build make[1]: Leaving directory '/build/reproducible-path/ruby-rubocop-ast-1.24.0' dh_auto_test -O--buildsystem=ruby dh_ruby --test create-stamp debian/debhelper-build-stamp dh_testroot -O--buildsystem=ruby dh_prep -O--buildsystem=ruby dh_auto_install --destdir=debian/ruby-rubocop-ast/ -O--buildsystem=ruby dh_ruby --install /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast ┌──────────────────────────────────────────────────────────────────────────────┐ │ ruby-rubocop-ast: Installing files and building extensions for ruby3.3 │ └──────────────────────────────────────────────────────────────────────────────┘ /usr/bin/ruby3.3 -S gem build --config-file /dev/null --verbose /tmp/d20260529-2904851-frzkt7/gemspec WARNING: open-ended dependency on parser (>= 3.1.1.0) is not recommended if parser is semantically versioned, use: add_runtime_dependency "parser", "~> 3.1", ">= 3.1.1.0" WARNING: See https://guides.rubygems.org/specification-reference/ for help Successfully built RubyGem Name: rubocop-ast Version: 1.24.0 File: rubocop-ast-1.24.0.gem /usr/bin/ruby3.3 -S gem install --config-file /dev/null --verbose --local --verbose --no-document --ignore-dependencies --install-dir debian/ruby-rubocop-ast/usr/share/rubygems-integration/all /tmp/d20260529-2904851-frzkt7/rubocop-ast-1.24.0.gem /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop-ast.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/builder.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/ext/range.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/ext/range_min_max.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/alias_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/and_asgn_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/and_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/arg_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/args_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/array_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/asgn_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/block_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/break_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/case_match_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/case_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/casgn_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/class_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/const_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/def_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/defined_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/dstr_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/ensure_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/float_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/for_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/forward_args_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/hash_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/if_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/in_pattern_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/index_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/indexasgn_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/int_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/keyword_splat_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/lambda_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/mixin/basic_literal_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/mixin/binary_operator_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/mixin/collection_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/mixin/conditional_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/mixin/descendence.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/mixin/hash_element_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/mixin/method_dispatch_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/mixin/method_identifier_predicates.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/mixin/modifier_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/mixin/numeric_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/mixin/parameterized_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/mixin/predicate_operator_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/module_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/next_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/op_asgn_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/or_asgn_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/or_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/pair_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/procarg0_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/range_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/regexp_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/resbody_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/rescue_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/return_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/self_class_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/send_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/str_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/super_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/symbol_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/until_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/when_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/while_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/yield_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node_pattern.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node_pattern/builder.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node_pattern/comment.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node_pattern/compiler.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node_pattern/compiler/atom_subcompiler.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node_pattern/compiler/binding.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node_pattern/compiler/debug.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node_pattern/compiler/node_pattern_subcompiler.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node_pattern/compiler/sequence_subcompiler.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node_pattern/compiler/subcompiler.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node_pattern/lexer.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node_pattern/lexer.rex.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node_pattern/method_definer.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node_pattern/node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node_pattern/parser.racc.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node_pattern/parser.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node_pattern/sets.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node_pattern/with_meta.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/processed_source.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/rubocop_compatibility.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/sexp.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/token.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/traversal.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/version.rb Successfully installed rubocop-ast-1.24.0 1 gem installed cd debian/ruby-rubocop-ast/usr/share/rubygems-integration/all rm -rf bin rm -rf build_info rm -rf cache rm -rf doc rm -rf extensions rmdir plugins cd gems/rubocop-ast-1.24.0 rm -f chmod 644 lib/rubocop/ast/builder.rb lib/rubocop/ast/ext/range.rb lib/rubocop/ast/ext/range_min_max.rb lib/rubocop/ast/node/alias_node.rb lib/rubocop/ast/node/and_asgn_node.rb lib/rubocop/ast/node/and_node.rb lib/rubocop/ast/node/arg_node.rb lib/rubocop/ast/node/args_node.rb lib/rubocop/ast/node/array_node.rb lib/rubocop/ast/node/asgn_node.rb lib/rubocop/ast/node/block_node.rb lib/rubocop/ast/node/break_node.rb lib/rubocop/ast/node/case_match_node.rb lib/rubocop/ast/node/case_node.rb lib/rubocop/ast/node/casgn_node.rb lib/rubocop/ast/node/class_node.rb lib/rubocop/ast/node/const_node.rb lib/rubocop/ast/node/def_node.rb lib/rubocop/ast/node/defined_node.rb lib/rubocop/ast/node/dstr_node.rb lib/rubocop/ast/node/ensure_node.rb lib/rubocop/ast/node/float_node.rb lib/rubocop/ast/node/for_node.rb lib/rubocop/ast/node/forward_args_node.rb lib/rubocop/ast/node/hash_node.rb lib/rubocop/ast/node/if_node.rb lib/rubocop/ast/node/in_pattern_node.rb lib/rubocop/ast/node/index_node.rb lib/rubocop/ast/node/indexasgn_node.rb lib/rubocop/ast/node/int_node.rb lib/rubocop/ast/node/keyword_splat_node.rb lib/rubocop/ast/node/lambda_node.rb lib/rubocop/ast/node/mixin/basic_literal_node.rb lib/rubocop/ast/node/mixin/binary_operator_node.rb lib/rubocop/ast/node/mixin/collection_node.rb lib/rubocop/ast/node/mixin/conditional_node.rb lib/rubocop/ast/node/mixin/descendence.rb lib/rubocop/ast/node/mixin/hash_element_node.rb lib/rubocop/ast/node/mixin/method_dispatch_node.rb lib/rubocop/ast/node/mixin/method_identifier_predicates.rb lib/rubocop/ast/node/mixin/modifier_node.rb lib/rubocop/ast/node/mixin/numeric_node.rb lib/rubocop/ast/node/mixin/parameterized_node.rb lib/rubocop/ast/node/mixin/predicate_operator_node.rb lib/rubocop/ast/node/module_node.rb lib/rubocop/ast/node/next_node.rb lib/rubocop/ast/node/op_asgn_node.rb lib/rubocop/ast/node/or_asgn_node.rb lib/rubocop/ast/node/or_node.rb lib/rubocop/ast/node/pair_node.rb lib/rubocop/ast/node/procarg0_node.rb lib/rubocop/ast/node/range_node.rb lib/rubocop/ast/node/regexp_node.rb lib/rubocop/ast/node/resbody_node.rb lib/rubocop/ast/node/rescue_node.rb lib/rubocop/ast/node/return_node.rb lib/rubocop/ast/node/self_class_node.rb lib/rubocop/ast/node/send_node.rb lib/rubocop/ast/node/str_node.rb lib/rubocop/ast/node/super_node.rb lib/rubocop/ast/node/symbol_node.rb lib/rubocop/ast/node/until_node.rb lib/rubocop/ast/node/when_node.rb lib/rubocop/ast/node/while_node.rb lib/rubocop/ast/node/yield_node.rb lib/rubocop/ast/node.rb lib/rubocop/ast/node_pattern/builder.rb lib/rubocop/ast/node_pattern/comment.rb lib/rubocop/ast/node_pattern/compiler/atom_subcompiler.rb lib/rubocop/ast/node_pattern/compiler/binding.rb lib/rubocop/ast/node_pattern/compiler/debug.rb lib/rubocop/ast/node_pattern/compiler/node_pattern_subcompiler.rb lib/rubocop/ast/node_pattern/compiler/sequence_subcompiler.rb lib/rubocop/ast/node_pattern/compiler/subcompiler.rb lib/rubocop/ast/node_pattern/compiler.rb lib/rubocop/ast/node_pattern/lexer.rb lib/rubocop/ast/node_pattern/lexer.rex.rb lib/rubocop/ast/node_pattern/method_definer.rb lib/rubocop/ast/node_pattern/node.rb lib/rubocop/ast/node_pattern/parser.racc.rb lib/rubocop/ast/node_pattern/parser.rb lib/rubocop/ast/node_pattern/sets.rb lib/rubocop/ast/node_pattern/with_meta.rb lib/rubocop/ast/node_pattern.rb lib/rubocop/ast/processed_source.rb lib/rubocop/ast/rubocop_compatibility.rb lib/rubocop/ast/sexp.rb lib/rubocop/ast/token.rb lib/rubocop/ast/traversal.rb lib/rubocop/ast/version.rb lib/rubocop/ast.rb lib/rubocop-ast.rb find lib/ -type d -empty -delete cd - cd - dh_installchangelogs -pruby-rubocop-ast /build/reproducible-path/ruby-rubocop-ast-1.24.0/CHANGELOG.md upstream /usr/bin/ruby3.3 /usr/bin/gem2deb-test-runner ┌──────────────────────────────────────────────────────────────────────────────┐ │ Checking Rubygems dependency resolution on ruby3.3 │ └──────────────────────────────────────────────────────────────────────────────┘ RUBYLIB=. GEM_PATH=/build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all:/build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/.debhelper/generated/_source/home/.local/share/gem/ruby/3.3.0:/var/lib/gems/3.3.0:/usr/local/lib/ruby/gems/3.3.0:/usr/lib/ruby/gems/3.3.0:/usr/lib/aarch64-linux-gnu/ruby/gems/3.3.0:/usr/share/rubygems-integration/3.3.0:/usr/share/rubygems-integration/all:/usr/lib/aarch64-linux-gnu/rubygems-integration/3.3.0 ruby3.3 -e gem\ \"rubocop-ast\" ┌──────────────────────────────────────────────────────────────────────────────┐ │ Run tests for ruby3.3 from debian/ruby-tests.rake │ └──────────────────────────────────────────────────────────────────────────────┘ RUBYLIB=. GEM_PATH=/build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all:/build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/.debhelper/generated/_source/home/.local/share/gem/ruby/3.3.0:/var/lib/gems/3.3.0:/usr/local/lib/ruby/gems/3.3.0:/usr/lib/ruby/gems/3.3.0:/usr/lib/aarch64-linux-gnu/ruby/gems/3.3.0:/usr/share/rubygems-integration/3.3.0:/usr/share/rubygems-integration/all:/usr/lib/aarch64-linux-gnu/rubygems-integration/3.3.0 ruby3.3 -S rake --rakelibdir /gem2deb-nonexistent -f debian/ruby-tests.rake /usr/bin/ruby3.3 -ruri -I/usr/share/rubygems-integration/all/gems/rspec-support-3.13.1/lib:/usr/share/rubygems-integration/all/gems/rspec-core-3.13.0/lib /usr/share/rubygems-integration/all/gems/rspec-core-3.13.0/exe/rspec --pattern ./spec/\*\*/\*_spec.rb --format documentation warning: parser/current is loading parser/ruby33, which recognizes 3.3.4-compliant syntax, but you are running 3.3.8. Please see https://github.com/whitequark/parser#compatibility-with-ruby-mri. Randomized with seed 46231 RuboCop::AST::IfNode #branches with an elsif statement is expected to all be literal is expected to eq 3 with an if statement is expected to eq 1 is expected to all be literal with an unless statement is expected to all be literal is expected to eq 1 with a ternary operator is expected to all be literal is expected to eq 2 with an else statement is expected to all be literal is expected to eq 2 #each_branch when passed a block yields all the branches when not passed a block is expected to be a kind of Enumerator #if? with a ternary operator is expected not to be if with an unless statement is expected not to be if with an if statement is expected to be if #unless? with a ternary operator is expected not to be unless with an unless statement is expected to be unless with an if statement is expected not to be unless #if_branch with an if statement is expected to be sym type with a ternary operator is expected to be sym type with an unless statement is expected to be sym type #inverse_keyword? with an if statement is expected to eq "unless" with an unless statement is expected to eq "if" with a ternary operator is expected to eq "" #ternary? with a ternary operator is expected to be ternary with an unless statement is expected not to be ternary with an if statement is expected not to be ternary #nested_conditional? with nested conditionals in elsif clause is expected to be nested conditional with no nested conditionals is expected not to be nested conditional with nested conditionals in if clause is expected to be nested conditional with nested conditionals in else clause is expected to be nested conditional with nested ternary operators when nested in the falsey branch is expected to be nested conditional when nested in the truthy branch is expected to be nested conditional #elsif_conditional? with nested conditionals in else clause is expected not to be elsif conditional with multiple elsif conditionals is expected to be elsif conditional with nested ternary operators when nested in the truthy branch is expected not to be elsif conditional when nested in the falsey branch is expected not to be elsif conditional with nested conditionals in if clause is expected not to be elsif conditional with one elsif conditional is expected to be elsif conditional #else? without an else statement is expected not to be elsif with an elsif statement is expected to be else #modifier_form? with a modifier if statement is expected to be modifier form with a non-modifier if statement is expected not to be modifier form with a modifier unless statement is expected to be modifier form with a non-modifier unless statement is expected not to be modifier form with a ternary operator is expected not to be modifier form #keyword with an unless statement is expected to eq "unless" with a ternary operator is expected to eq "" with an if statement is expected to eq "if" #else_branch with an unless statement is expected to be int type with an if statement is expected to be int type with a ternary operator is expected to be int type .new with a modifier statement is expected to be a kind of RuboCop::AST::IfNode with a regular if statement is expected to be a kind of RuboCop::AST::IfNode with a ternary operator is expected to be a kind of RuboCop::AST::IfNode #elsif? without an elsif statement is expected not to be elsif with an if statement comtaining an elsif is expected not to be elsif with an elsif statement is expected to be elsif RuboCop::AST::AndAsgnNode #operator is expected to eq :"&&" .new is expected to be a kind of RuboCop::AST::AndAsgnNode #name is expected to eq :var #expression is expected to eq s(:send, nil, :value) #assignment_node is expected to be a kind of RuboCop::AST::AsgnNode RuboCop::AST::HashNode #empty? with an empty hash is expected to be empty with a hash containing pairs is expected not to be empty with a hash containing a keyword splat is expected not to be empty #each_value when passed a block yields all the pairs when not passed a block is expected to be a kind of Enumerator #mixed_delimiters? when all pairs are using a hash rocket delimiter is expected not to be mixed delimiters when pairs are using different delimiters is expected to be mixed delimiters when all pairs are using a colon delimiter is expected not to be mixed delimiters #values with a hash with literal values is expected to eq 3 is expected to all be literal with a hash with string keys is expected to eq 2 is expected to all be send type with an empty hash is expected to be empty #pairs_on_same_line? with all pairs on the same line is expected to be pairs on same line with no pairs on the same line is expected not to be pairs on same line with some pairs on the same line is expected to be pairs on same line #keys with a hash with string keys is expected to all be str type is expected to eq 2 with an empty hash is expected to be empty with a hash with symbol keys is expected to eq 3 is expected to all be sym type #each_key when passed a block yields all the pairs when not passed a block is expected to be a kind of Enumerator #braces? as an argument with braces is expected to be braces as an argument with no braces is expected not to be braces with braces is expected to be braces .new is expected to be a kind of RuboCop::AST::HashNode #pairs with an empty hash is expected to be empty with a hash of variables is expected to eq 2 is expected to all be pair type with a hash of literals is expected to eq 3 is expected to all be pair type #each_pair when passed a block yields all the pairs when not passed a block is expected to be a kind of Enumerator RuboCop::AST::AndNode #inverse_operator with a semantic and node is expected to eq "or" with a logical and node is expected to eq "||" .new with a logical and node is expected to be a kind of RuboCop::AST::AndNode with a semantic and node is expected to be a kind of RuboCop::AST::AndNode #lhs with a semantic and node is expected to be sym type with a logical and node is expected to be sym type #operator with a logical and node is expected to eq "&&" with a semantic and node is expected to eq "and" #alternate_operator with a logical and node is expected to eq "and" with a semantic and node is expected to eq "&&" #rhs with a logical and node is expected to be int type with a semantic and node is expected to be int type #semantic_operator? with a semantic and node is expected to be semantic operator with a logical and node is expected not to be semantic operator #logical_operator? with a semantic and node is expected not to be logical operator with a logical and node is expected to be logical operator RuboCop::AST::EnsureNode .new is expected to be a kind of RuboCop::AST::EnsureNode #body is expected to be sym type RuboCop::AST::YieldNode #method_name is expected to eq :yield #block_argument? is expected not to be block argument #command? when argument is a symbol is expected to be command :yield when argument is a string is expected to be command "yield" #block_literal? is expected not to be block literal #splat_argument? with a splat argument is expected to be splat argument with mixed arguments is expected to be splat argument with regular arguments is expected not to be splat argument with no arguments is expected not to be splat argument #bang_method? is expected not to be bang method #first_argument with a single splat argument is expected to be splat type with a single literal argument is expected to be sym type with multiple mixed arguments is expected to be sym type with multiple literal arguments is expected to be sym type with no arguments is expected to be nil #camel_case_method? is expected not to be camel case method #dot? is expected not to be dot #receiver is expected to be nil #last_argument with multiple literal arguments is expected to be sym type with a single splat argument is expected to be splat type with a single literal argument is expected to be sym type with no arguments is expected to be nil with multiple mixed arguments is expected to be splat type #self_receiver? is expected not to be self receiver #double_colon? is expected not to be double colon #operator_method? is expected not to be operator method #setter_method? is expected not to be setter method #const_receiver? is expected not to be const receiver #assignment_method? is expected not to be assignment method #arguments with no arguments is expected to be empty with multiple mixed arguments is expected to eq 2 with a single literal argument is expected to eq 1 with a single splat argument is expected to eq 1 with multiple literal arguments is expected to eq 2 #method? when message matches when argument is a string is expected to be method "yield" when argument is a symbol is expected to be method :yield when message does not match when argument is a symbol is expected not to be method :foo when argument is a string is expected not to be method "foo" #arguments? with no arguments is expected not to be arguments with multiple literal arguments is expected to be arguments with a single literal argument is expected to be arguments with multiple mixed arguments is expected to be arguments with a single splat argument is expected to be arguments #macro? is expected not to be macro #block_node is expected to be nil #parenthesized? with arguments when using parentheses is expected to be parenthesized when not using parentheses is expected not to be parenthesized with no arguments when not using parentheses is expected not to be parenthesized when using parentheses is expected to be parenthesized #comparison_method? is expected not to be comparison method #predicate_method? is expected not to be predicate method .new is expected to be a kind of RuboCop::AST::YieldNode #implicit_call? is expected not to be implicit call RuboCop::AST::ArrayNode .new is expected to be a kind of RuboCop::AST::ArrayNode #values with an array of variables is expected to all be send type is expected to eq 2 with an array of literals is expected to eq 3 is expected to all be literal with an empty array is expected to be empty #percent_literal? with square brackets is expected not to be percent literal :symbol is expected not to be percent literal :string is expected not to be percent literal with a string percent literal is expected to be percent literal :string is expected to be percent literal is expected not to be percent literal :symbol with a symbol percent literal is expected not to be percent literal :string is expected to be percent literal :symbol is expected to be percent literal #bracketed? unbracketed is expected to be nil with square brackets is expected to be bracketed with a percent literal is expected to be bracketed #square_brackets? with a percent literal is expected not to be square brackets with square brackets is expected to be square brackets #each_value without block is expected to be a kind of Enumerator with block is expected to eq ["(int 1)", "(int 2)", "(int 3)"] is expected to be a kind of RuboCop::AST::ArrayNode RuboCop::AST::ReturnNode behaves like wrapped arguments node .new with arguments is expected to be a kind of RuboCop::AST::ReturnNode without arguments is expected to be a kind of RuboCop::AST::ReturnNode #arguments with a single splat argument is expected to eq 1 with a single argument is expected to eq 1 with no arguments is expected to be empty with no arguments and braces is expected to be empty with multiple literal arguments is expected to eq 2 with a single argument and braces is expected to eq 1 RuboCop::AST::RescueNode #branches when there is no else keyword returns only then rescue bodies when there is an else returns all the bodies with an empty else returns all the bodies #else_branch with an else statement is expected to be send type without an else statement is expected to be nil #else? without an else statement is expected not to be else with an else statement is expected to be else #resbody_branches is expected to eq 2 is expected to all be resbody type .new is expected to be a kind of RuboCop::AST::RescueNode #body is expected to be send type RuboCop::AST::RangeNode .new with a beignless range is expected to be range type is expected to be a kind of RuboCop::AST::RangeNode with an exclusive range is expected to be range type is expected to be a kind of RuboCop::AST::RangeNode with an infinite range is expected to be range type is expected to be a kind of RuboCop::AST::RangeNode with an inclusive range is expected to be a kind of RuboCop::AST::RangeNode is expected to be range type RuboCop::AST::SuperNode #implicit_call? is expected not to be implicit call #block_literal? with a block argument is expected not to be block literal with a block literal is expected to be block literal with no block is expected not to be block literal #receiver is expected to be nil #setter_method? is expected not to be setter method #predicate_method? is expected not to be predicate method #assignment_method? is expected not to be assignment method #comparison_method? is expected not to be comparison method #command? when argument is a symbol is expected to be command :super when argument is a string is expected to be command "super" #self_receiver? is expected not to be self receiver #camel_case_method? is expected not to be camel case method #bang_method? is expected not to be bang method #first_argument with a single splat argument is expected to be splat type with multiple mixed arguments is expected to be sym type with a single literal argument is expected to be sym type with multiple literal arguments is expected to be sym type with no arguments is expected to be nil #macro? is expected not to be macro #method? when message does not match when argument is a symbol is expected not to be method :foo when argument is a string is expected not to be method "foo" when message matches when argument is a string is expected to be method "super" when argument is a symbol is expected to be method :super #arguments? with a single splat argument is expected to be arguments with no arguments is expected not to be arguments with multiple mixed arguments is expected to be arguments with multiple literal arguments is expected to be arguments with a single literal argument is expected to be arguments #parenthesized? with arguments when not using parentheses is expected not to be parenthesized when using parentheses is expected to be parenthesized with no arguments when using parentheses is expected to be parenthesized when not using parentheses is expected not to be parenthesized #method_name is expected to eq :super #dot? is expected not to be dot #double_colon? is expected not to be double colon #last_argument with multiple literal arguments is expected to be sym type with no arguments is expected to be nil with a single literal argument is expected to be sym type with a single splat argument is expected to be splat type with multiple mixed arguments is expected to be splat type #splat_argument? with a splat argument is expected to be splat argument with no arguments is expected not to be splat argument with mixed arguments is expected to be splat argument with regular arguments is expected not to be splat argument #operator_method? is expected not to be operator method #const_receiver? is expected not to be const receiver #block_node with a block argument is expected to be nil with a block literal is expected to be block type with no block is expected to be nil #block_argument? with regular arguments is expected not to be block argument with mixed arguments is expected to be block argument with no arguments is expected not to be block argument with a block argument is expected to be block argument #arguments with multiple literal arguments is expected to eq 2 with no arguments is expected to be empty with a single literal argument is expected to eq 1 with multiple mixed arguments is expected to eq 2 with a single splat argument is expected to eq 1 .new with a zsuper node is expected to be a kind of RuboCop::AST::SuperNode with a super node is expected to be a kind of RuboCop::AST::SuperNode Changelog merges correctly parses correctly Changelog::Entry generates correct content RuboCop::AST::Ext::Range #line_span returns the range of lines a range occupies accepts an `exclude_end` keyword argument RuboCop::AST::RegexpNode #options with a regexp with multiple options is expected to eq 3 with a regexp with "o" option is expected to eq 0 with an empty regexp is expected to eq 0 with a regexp without option is expected to eq 0 with a regexp with single option is expected to eq 1 #single_interpolation? with o and other options is expected to be single interpolation with other options is expected not to be single interpolation with no options is expected not to be single interpolation with only o option is expected to be single interpolation #to_regexp with a regexp with option is expected to eq /.+/mix with a multi-line regexp with option is expected to eq / .+ /ix with a regexp without option is expected to eq /.+/ with an empty regexp with option is expected to eq //ix with a regexp with an "u" option is expected to eq "/abc/" with a regexp with an "n" option is expected to eq "/abc/n" with an empty regexp is expected to eq // with a regexp with an "o" option is expected to eq "/abc/i" with a multi-line regexp without option is expected to eq / .+ / #delimiters with %r{-delimiters is expected to eq ["{", "}"] with %r/-delimiters is expected to eq ["/", "/"] with %r<-delimiters is expected to eq ["<", ">"] with multi-line %r{-delimiters is expected to eq ["{", "}"] with /-delimiters is expected to eq ["/", "/"] #no_encoding? with no options is expected not to be no encoding with n and other options is expected to be no encoding with only n option is expected to be no encoding with other options is expected not to be no encoding #content with a multi-line regexp with option is expected to eq "\n.+\n" with a regexp with option is expected to eq ".+" with a multi-line regexp without option is expected to eq "\n.+\n" with a regexp without option is expected to eq ".+" with an empty regexp is expected to eq "" with an empty regexp with option is expected to eq "" #percent_r_literal? with %r<-delimiters is expected to be percent r literal with /-delimiters is expected not to be percent r literal with multi-line %r{-delimiters is expected to be percent r literal with %r{-delimiters is expected to be percent r literal with %r/-delimiters is expected to be percent r literal #regopt with a regexp with option is expected to eq [:i, :m, :x] is expected to be regopt type with a multi-line regexp without option is expected to be empty is expected to be regopt type with a multi-line regexp with option is expected to be regopt type is expected to eq [:i, :m, :x] with a regexp without option is expected to be regopt type is expected to be empty with an empty regexp with option is expected to be regopt type is expected to eq [:i, :x] with an empty regexp is expected to be regopt type is expected to be empty #fixed_encoding? with other options is expected not to be fixed encoding with u and other options is expected to be fixed encoding with only u option is expected to be fixed encoding with no options is expected not to be fixed encoding #multiline_mode? with m and other options is expected to be multiline mode with only m option is expected to be multiline mode with other options is expected not to be multiline mode with no options is expected not to be multiline mode #interpolation? with regexp quote is expected to be interpolation with no interpolation returns false is expected not to be interpolation with direct variable interpoation is expected to be interpolation #delimiter? with multi-line %r{-delimiters is expected not to be delimiter "/" is expected not to be delimiter "%" is expected not to be delimiter "%r/" is expected not to be delimiter "%r" is expected not to be delimiter "r" is expected not to be delimiter "%r{" is expected to be delimiter "}" is expected to be delimiter "{" with /-delimiters is expected not to be delimiter "{" is expected to be delimiter "/" with %r/-delimiters is expected not to be delimiter "%" is expected not to be delimiter "%r" is expected not to be delimiter "{" is expected not to be delimiter "r" is expected not to be delimiter "}" is expected to be delimiter "/" is expected not to be delimiter "%r/" with %r{-delimiters is expected not to be delimiter "%r" is expected not to be delimiter "/" is expected not to be delimiter "%" is expected to be delimiter "}" is expected to be delimiter "{" is expected not to be delimiter "%r{" is expected not to be delimiter "%r/" is expected not to be delimiter "r" with %r<-delimiters is expected not to be delimiter "%r{" is expected to be delimiter "<" is expected to be delimiter ">" is expected not to be delimiter "{" is expected not to be delimiter "r" is expected not to be delimiter "%" is expected not to be delimiter "}" is expected not to be delimiter "%r" is expected not to be delimiter "/" is expected not to be delimiter "%r/" is expected not to be delimiter "%r<" .new is expected to be a kind of RuboCop::AST::RegexpNode #ignore_case? with only i option is expected to be ignore case with i and other options is expected to be ignore case with no options is expected not to be ignore case with other options is expected not to be ignore case #slash_literal? with /-delimiters is expected to be slash literal with %r<-delimiters is expected not to be slash literal with multi-line %r{-delimiters is expected not to be slash literal with %r/-delimiters is expected not to be slash literal with %r{-delimiters is expected not to be slash literal #extended? with x and other options is expected to be extended with no options is expected not to be extended with only x option is expected to be extended with other options is expected not to be extended RuboCop::AST::Traversal knows all current node types for example !/wat/ traverses all nodes for example def String=; end traverses all nodes for example if foo; bar; elsif baz; 1; else 2; end traverses all nodes for example module Bar::Foo; end traverses all nodes for example [*foo] traverses all nodes for example a b{c d}, 1.0r do end traverses all nodes for example m "#{[]}" traverses all nodes for example var = 10; var traverses all nodes for example meth rescue bar traverses all nodes for example proc {_1 = nil} traverses all nodes for example foo.a += m foo traverses all nodes for example [1, *foo] traverses all nodes for example case [__FILE__, __LINE__ + 1, __ENCODING__] in [__FILE__, __LINE__, __ENCODING__] end traverses all nodes for example %q{#@@1} traverses all nodes for example while class << self; tap do end; end; break; end traverses all nodes for example -> { _1 + _9} traverses all nodes for example f{ |*s| } traverses all nodes for example %{a\ b} traverses all nodes for example p <<~E E traverses all nodes for example a b(c(d)), :e do end traverses all nodes for example case foo; in x, y, then nil; end traverses all nodes for example foo === 1 traverses all nodes for example foo ** 1 traverses all nodes for example a b{c(d)}, /x/m do end traverses all nodes for example defined? foo traverses all nodes for example a, *b, c = bar traverses all nodes for example foo = meth rescue bar traverses all nodes for example bar unless foo traverses all nodes for example a b(c(d)), 1.0r do end traverses all nodes for example def foo; end traverses all nodes for example %s{a\ b} traverses all nodes for example def f ((a, *)); end traverses all nodes for example def f *, **; end traverses all nodes for example %W[#@1] traverses all nodes for example :"#@1" traverses all nodes for example fun do end traverses all nodes for example foo.(1) traverses all nodes for example f{ |a, c| } traverses all nodes for example case foo; in (1) then true; end traverses all nodes for example %{#@@1} traverses all nodes for example foo[m bar] traverses all nodes for example super traverses all nodes for example def self.foo; end traverses all nodes for example @var = 10 traverses all nodes for example case foo; in {a: } true ; end traverses all nodes for example foo::fun bar traverses all nodes for example foo < 1 traverses all nodes for example while foo do meth end traverses all nodes for example f{ |*s, &b| } traverses all nodes for example fun(*bar, &baz) traverses all nodes for example case foo; in "#{ 'a' }": 1 then true; end traverses all nodes for example case foo; in [x, y, *] then true; end traverses all nodes for example def f o=1, p, &b; end traverses all nodes for example a b{c d}, 1 do end traverses all nodes for example f{ |a, &b| } traverses all nodes for example $foo traverses all nodes for example def x(_4) end traverses all nodes for example case foo; in A::B then true; end traverses all nodes for example foo.C += raise(bar) rescue nil traverses all nodes for example foo = raise bar rescue nil traverses all nodes for example <<-`HERE` #@@1 HERE traverses all nodes for example case foo; in "#{ %Q{a} }": then true; end traverses all nodes for example unless foo then bar; else baz; end traverses all nodes for example foo::a = 1 traverses all nodes for example yield traverses all nodes for example a += 1 traverses all nodes for example p <<~E x y E traverses all nodes for example foo && bar traverses all nodes for example foo (-1.3).abs traverses all nodes for example begin meth end while foo traverses all nodes for example :foo traverses all nodes for example :'#@@1' traverses all nodes for example case foo; when 'bar'; bar; else baz; end traverses all nodes for example meth while foo traverses all nodes for example (foo, bar) = 1, 2 traverses all nodes for example "#@1" traverses all nodes for example p <<~E x \ y E traverses all nodes for example def foo raise; raise A::B, ''; end traverses all nodes for example m def x(); end; 1.tap do end traverses all nodes for example p begin 1.times do 1 end end traverses all nodes for example %i[foo bar] traverses all nodes for example break(foo) traverses all nodes for example p <<~"E" x #{foo} E traverses all nodes for example foo[0, 1] &&= 2 traverses all nodes for example case foo; in [x, y, *z] then true; end traverses all nodes for example def foo a:b end traverses all nodes for example :"#@@1" traverses all nodes for example def String.foo; end traverses all nodes for example p -> { :hello }, a: 1 do end traverses all nodes for example def f ((*r, p)); end traverses all nodes for example p ->() do a() do end end traverses all nodes for example foo = bar = m foo traverses all nodes for example <<`HERE` foo bar HERE traverses all nodes for example f{ |a, *s| } traverses all nodes for example foo && (a, b = bar) traverses all nodes for example case foo; in 1, "a", [], {} then nil; end traverses all nodes for example foo "#{(1+1).to_i}" do; end traverses all nodes for example { 'foo': 2 } traverses all nodes for example case foo; in {a: 2} false ; end traverses all nodes for example %s{#@@1} traverses all nodes for example /\xa8/n =~ "" traverses all nodes for example p <<~E x y E traverses all nodes for example # coding:utf-8 "\xD0\xBF\xD1\x80\xD0\xBE\xD0\xB2\xD0\xB5\xD1\x80\xD0\xBA\xD0\xB0" traverses all nodes for example foo * 1 traverses all nodes for example a b{c d}, /x/m do end traverses all nodes for example yield foo traverses all nodes for example p <<~`E` x #{foo} E traverses all nodes for example a b(c(d)), 1.0 do end traverses all nodes for example if (bar; a, b = foo); end traverses all nodes for example foo.fun bar traverses all nodes for example meth until foo traverses all nodes for example foo[1, 2] = 3 traverses all nodes for example def f ((*, p)); end traverses all nodes for example case foo; when 'bar' then bar; end traverses all nodes for example foo / 1 traverses all nodes for example p <<~"E" x #{" y"} E traverses all nodes for example def f ((a, *r)); end traverses all nodes for example "#{-> foo {}}" traverses all nodes for example fun(*bar) traverses all nodes for example false ? raise do end : tap do end traverses all nodes for example f{ |o=1, &b| } traverses all nodes for example def m; class << self; class C; end; end; end traverses all nodes for example -> * { } traverses all nodes for example f{ |;a| } traverses all nodes for example unless foo; bar; else baz; end traverses all nodes for example break() traverses all nodes for example foo += m foo traverses all nodes for example def foo(...); bar(...); end traverses all nodes for example `#@@1` traverses all nodes for example foo, bar, baz = 1, 2 traverses all nodes for example `a\ b` traverses all nodes for example -> do _1 + _9 end traverses all nodes for example foo::a += 1 traverses all nodes for example fun (f bar) traverses all nodes for example f(a ? "a":1) traverses all nodes for example def self.m; _1; end traverses all nodes for example fun(f bar) traverses all nodes for example while def self.foo; tap do end; end; break; end traverses all nodes for example def m; class << self; A = nil; end; end traverses all nodes for example @a |= 1 traverses all nodes for example 1.33 traverses all nodes for example f{ |&b| } traverses all nodes for example retry traverses all nodes for example a b{c(d)}, 1.0i do end traverses all nodes for example <<-'HERE' a\ b HERE traverses all nodes for example break foo traverses all nodes for example f{ |*| } traverses all nodes for example module A; _1; end traverses all nodes for example f{ |a| } traverses all nodes for example <<-`HERE` a\ b HERE traverses all nodes for example foo, bar = 1, 2 traverses all nodes for example def f **baz, &b; end traverses all nodes for example foo & 1 traverses all nodes for example return foo traverses all nodes for example class << foo; _1; end traverses all nodes for example def foo(_a, _a); end traverses all nodes for example return fun foo do end traverses all nodes for example foo.a = 1 traverses all nodes for example f{ |*r, p, &b| } traverses all nodes for example f{ |a, *, &b| } traverses all nodes for example case foo; in "#{ 'a' }": then true; end traverses all nodes for example case foo; in a:, b: then true; end traverses all nodes for example def f ((*r)); end traverses all nodes for example fun (1).to_i traverses all nodes for example def f(**); end traverses all nodes for example td (1_500).toString(); td.num do; end traverses all nodes for example super() traverses all nodes for example def f ; end traverses all nodes for example a b(c d), 1 do end traverses all nodes for example ..100 traverses all nodes for example fun(1) traverses all nodes for example foo <= 1 traverses all nodes for example foo[0, 1] += m foo traverses all nodes for example case foo; in "a": 1 then true; end traverses all nodes for example class Foo < Bar; end traverses all nodes for example case foo; in x unless true; nil; end traverses all nodes for example foo.A += m foo traverses all nodes for example def f(**nil); end traverses all nodes for example :'foo' traverses all nodes for example begin; meth; rescue; foo; else; bar; end traverses all nodes for example case foo; in ::A then true; end traverses all nodes for example %I() traverses all nodes for example while def self.foo a = tap do end; end; break; end traverses all nodes for example *, c, d = bar traverses all nodes for example %x{#@1} traverses all nodes for example [1, *foo, 2] traverses all nodes for example def f ((a, *, p)); end traverses all nodes for example [ 1, 2 => 3 ] traverses all nodes for example defined?(foo) traverses all nodes for example a += b += raise :x traverses all nodes for example %W"#{1}" traverses all nodes for example a b(c(d)), 1 do end traverses all nodes for example proc {_1 = nil} traverses all nodes for example f{ |a, o=1, &b| } traverses all nodes for example case foo; in self then true; end traverses all nodes for example true traverses all nodes for example foo[1, 2] traverses all nodes for example case foo; in {} then true; end traverses all nodes for example if foo; bar; end traverses all nodes for example begin ensure end traverses all nodes for example def foo(...); end traverses all nodes for example END { 1 } traverses all nodes for example f{ |foo: 1, &b| } traverses all nodes for example { 1 => 2 } traverses all nodes for example foo.a ||= 1 traverses all nodes for example case foo; in a: 1, b: 2 then true; end traverses all nodes for example Foo = 10 traverses all nodes for example 42i traverses all nodes for example if foo then bar; end traverses all nodes for example case foo; in A(1, 2) then true; end traverses all nodes for example < proc do end, b: proc do end} traverses all nodes for example desc "foo" do end traverses all nodes for example f{ |a, *s, &b| } traverses all nodes for example p <<~E E traverses all nodes for example case foo; in [x, *, y] then true; end traverses all nodes for example f{ |a, o=1, *r, p, &b| } traverses all nodes for example def a; @@var |= 10; end traverses all nodes for example until foo; meth end traverses all nodes for example a b(c d), /x/m do end traverses all nodes for example foo[:baz => 1,] traverses all nodes for example m { |**nil| } traverses all nodes for example %i[] traverses all nodes for example def f o=1, *r, p, &b; end traverses all nodes for example super foo traverses all nodes for example true ? 1.tap do |n| p n end : 0 traverses all nodes for example foo, bar = meth rescue [1, 2] traverses all nodes for example def f o=1, *r, &b; end traverses all nodes for example def f a, &b; end traverses all nodes for example a b(c(d)), /x/ do end traverses all nodes for example begin; meth; rescue Exception; bar; end traverses all nodes for example nil traverses all nodes for example fun (1) traverses all nodes for example foo += meth rescue bar traverses all nodes for example m do _1 + _9 end traverses all nodes for example f (g rescue nil) traverses all nodes for example foo&.bar {} traverses all nodes for example f{ |foo: 1, bar: 2, **baz, &b| } traverses all nodes for example a = b += raise :x traverses all nodes for example case foo; in 1 => a then true; end traverses all nodes for example 1.. traverses all nodes for example def f(foo); end traverses all nodes for example f{ |o=1, *r, p, &b| } traverses all nodes for example fun traverses all nodes for example `#@1` traverses all nodes for example case foo; in A[x:] then true; end traverses all nodes for example m ->(a: ->{_1}) {a} traverses all nodes for example def f foo = 1; end traverses all nodes for example a&.b traverses all nodes for example [/()\1/, ?#] traverses all nodes for example a b{c d}, 1.0i do end traverses all nodes for example 42ri traverses all nodes for example %i[ #@1 ] traverses all nodes for example until foo do meth end traverses all nodes for example foo::Fun bar traverses all nodes for example yield(foo) traverses all nodes for example ->(a; foo, bar) { } traverses all nodes for example if foo..bar; end traverses all nodes for example class Foo end traverses all nodes for example a # # &.foo traverses all nodes for example !foo traverses all nodes for example :'a\ b' traverses all nodes for example `foobar` traverses all nodes for example foo traverses all nodes for example m ->(a = ->{_1}) {a} traverses all nodes for example super(foo) traverses all nodes for example def self::foo; end traverses all nodes for example case foo; in x, y then nil; end traverses all nodes for example fun(1) { } traverses all nodes for example return traverses all nodes for example begin foo!; bar! end traverses all nodes for example while def foo; tap do end; end; break; end traverses all nodes for example %{#@1} traverses all nodes for example $10 traverses all nodes for example /#{1}(?bar)/ =~ 'bar' traverses all nodes for example foo != 1 traverses all nodes for example -2.0 ** 10 traverses all nodes for example %i{a\ b} traverses all nodes for example foo::fun traverses all nodes for example __LINE__ traverses all nodes for example p <<~E " y" x E traverses all nodes for example alias $a $+ traverses all nodes for example def foo(...); bar(...); end traverses all nodes for example %r{#@1} traverses all nodes for example case foo; in 1 | 2 then true; end traverses all nodes for example if foo then bar end traverses all nodes for example let (:a) { m do; end } traverses all nodes for example foo += raise bar rescue nil traverses all nodes for example case foo; in { a: 1, } then true; end traverses all nodes for example f{ |**baz, &b| } traverses all nodes for example %I[#@@1] traverses all nodes for example 'foobar' traverses all nodes for example '#@1' traverses all nodes for example BEGIN { 1 } traverses all nodes for example fun (1 ) traverses all nodes for example case foo; in **nil then true; end traverses all nodes for example bar def foo; self.each do end end traverses all nodes for example a # # .foo traverses all nodes for example foo += raise(bar) rescue nil traverses all nodes for example fun! traverses all nodes for example def _5; end traverses all nodes for example %x{a\ b} traverses all nodes for example a b(c d), /x/ do end traverses all nodes for example foo::a += m foo traverses all nodes for example p <<~E x y E traverses all nodes for example case foo; in ..2 then true; end traverses all nodes for example next foo traverses all nodes for example %w[foo bar] traverses all nodes for example !(foo..bar) traverses all nodes for example %r{#@@1} traverses all nodes for example a b{c d}, :e do end traverses all nodes for example p <<~E x \ y E traverses all nodes for example foo::C ||= raise(bar) rescue nil traverses all nodes when a class defines `on_block_pass` calls it for all block-pass arguments for example p <<~"E" x\n y E traverses all nodes for example a b{c(d)}, 1.0 do end traverses all nodes for example "#@@1" traverses all nodes for example { foo: 2, **bar } traverses all nodes for example while class Foo a = tap do end; end; break; end traverses all nodes for example def self._6; end traverses all nodes for example a b(c d), 1.0i do end traverses all nodes for example next fun foo do end traverses all nodes for example _2 = 1 traverses all nodes for example 1...2 traverses all nodes for example fun (1) {} traverses all nodes for example while not (true) do end traverses all nodes for example %Q{#@1} traverses all nodes for example a b(c d), 1.0r do end traverses all nodes for example m a + b do end traverses all nodes for example { 'foo': 2, 'bar': {}} traverses all nodes for example case foo; in [*x, y] then true; end traverses all nodes for example not(foo) traverses all nodes for example f{ |a, *| } traverses all nodes for example ::A += 1 traverses all nodes for example { foo: 2 } traverses all nodes for example module Foo; end traverses all nodes for example fun() { } traverses all nodes for example def f(&block); end traverses all nodes for example ->{ } traverses all nodes for example fun(foo, :foo => 1) traverses all nodes for example def foo(...); super(...); end traverses all nodes for example %q(foobar) traverses all nodes for example def String; end traverses all nodes for example <<-'HERE' #@1 HERE traverses all nodes for example foo and bar traverses all nodes for example /foo#{bar}baz/ traverses all nodes for example false traverses all nodes for example o = { a: 1 } traverses all nodes for example def f(*foo); end traverses all nodes for example %i[ #@@1 ] traverses all nodes for example foo.C += raise bar rescue nil traverses all nodes for example %Q{a\ b} traverses all nodes for example { 1 => 2, :foo => "bar" } traverses all nodes for example foo[0] += raise(bar) rescue nil traverses all nodes for example foo % 1 traverses all nodes for example class Foo; end traverses all nodes for example foo.m += raise(bar) rescue nil traverses all nodes for example begin; meth; rescue; baz; ensure; bar; end traverses all nodes for example 1... traverses all nodes for example case foo; in ...2 then true; end traverses all nodes for example foo == 1 traverses all nodes for example meth 1 do end::fun bar traverses all nodes for example case foo; in A() then true; end traverses all nodes for example B::A += 1 traverses all nodes for example * = bar traverses all nodes for example %x{#@@1} traverses all nodes for example case foo; in ^foo then nil; end traverses all nodes for example foo[bar,] traverses all nodes for example lambda{|;a|a} traverses all nodes for example m { |foo| } traverses all nodes for example <<-"HERE" a\ b HERE traverses all nodes for example case foo; in a: 1 then true; end traverses all nodes for example for a in foo do p a; end traverses all nodes for example __FILE__ traverses all nodes for example if (a, b = foo); end traverses all nodes for example def f foo: ; end traverses all nodes for example <<-`HERE` #@1 HERE traverses all nodes for example case foo; in "#{ %Q{a} }": 1 then true; end traverses all nodes for example foo >= 1 traverses all nodes for example %W[foo #{bar}] traverses all nodes for example super foo, bar do end traverses all nodes for example /a\ b/ traverses all nodes for example f{ || } traverses all nodes for example case foo; in {a: 1 } false ; end traverses all nodes for example def f o=1, &b; end traverses all nodes for example %W[#@@1] traverses all nodes for example a b{c d}, 1.0 do end traverses all nodes for example f x: -> do meth do end end traverses all nodes for example !(a, b = foo) traverses all nodes for example foo[1, 2] traverses all nodes for example def f (foo: 1, bar: 2, **baz, &b); end traverses all nodes for example if foo then bar; else baz; end traverses all nodes for example self::a, foo = foo traverses all nodes for example case 1; in 2; 3; else; 4; end traverses all nodes for example case foo; in "#{ %q{a} }": then true; end traverses all nodes for example !m foo traverses all nodes for example %W{a\ b} traverses all nodes for example meth 1 do end.fun bar traverses all nodes for example unless foo; bar; end traverses all nodes for example {a: if true then 42 end} traverses all nodes for example case foo; when 1, *baz; bar; when *foo; end traverses all nodes for example def f (((a))); end traverses all nodes for example alias :foo bar traverses all nodes for example meth (-1.3).abs traverses all nodes for example @foo traverses all nodes for example +2.0 ** 10 traverses all nodes for example a b{c d}, "x" do end traverses all nodes for example foo.A = 1 traverses all nodes for example p :foo, {** proc do end, b: proc do end} traverses all nodes for example next(foo) traverses all nodes for example Bar::Foo = 10 traverses all nodes for example break traverses all nodes for example ::Foo = 10 traverses all nodes for example @foo, @@bar = *foo traverses all nodes for example @@var |= 10 traverses all nodes for example if foo...bar; end traverses all nodes for example %Q{#@@1} traverses all nodes for example foo | 1 traverses all nodes for example <<-"HERE" #@@1 HERE traverses all nodes for example while class << self; a = tap do end; end; break; end traverses all nodes for example A += 1 traverses all nodes for example case foo; in ->{ 42 } then true; end traverses all nodes for example case foo; in 1...2 then true; end traverses all nodes for example false ? raise {} : tap {} traverses all nodes for example not m foo traverses all nodes for example ::Foo traverses all nodes for example a &&= 1 traverses all nodes for example # Extracted from `parser` gem. # Add the following code at the beginning of `def assert_parses`: # # File.open('./out.rb', 'a+') do |f| # f << code << "\n\n#----\n" if versions.include? '2.7' # end alias $a $b traverses all nodes for example m "#{}#{()}" traverses all nodes for example foo.fun (1) {} traverses all nodes for example begin meth end until foo traverses all nodes for example "#{1}" traverses all nodes for example defined? @foo traverses all nodes for example begin; rescue LoadError; else; end traverses all nodes for example ((b, )) = foo traverses all nodes for example f{ |a| } traverses all nodes for example def m; class << self; module M; end; end; end traverses all nodes for example foo << 1 traverses all nodes for example begin; meth; rescue => ex; bar; end traverses all nodes for example case foo; in x then x; end traverses all nodes for example case foo; in 1.. then true; end traverses all nodes for example def f ((a, a1)); end traverses all nodes for example f <<-TABLE do TABLE end traverses all nodes for example foo + 1 traverses all nodes for example fun(foo, *bar, &baz) traverses all nodes for example meth 1 do end::fun(bar) traverses all nodes for example /(?bar)/ =~ 'bar'; match traverses all nodes for example foo >> 1 traverses all nodes for example ->(scope) {}; scope traverses all nodes for example /#)/x traverses all nodes for example foo::fun (1) {} traverses all nodes for example def f(foo:); end traverses all nodes for example m { |(foo, bar)| } traverses all nodes for example a b{c(d)}, :e do end traverses all nodes for example a b{c d}, /x/ do end traverses all nodes for example foo or bar traverses all nodes for example case foo; in A[1, 2] then true; end traverses all nodes for example p <<~E x y E traverses all nodes for example 42r traverses all nodes for example foo, bar = m foo traverses all nodes for example fun { } traverses all nodes for example def f(foo: 1); end traverses all nodes for example ...100 traverses all nodes for example a b(c d), 1.0 do end traverses all nodes for example p :foo, {:a => proc do end, b: proc do end} traverses all nodes for example next traverses all nodes for example self.a, self[1, 2] = foo traverses all nodes for example def f(foo, bar); end traverses all nodes for example fun(&bar) traverses all nodes for example module ::Foo; end traverses all nodes for example %q{a\ b} traverses all nodes for example def foo() a:b end traverses all nodes for example !(foo...bar) traverses all nodes for example def f a, o=1, p, &b; end traverses all nodes for example case; when foo; 'foo'; end traverses all nodes for example :"foo#{bar}baz" traverses all nodes for example foo = bar, 1 traverses all nodes for example foo !~ 1 traverses all nodes for example case foo; in *x, y, z then nil; end traverses all nodes for example case foo; in A then true; end traverses all nodes for example while class Foo; tap do end; end; break; end traverses all nodes for example case foo; in [x,] then nil; end traverses all nodes for example foo <=> 1 traverses all nodes for example foo || (a, b = bar) traverses all nodes for example foo > 1 traverses all nodes for example %w[] traverses all nodes for example self::A, foo = foo traverses all nodes for example m1 :k => m2 do; m3() do end; end traverses all nodes for example a = b = raise :x traverses all nodes for example undef foo, :bar, :"foo#{1}" traverses all nodes for example Foo traverses all nodes for example a b{c(d)}, 1.0r do end traverses all nodes for example redo traverses all nodes for example case foo; in "#{ %q{a} }": 1 then true; end traverses all nodes for example case foo; in "a": then true; end traverses all nodes for example f { || a:b } traverses all nodes for example _1 traverses all nodes for example foo =~ 1 traverses all nodes for example 42.1r traverses all nodes for example ->{ } traverses all nodes for example while def foo a = tap do end; end; break; end traverses all nodes for example tap (proc do end) traverses all nodes for example -2 ** 10 traverses all nodes for example a ||= 1 traverses all nodes for example fun(:foo => 1) traverses all nodes for example let () { m(a) do; end } traverses all nodes for example if foo; bar; else baz; end traverses all nodes for example 42 traverses all nodes for example @@var = 10 traverses all nodes for example case foo; in *x then nil; end traverses all nodes for example return(foo) traverses all nodes for example foo ? 1 : 2 traverses all nodes for example t=1;(foo)?t:T traverses all nodes for example foo.fun traverses all nodes for example $+ traverses all nodes for example foo ^ 1 traverses all nodes for example %W[foo #{bar}foo#@baz] traverses all nodes for example foo::m += raise(bar) rescue nil traverses all nodes for example f{ |o=1, *r, &b| } traverses all nodes for example assert do: true traverses all nodes for example case foo; in **a then true; end traverses all nodes for example if (bar); foo; end traverses all nodes for example '#@@1' traverses all nodes for example [1, 2] traverses all nodes for example case foo; in A(x:) then true; end traverses all nodes for example "foo#@a" "bar" traverses all nodes for example yield() traverses all nodes for example foo = baz, *bar traverses all nodes for example -foo traverses all nodes for example p <<~E x E traverses all nodes for example m { _1 + _9 } traverses all nodes for example fun () {} traverses all nodes for example def f foo: -1 ; end traverses all nodes for example case foo; when 'bar'; bar; end traverses all nodes for example <<-'HERE' #@@1 HERE traverses all nodes for example p :foo, {"a": proc do end, b: proc do end} traverses all nodes for example def f &b; end traverses all nodes for example a = 1; a b: 1 traverses all nodes for example foo::m += raise bar rescue nil traverses all nodes for example while foo; meth end traverses all nodes for example fun(:foo => 1, &baz) traverses all nodes for example unless foo then bar; end traverses all nodes for example /source/im traverses all nodes for example begin; meth; rescue foo => ex; bar; end traverses all nodes for example case foo; in [x, *y, z] then true; end traverses all nodes for example /#@@1/ traverses all nodes for example 42.1i traverses all nodes for example f{ |a, o=1, o1=2, *r, &b| } traverses all nodes for example %I{a\ b} traverses all nodes for example traverses all nodes for example fun(foo, :foo => 1, &baz) traverses all nodes for example case; when foo; 'foo'; else 'bar'; end traverses all nodes for example :"a\ b" traverses all nodes for example `foo#{bar}baz` traverses all nodes for example <<~E 1 \ 2 3 E traverses all nodes for example a ? b & '': nil traverses all nodes for example proc {|_3|} traverses all nodes for example ::A, foo = foo traverses all nodes for example def BEGIN; end traverses all nodes for example def f a, o=1, &b; end traverses all nodes for example def foo(_, _); end traverses all nodes for example begin; meth; ensure; bar; end traverses all nodes for example def (foo).foo; end traverses all nodes for example foo::C ||= raise bar rescue nil traverses all nodes for example a b(c(d)), 1.0i do end traverses all nodes for example foo[bar, :baz => 1,] traverses all nodes for example -> (arg={}) {} traverses all nodes for example for a in foo; p a; end traverses all nodes when a class defines on_arg calls it for all arguments for example case foo; in A[] then true; end traverses all nodes for example a @b do |c|;end traverses all nodes for example fun(foo, *bar) traverses all nodes for example def END; end traverses all nodes for example -> do rescue; end traverses all nodes for example a += b = raise :x traverses all nodes for example def f a, *r, p, &b; end traverses all nodes for example bar if foo traverses all nodes for example 'a\ b' traverses all nodes for example Bar::Foo traverses all nodes for example p <<~E x y E traverses all nodes for example foo = *bar traverses all nodes for example def String::foo; end traverses all nodes for example a, *b = bar traverses all nodes for example def f(*); end traverses all nodes for example __ENCODING__ traverses all nodes for example f{ |foo:| } traverses all nodes for example case foo; in ** then true; end traverses all nodes for example foo[1, 2] = 3 traverses all nodes for example assert dogs traverses all nodes for example a, (b, c) = foo traverses all nodes for example foo.a &&= 1 traverses all nodes for example f{ |o=1, p, &b| } traverses all nodes for example f{ |a| } traverses all nodes for example foo.m += raise bar rescue nil traverses all nodes for example %w[ #@@1 ] traverses all nodes for example %s{#@1} traverses all nodes for example def f a, o=1, *r, &b; end traverses all nodes for example m [], 1 do end traverses all nodes for example case foo; in [x] then nil; end traverses all nodes for example f{ |a,| } traverses all nodes for example def f a, o=1, *r, p, &b; end traverses all nodes for example %W() traverses all nodes for example case foo; in x, *y, z then nil; end traverses all nodes for example foo = m foo traverses all nodes for example m = -> *args do end traverses all nodes for example <<'HERE' foo bar HERE traverses all nodes for example %r{a\ b} traverses all nodes for example a b(c d), "x" do end traverses all nodes for example begin end traverses all nodes for example foo || bar traverses all nodes for example class A < B end traverses all nodes when given an unexpected AST with too many children raises debugging error with too few children raises debugging error for example return() traverses all nodes for example case foo; in a: 1, _a:, ** then true; end traverses all nodes for example %I[foo #{bar}] traverses all nodes for example begin; meth; rescue; baz; else foo; ensure; bar end traverses all nodes for example class A; _1; end traverses all nodes for example break fun foo do end traverses all nodes for example begin; meth; rescue Exception, foo; bar; end traverses all nodes for example a&.b &&= 1 traverses all nodes for example *b = bar traverses all nodes for example "foo#{bar}baz" traverses all nodes for example meth 1 do end.fun bar do end traverses all nodes for example /#@1/ traverses all nodes for example case foo; in 1..2 then true; end traverses all nodes for example def f(foo=1, bar=2); end traverses all nodes for example begin; meth; rescue; foo; end traverses all nodes for example def a b: return end traverses all nodes for example -1.33 traverses all nodes for example %w[ #@1 ] traverses all nodes for example def until; end traverses all nodes for example f{ } traverses all nodes for example 1..2 traverses all nodes for example -42 traverses all nodes for example case 1; in 2; 3; else; end traverses all nodes for example next() traverses all nodes for example foo - 1 traverses all nodes for example case foo; in [*, x] then true; end traverses all nodes for example for a, b in foo; p a, b; end traverses all nodes for example :'#@1' traverses all nodes for example def f *r, &b; end traverses all nodes for example ->(**nil) {} traverses all nodes for example case foo; in 1... then true; end traverses all nodes for example class << foo; nil; end traverses all nodes for example <<-E 1 \ 2 3 E traverses all nodes for example a # # &.foo traverses all nodes for example def f a, *r, &b; end traverses all nodes for example self traverses all nodes for example -> do end traverses all nodes for example foo::Fun() traverses all nodes for example %I[#@1] traverses all nodes for example foo.a += 1 traverses all nodes for example $var = 10 traverses all nodes for example 1 in [a]; a traverses all nodes for example "a\ b" traverses all nodes for example begin; meth; rescue => @ex; bar; end traverses all nodes for example @@foo traverses all nodes for example case foo; in [x, y,] then true; end traverses all nodes for example f{ |a, *r, p, &b| } traverses all nodes for example ->(a) { } traverses all nodes for example a b(c(d)), /x/m do end traverses all nodes for example def f(**foo); end traverses all nodes for example case foo; in * then nil; end traverses all nodes for example a # # .foo traverses all nodes for example foo = raise(bar) rescue nil traverses all nodes for example { } traverses all nodes for example foo[0, 1] ||= 2 traverses all nodes for example case foo; in { a: 1 } then true; end traverses all nodes for example self.A, foo = foo traverses all nodes for example not foo traverses all nodes for example a&.b = 1 traverses all nodes for example case foo; in a: then true; end traverses all nodes for example meth 1 do end.fun(bar) traverses all nodes for example def f *r, p, &b; end traverses all nodes for example f{ |; a | } traverses all nodes for example super do end traverses all nodes for example case foo; in x if true; nil; end traverses all nodes for example *b, c = bar traverses all nodes for example class Foo < a:b; end traverses all nodes for example def x; ::A ||= 1; end traverses all nodes for example case foo; in x, then nil; end traverses all nodes for example a b{c(d)}, /x/ do end traverses all nodes for example p <<~E x y E traverses all nodes for example if /wat/; end traverses all nodes for example p :foo, {a: proc do end, b: proc do end} traverses all nodes for example %w{a\ b} traverses all nodes for example %q{#@1} traverses all nodes for example foo[0, 1] += 2 traverses all nodes for example a b{c(d)}, "x" do end traverses all nodes for example def foo =begin =end end traverses all nodes for example "#@a #@@a #$a" traverses all nodes for example f{ |*, &b| } traverses all nodes for example case foo; in [x, y] then true; end traverses all nodes for example case foo; when 'bar', 'baz'; bar; end traverses all nodes for example meth 1 do end.fun {} traverses all nodes for example p p{p(p);p p}, tap do end traverses all nodes for example m [] do end traverses all nodes for example f{ |a, o=1, p, &b| } traverses all nodes for example foo::A = 1 traverses all nodes for example a, * = bar traverses all nodes for example -> a: 1 { } traverses all nodes for example foo::A += m foo traverses all nodes for example meth[] {} traverses all nodes for example meth 1 do end.fun(bar) {} traverses all nodes for example a b{c(d)}, 1 do end traverses all nodes for example def f ((*)); end traverses all nodes for example a b(c d), :e do end traverses all nodes for example meth do; foo; rescue; bar; end traverses all nodes for example -> a: { } traverses all nodes for example ?a traverses all nodes for example 42.1ri traverses all nodes for example case foo; in 1; end traverses all nodes for example ~foo traverses all nodes for example foo.A += 1 traverses all nodes for example f{ | | } traverses all nodes for example [ 1 => 2 ] traverses all nodes for example foo[0] += raise bar rescue nil traverses all nodes for example foo::(1) traverses all nodes for example case foo; in {Foo: 42 } false ; end traverses all nodes for example %I[foo#{bar}] traverses all nodes for example () traverses all nodes for example a, *, c = bar traverses all nodes for example def x; self::A ||= 1; end traverses all nodes for example def f ((a, *r, p)); end traverses all nodes for example a b(c(d)), "x" do end traverses all nodes for example __ENCODING__ traverses all nodes for example def f (foo: 1, &b); end traverses all nodes for example p <<~E x y E traverses all nodes for example -> (a) { } traverses all nodes for example <<~FOO baz\ qux FOO traverses all nodes for example a, b = *foo, bar traverses all nodes for example +42 traverses all nodes for example f{ |a, b,| } traverses all nodes for example +foo traverses all nodes for example <<-"HERE" #@1 HERE traverses all nodes for example case foo; in a: {b:}, c: p c ; end traverses all nodes RuboCop::AST::NodePattern negation on square brackets with a node which meets all requirements of [] behaves like nonmatching doesn't match with a node which meets only 1 requirement of [] is expected to match code 1 on a string with a matching string behaves like nonmatching doesn't match with a non-matching symbol is expected to match code s(:str, "bar") and :upcase when nested in complex ways with (send str :+ (send str :to_i)) is expected to match code s(:str, "abc"), :+, and s(:send, s(:str, "1"), :to_i) with (send str :<< str) behaves like nonmatching doesn't match with (send int :- int) is expected to match code s(:int, 1), :-, and s(:int, 1) on a set with a matching value behaves like nonmatching doesn't match with a non-matching value is expected to match code :@a and s(:int, 3) on a symbol with a matching symbol behaves like nonmatching doesn't match with a non-matching symbol, but too many children behaves like nonmatching doesn't match with a non-matching symbol is expected to match code s(:send, nil, :obj) and :xyz on a sequence with a node with non-matching children is expected to match code :@b and s(:int, 1) with a node of different type is expected to match code :@@a and s(:int, 1) with a matching node behaves like nonmatching doesn't match bad syntax with negated closing curly behaves like invalid is invalid with unmatched closing paren behaves like invalid is invalid with unmatched closing curly behaves like invalid is invalid with doubled comma in arg list behaves like invalid is invalid with unmatched opening paren behaves like invalid is invalid with empty intersection behaves like invalid is invalid with negated closing paren behaves like invalid is invalid with leading comma in arg list behaves like invalid is invalid with empty parentheses behaves like invalid is invalid with empty union behaves like invalid is invalid with doubled ellipsis is expected to match code "foo" with unmatched opening curly behaves like invalid is invalid with variadic unions where not supported behaves like invalid is invalid with empty union subsequence in seq head behaves like invalid is invalid with negated ellipsis behaves like invalid is invalid with unsupported subsequence in seq head within union behaves like invalid is invalid with unmatched opening paren and `...` behaves like invalid is invalid descend with an immediate match behaves like single capture returns captured values if there is no block yields captured value(s) and returns true if there is a block with a literal match is expected to match code s(:int, 1) and s(:array, s(:array, s(:int, 2), s(:int, 3), s(:array, s(:array, s(:int, 5)))), s(:int, 4)) with a match multiple levels, depth first behaves like single capture returns captured values if there is no block yields captured value(s) and returns true if there is a block without match behaves like nonmatching doesn't match nested behaves like single capture yields captured value(s) and returns true if there is a block returns captured values if there is no block sequence with trailing ... on a node with the same type and exact number of children is expected to match code s(:int, 1) and :blah on a node with the same type and fewer children behaves like nonmatching doesn't match on a node with fewer children, with a wildcard preceding behaves like nonmatching doesn't match on a node with the same type and more children with 1 child more is expected to match code s(:int, 1), :blah, and s(:int, 1) with 2 children more is expected to match code s(:int, 1), :blah, s(:int, 1), and s(:sym, :something) on a node with non-matching children behaves like nonmatching doesn't match on a node with a different type behaves like nonmatching doesn't match captures which also perform a match on a literal behaves like single capture returns captured values if there is no block yields captured value(s) and returns true if there is a block when nested behaves like multiple capture returns captured values if there is no block yields captured value(s) and returns true if there is a block on a node type behaves like single capture yields captured value(s) and returns true if there is a block returns captured values if there is no block on a set behaves like single capture returns captured values if there is no block yields captured value(s) and returns true if there is a block on [] behaves like single capture returns captured values if there is no block yields captured value(s) and returns true if there is a block on a sequence behaves like single capture yields captured value(s) and returns true if there is a block returns captured values if there is no block repeated using ? with zero match behaves like single capture yields captured value(s) and returns true if there is a block returns captured values if there is no block with too many matching children behaves like nonmatching doesn't match behaves like repeated pattern at beginning of sequence behaves like invalid is invalid with one match behaves like single capture yields captured value(s) and returns true if there is a block returns captured values if there is no block with an ellipsis in the same sequence is expected to match code "[:hello, 1, 2, 3]" using + behaves like repeated pattern at beginning of sequence behaves like invalid is invalid with an ellipsis in the same sequence is expected to match code "[:hello, 1, 2, 3]" with one match behaves like single capture yields captured value(s) and returns true if there is a block returns captured values if there is no block with zero match behaves like nonmatching doesn't match with matching children behaves like single capture returns captured values if there is no block yields captured value(s) and returns true if there is a block using * behaves like repeated pattern with an ellipsis in the same sequence is expected to match code "[:hello, 1, 2, 3]" at beginning of sequence behaves like invalid is invalid with one match behaves like single capture returns captured values if there is no block yields captured value(s) and returns true if there is a block nested with multiple subcaptures behaves like multiple capture yields captured value(s) and returns true if there is a block returns captured values if there is no block with multiple subcaptures behaves like multiple capture yields captured value(s) and returns true if there is a block returns captured values if there is no block with zero match behaves like single capture returns captured values if there is no block yields captured value(s) and returns true if there is a block without capture is expected to match code s(:sym, :hello), s(:int, 1), s(:int, 2), and s(:int, 3) with matching children behaves like single capture yields captured value(s) and returns true if there is a block returns captured values if there is no block with no match behaves like nonmatching doesn't match bare node type #pattern returns the pattern yaml compatibility is expected to match code s(:send, nil, :obj) and :method #== returns true iff the patterns are similar on a node with the same type is expected to match code s(:send, nil, :obj) and :method on a node with a matching, hyphenated type is expected to match code s(:lvasgn, :a), :+, and s(:int, 1) #to_s is instructive marshal compatibility is expected to match code s(:send, nil, :obj) and :method on a node with a different type behaves like nonmatching doesn't match #dup is expected to match code s(:send, nil, :obj) and :method captures on ... with a remaining [] at the end behaves like single capture returns captured values if there is no block yields captured value(s) and returns true if there is a block with a remaining set at the end behaves like single capture yields captured value(s) and returns true if there is a block returns captured values if there is no block after a child behaves like single capture returns captured values if there is no block yields captured value(s) and returns true if there is a block with a remaining capture at the end behaves like multiple capture yields captured value(s) and returns true if there is a block returns captured values if there is no block with a remaining wildcard at the end behaves like single capture yields captured value(s) and returns true if there is a block returns captured values if there is no block with remaining patterns at the end behaves like single capture returns captured values if there is no block yields captured value(s) and returns true if there is a block at the very beginning of a sequence behaves like single capture yields captured value(s) and returns true if there is a block returns captured values if there is no block with a remaining sequence at the end behaves like single capture yields captured value(s) and returns true if there is a block returns captured values if there is no block with a remaining node type at the end behaves like single capture yields captured value(s) and returns true if there is a block returns captured values if there is no block with no remaining pattern at the end behaves like single capture returns captured values if there is no block yields captured value(s) and returns true if there is a block with a remaining literal at the end behaves like single capture returns captured values if there is no block yields captured value(s) and returns true if there is a block node type in seq head on a node with the same type is expected to match code s(:ivar, :@ivar), :+, and s(:int, 2) on a child with a different type behaves like nonmatching doesn't match for a child on a child with a different type behaves like nonmatching doesn't match on a child with the same type is expected to match code s(:send, nil, :foo) and :bar on a child litteral behaves like nonmatching doesn't match captures within union on simple subpatterns behaves like single capture yields captured value(s) and returns true if there is a block returns captured values if there is no block within nested sequences behaves like multiple capture yields captured value(s) and returns true if there is a block returns captured values if there is no block with a different number of captures in each branch behaves like invalid is invalid with complex nesting behaves like multiple capture yields captured value(s) and returns true if there is a block returns captured values if there is no block predicates when captured behaves like single capture yields captured value(s) and returns true if there is a block returns captured values if there is no block applied to an integer for which the predicate is true is expected to match code s(:int, 1) and :inc with multiple arguments for which the predicate is false behaves like nonmatching doesn't match for which the predicate is true is expected to match code s(:str, "c"), "a", and "d" at head position of a sequence is expected to match code s(:int, 1) and :inc when in last-child position, but all children have already been matched behaves like nonmatching doesn't match with a named argument for which the predicate is false behaves like nonmatching doesn't match for which the predicate is true is expected to match code s(:send, s(:int, 1), :+, s(:int, 2)) and {:param=>1} when not given raises an error with extra arguments raises an error with one extra argument for which the predicate is true is expected to match code s(:send, s(:int, 1), :+, s(:int, 2)) and 1 for which the predicate is false behaves like nonmatching doesn't match with an expression argument for which the predicate is true is expected to match code s(:int, 2), :+, and s(:float, 2.0) for which the predicate is false behaves like nonmatching doesn't match with a constant argument for which the predicate is true is expected to match code s(:int, 1), :+, and s(:int, 2) for which the predicate is false behaves like nonmatching doesn't match applied to an integer for which the predicate is false behaves like nonmatching doesn't match when negated is expected to match code s(:int, 1) and :inc in root position is expected to match code s(:int, 1) and :inc with name containing a numeral is expected to match code s(:int, 1) and :inc macros with a pattern without captures def_node_matcher returns the method name when called on matching code is expected to match code :hello when called on non-matching code behaves like nonmatching doesn't match when it errors raises an error with the right location def_node_search returns the method name with a predicate name when called on matching code is expected to match code nil, :foo, s(:sym, :hello), and s(:sym, :world) when called on non-matching code behaves like nonmatching doesn't match when it errors raises an error with the right location without a predicate name when called on non-matching code returns an enumerator yielding nothing when it errors raises an error with the right location when called on matching code returns an enumerator yielding the matches with a pattern with a constant is expected to match code :hello when the value is not in the set behaves like nonmatching doesn't match with a pattern with a namespaced call is expected to match code :hello when the value is not in the set behaves like nonmatching doesn't match with a pattern with captures def_node_search without a predicate name when it errors raises an error with the right location when called on matching code returns an enumerator yielding the captures when the pattern contains keyword_params returns an enumerator yielding the captures when helper is called with default keyword_params is overridden when calling the matcher and no value is given to the matcher uses the defaults some defaults are not params raises an error when called on non-matching code returns an enumerator yielding nothing with a predicate name when called on matching code is expected to match code nil, :foo, s(:sym, :hello), and s(:sym, :world) when called on non-matching code behaves like nonmatching doesn't match when it errors raises an error with the right location def_node_matcher when called on matching code is expected to eq :hello when called on non-matching code behaves like nonmatching doesn't match when it errors raises an error with the right location funcalls without extra arguments is expected to match code :a and s(:int, 1) with one argument is expected to match code s(:str, "foo") and "foo" with multiple arguments is expected to match code s(:str, "c"), "a", and "d" regexp matches symbols or strings comments behaves like single capture yields captured value(s) and returns true if there is a block returns captured values if there is no block nil against a node pattern (bug #5470) behaves like nonmatching doesn't match nil value in AST behaves like nonmatching doesn't match nil literals is expected to match code nil value in AST, use nil? method is expected to match code nil and :foo unions with a nested sequence is expected to match code s(:const, nil, :Const) and :method nested inside a sequence is expected to match code s(:const, nil, :Const) and :method variadic with fixed terms works for cases with fixed arity before and after union works for cases with variadic terms after union works for cases with variadic terms before and after union with variadic terms works for cases with variadic terms after union works for cases with fixed arity before and after union works for cases with variadic terms before and after union multiple works for complex cases at the top level containing string literals is expected to match code s(:str, "a") and :upcase containing mixed node and literals is expected to match code nil and :obj containing integer literals is expected to match code s(:int, 10) and :abs containing symbol literals when the AST has a matching symbol is expected to match code s(:send, nil, :obj) and :b when the AST does not have a matching symbol behaves like nonmatching doesn't match containing multiple [] on a node which meets all requirements of the first [] is expected to match code 3 on a node which meets all requirements of the second [] is expected to match code 2.4 on a node which meets some requirements but not all behaves like nonmatching doesn't match simple sequence on a node with a different type behaves like nonmatching doesn't match on a node with the same type and matching children is expected to match code s(:int, 1), :+, and s(:int, 1) on a node with the same type and non-matching children with non-matching receiver type behaves like nonmatching doesn't match with non-matching selector behaves like nonmatching doesn't match on a node with too many children behaves like nonmatching doesn't match with a nested sequence in non-head position is expected to match code s(:send, s(:send, nil, :obj), :a) and :b with a nested sequence in head position behaves like invalid is invalid ellipsis with a nested sequence at the end, but no remaining child behaves like nonmatching doesn't match preceding a capture behaves like single capture yields captured value(s) and returns true if there is a block returns captured values if there is no block with a set at the end, but no remaining child to match it behaves like nonmatching doesn't match preceding multiple captures behaves like multiple capture yields captured value(s) and returns true if there is a block returns captured values if there is no block with a wildcard at the end, but no remaining child to match it behaves like nonmatching doesn't match at the very beginning of a sequence is expected to match code s(:int, 10), :*, and s(:int, 1) with a nodetype at the end, but no remaining child to match it behaves like nonmatching doesn't match with [] at the end, but no remaining child to match it behaves like nonmatching doesn't match commas with commas randomly strewn around behaves like invalid is invalid in any order invalid doubled with ellipsis behaves like multiple capture yields captured value(s) and returns true if there is a block returns captured values if there is no block doubled with ellipsis in wrong order behaves like nonmatching doesn't match nested behaves like invalid is invalid at the beginning of a sequence behaves like invalid is invalid containing ellipsis not at the end behaves like invalid is invalid with an ellipsis inside and outside behaves like multiple capture yields captured value(s) and returns true if there is a block returns captured values if there is no block captured without ellipsis behaves like single capture yields captured value(s) and returns true if there is a block returns captured values if there is no block with an ellipsis behaves like single capture returns captured values if there is no block yields captured value(s) and returns true if there is a block doubled separated by fixed argument behaves like multiple capture returns captured values if there is no block yields captured value(s) and returns true if there is a block separated by an ellipsis behaves like multiple capture returns captured values if there is no block yields captured value(s) and returns true if there is a block with a captured ellipsis nested behaves like multiple capture yields captured value(s) and returns true if there is a block returns captured values if there is no block matching non sequential children behaves like single capture returns captured values if there is no block yields captured value(s) and returns true if there is a block matching all children behaves like single capture returns captured values if there is no block yields captured value(s) and returns true if there is a block without ellipsis with too many children behaves like nonmatching doesn't match with matching children behaves like multiple capture returns captured values if there is no block yields captured value(s) and returns true if there is a block with too few children behaves like nonmatching doesn't match wildcards unnamed wildcards within a sequence is expected to match code nil and :Const in head position of a sequence is expected to match code s(:int, 1), :+, and s(:send, nil, :a) within a sequence with other patterns intervening is expected to match code :@abc and s(:int, 22) negated behaves like nonmatching doesn't match at the root level is expected to match code s(:sclass, s(:self), s(:def, :something, s(:args), s(:int, 1))) and :freeze named wildcards within a sequence with values which can be unified is expected to match code s(:int, 5), :+, and s(:int, 5) unifying the node type with an argument is expected to match code s(:send, nil, :obj) and :send with values which cannot be unified behaves like nonmatching doesn't match within a union with a succeeding unifying constraint with all branches with the wildcard that can not be unified behaves like nonmatching doesn't match matching another branch is expected to match code s(:array, s(:int, 2), s(:int, 1)) and s(:int, 2) matching the first branch is expected to match code s(:array, s(:int, 1), s(:int, 2)) and s(:int, 2) with branches without the wildcard encountered first behaves like invalid is invalid encountered after behaves like invalid is invalid confined to the union without unification is expected to match code s(:int, 2) and s(:int, 1) with partial unification that can not be unified behaves like nonmatching doesn't match matching the unified branch is expected to match code s(:int, 5) and s(:int, 5) matching the free branch is expected to match code s(:int, 2) and s(:int, 1) with a preceding unifying constraint that can not be unified behaves like nonmatching doesn't match matching a branch is expected to match code s(:int, 2) and s(:array, s(:int, 2), s(:int, 1)) at the root level is expected to match code s(:sclass, s(:self), s(:def, :something, s(:args), s(:int, 1))) and :freeze in head position of a sequence is expected to match code s(:int, 1), :+, and s(:send, nil, :a) within a sequence with other patterns intervening is expected to match code :@abc and s(:int, 22) params when preceded by $... behaves like single capture yields captured value(s) and returns true if there is a block returns captured values if there is no block as named parameters when extra are provided raises an ArgumentError when not provided raises an ArgumentError when provided as argument to match is expected to match code s(:int, 10) and {:foo=>#} param number zero in a position which matches original target node is expected to match code 1 in a position which does not match original target node behaves like nonmatching doesn't match when negated, with a matching value behaves like nonmatching doesn't match when negated, with a nonmatching value is expected to match code s(:const, s(:const, nil, :Namespace), :B) and :A without explicit number is expected to match code s(:const, s(:const, nil, :Namespace), :A), :A, and s(:const, nil, :Namespace) when captured behaves like single capture returns captured values if there is no block yields captured value(s) and returns true if there is a block when inside a union, with a matching value is expected to match code s(:int, 10) and 10 when inside a union, with a nonmatching value behaves like nonmatching doesn't match when inside an intersection is expected to match code s(:int, 20), 10, and 20 in a nested sequence is expected to match code s(:send, s(:send, s(:int, 5), :dec), :inc), :inc, and :dec when preceded by ... is expected to match code s(:send, s(:int, 1), :+, s(:int, 10)) and s(:int, 10) in root position is expected to match code s(:int, 10) and s(:int, 10) in root position is expected to match code s(:int, 10) and # captures on a wildcard nested in any child behaves like multiple capture yields captured value(s) and returns true if there is a block returns captured values if there is no block in head position in a sequence against literal (bug #5470) behaves like nonmatching doesn't match in head position in a sequence behaves like single capture yields captured value(s) and returns true if there is a block returns captured values if there is no block at the root level behaves like single capture yields captured value(s) and returns true if there is a block returns captured values if there is no block in non-head position in a sequence behaves like single capture yields captured value(s) and returns true if there is a block returns captured values if there is no block in a nested sequence behaves like single capture returns captured values if there is no block yields captured value(s) and returns true if there is a block in head position in a sequence against nil (bug #5470) behaves like nonmatching doesn't match .descend yields the given argument if it is not a Node yields all children depth first literals double quoted string literals is expected to match code "foo" bare literal on a node behaves like nonmatching doesn't match on a matching literal is expected to match code :bar symbol literals is expected to match code :foo negative integer literals is expected to match code -100 single quoted string literals is expected to match code "foo" negative float literals is expected to match code -2.5 positive float literals is expected to match code 1.0 caret (ascend) inside a union is expected to match code "abc" using unification to match self within parent with self in the wrong position behaves like nonmatching doesn't match with self in the right position is expected to match code 2 inside an intersection is expected to match code 1 repeated twice is expected to match code 1 within sequence not in head is expected to match code s(:int, 1) and :inc of a sequence is expected to match code s(:int, 1) and :inc in head is expected to match code 1 of a sequence is expected to match code 1 used with a node type which matches is expected to match code 1 which doesn't match behaves like nonmatching doesn't match RuboCop::AST::StrNode #heredoc? with a heredoc is expected to be heredoc with a string with interpolation is expected not to be heredoc with a normal string is expected not to be heredoc #character_literal? with a character literal is expected to be character literal with a normal string literal is expected not to be character literal with a heredoc is expected not to be character literal .new with a normal string is expected to be a kind of RuboCop::AST::StrNode with a heredoc is expected to be a kind of RuboCop::AST::StrNode with a string with interpolation is expected to be a kind of RuboCop::AST::StrNode RuboCop::AST::DefNode #method_name with a setter method is expected to eq :foo= with a unary method is expected to eq :-@ with a plain method is expected to eq :foo with an operator method is expected to eq :== when using Ruby 2.7 or newer #argument_forwarding? is expected to be argument forwarding #first_argument with a single rest argument is expected to be restarg type with a single regular argument is expected to be arg type with a single keyword argument is expected to be kwoptarg type with no arguments is expected to be nil with multiple regular arguments is expected to be arg type with multiple mixed arguments is expected to be arg type #block_argument? with a block argument is expected to be block argument with regular arguments is expected not to be block argument with mixed arguments is expected to be block argument with no arguments is expected not to be block argument #method? when message does not match when argument is a string is expected not to be method "foo" when argument is a symbol is expected not to be method :foo when message matches when argument is a symbol is expected to be method :bar when argument is a string is expected to be method "bar" #endless? with standard method definition is expected not to be endless with endless method definition is expected to be endless #comparison_method? with a comparison method is expected to be comparison method with a regular method is expected not to be comparison method #self_receiver? with a singleton method definition is expected not to be self receiver with an instance method definition is expected not to be self receiver with a class method definition is expected to be self receiver #const_receiver? with a class method definition is expected not to be const receiver with an instance method definition is expected not to be const receiver with a singleton method definition is expected to be const receiver #arguments? with no arguments is expected not to be arguments with multiple regular arguments is expected to be arguments with a single regular argument is expected to be arguments with multiple mixed arguments is expected to be arguments with a single rest argument is expected to be arguments with a single keyword argument is expected to be arguments #body with a multi-expression body is expected to be begin type with no body is expected to be nil with a single expression body is expected to be send type #operator_method? with a binary operator method is expected to be operator method with a setter method is expected not to be operator method with a regular method is expected not to be operator method with a unary operator method is expected to be operator method #camel_case_method? with a regular method is expected not to be camel case method with a camel case method is expected to be camel case method #rest_argument? with mixed arguments is expected to be rest argument with regular arguments is expected not to be rest argument with a rest argument is expected to be rest argument with no arguments is expected not to be rest argument .new with a def node is expected to be a kind of RuboCop::AST::DefNode with a defs node is expected to be a kind of RuboCop::AST::DefNode #bang_method? with a predicate method is expected not to be bang method with a bang method is expected to be bang method with a regular method is expected not to be bang method #arguments with multiple mixed arguments is expected to eq 2 with no arguments is expected to be empty with multiple regular arguments is expected to eq 2 with argument forwarding is expected to eq 1 with a single rest argument is expected to eq 1 with a single regular argument is expected to eq 1 #assignment_method? with a bracket assignment method is expected to be assignment method with a comparison method is expected not to be assignment method with an assignment method is expected to be assignment method with a regular method is expected not to be assignment method #predicate_method? with a bang method is expected not to be predicate method with a predicate method is expected to be predicate method with a regular method is expected not to be predicate method #void_context? with a bracket assignment method is expected to be void context with an initializer method is expected to be void context with a regular method is expected not to be void context with a regular assignment method is expected to be void context with a comparison method is expected not to be void context #last_argument with a single regular argument is expected to be arg type with multiple mixed arguments is expected to be restarg type with a single rest argument is expected to be restarg type with a single keyword argument is expected to be kwoptarg type with no arguments is expected to be nil with multiple regular arguments is expected to be arg type #receiver with an instance method definition is expected to be nil with a class method definition is expected to be self type with a singleton method definition is expected to be const type RuboCop::AST::ArgNode .new with a keyword argument is expected to be a kind of RuboCop::AST::ArgNode with a lambda literal is expected to be a kind of RuboCop::AST::ArgNode with a double splatted argument is expected to be a kind of RuboCop::AST::ArgNode with a block argument is expected to be a kind of RuboCop::AST::ArgNode with a block is expected to be a kind of RuboCop::AST::ArgNode with an optional argument is expected to be a kind of RuboCop::AST::ArgNode with a shadow argument is expected to be a kind of RuboCop::AST::ArgNode with argument forwarding with Ruby >= 3.0 is expected to be a kind of RuboCop::AST::ArgNode with Ruby >= 2.7 is expected to be a kind of RuboCop::AST::ArgNode with a splatted argument is expected to be a kind of RuboCop::AST::ArgNode with an optional keyword argument is expected to be a kind of RuboCop::AST::ArgNode with a method definition is expected to be a kind of RuboCop::AST::ArgNode #default? with a splatted argument is expected to equal false with an optional argument is expected to equal true with a regular argument is expected to equal false with a double splatted argument is expected to equal false with a shadow argument is expected to equal false with a block argument is expected to equal false with an optional keyword argument is expected to equal true with argument forwarding with Ruby >= 3.0 is expected to equal false with Ruby >= 2.7 is expected to equal false with a block is expected to equal false #name with a regular argument is expected to eq :x with a block argument is expected to eq :x with a block is expected to eq :x with an optional argument is expected to eq :x with a keyword argument is expected to eq :x with an optional keyword argument is expected to eq :x with a splatted argument is expected to eq :x with a shadow argument is expected to eq :x with a nameless splatted argument is expected to be nil with a double splatted argument is expected to eq :x with argument forwarding with Ruby >= 2.7 is expected to be nil with Ruby >= 3.0 is expected to be nil with a nameless double splatted argument is expected to be nil #default_value with a block argument is expected to be nil with an optional argument is expected to eq s(:int, 42) with a block is expected to be nil with a double splatted argument is expected to be nil with a regular argument is expected to be nil with a shadow argument is expected to be nil with a splatted argument is expected to be nil with an optional keyword argument is expected to eq s(:int, 42) with argument forwarding with Ruby >= 3.0 is expected to be nil with Ruby >= 2.7 is expected to be nil RuboCop::AST::CaseMatchNode when using Ruby 2.7 or newer #in_pattern_branches is expected to all be in pattern type is expected to eq 3 #each_in_pattern when not passed a block is expected to be a kind of Enumerator when passed a block yields all the conditions #keyword is expected to eq "case" #else_branch #else? with an else statement is expected to be sym type without an else statement is expected to be nil with an empty else statement is expected to be empty else type #else? without an else statement is expected not to be else with an else statement is expected to be else .new is expected to be a kind of RuboCop::AST::CaseMatchNode #branches when there is an else with else body returns all the bodies with empty else returns all the bodies when there is no else keyword returns only then when bodies RuboCop::AST::WhileNode #inverse_keyword is expected to eq "until" #loop_keyword? with a statement while is expected to be loop keyword with a modifier while is expected to be loop keyword #do? without a do keyword is expected not to be do with a do keyword is expected to be do #post_condition_loop? with a modifier while is expected to be post condition loop with a statement while is expected not to be post condition loop #keyword is expected to eq "while" .new with a statement while is expected to be a kind of RuboCop::AST::WhileNode with a modifier while is expected to be a kind of RuboCop::AST::WhileNode RuboCop::AST::InPatternNode when using Ruby 2.7 or newer #pattern with a variable pattern is expected to be match var type with a pin operator is expected to be pin type with an array pattern is expected to be array pattern type with an alternative pattern is expected to be match alt type with a hash pattern is expected to be hash pattern type with a value pattern is expected to be int type with an as pattern is expected to be match as type #branch_index is expected to eq 0 is expected to eq 2 is expected to eq 1 .new is expected to be a kind of RuboCop::AST::InPatternNode #then? with a then keyword is expected to be then without a then keyword is expected not to be then #body without a then keyword is expected to be array type with a then keyword is expected to be sym type RuboCop::AST::BreakNode behaves like wrapped arguments node #arguments with multiple literal arguments is expected to eq 2 with a single splat argument is expected to eq 1 with a single argument and braces is expected to eq 1 with no arguments and braces is expected to be empty with a single argument is expected to eq 1 with no arguments is expected to be empty .new without arguments is expected to be a kind of RuboCop::AST::BreakNode with arguments is expected to be a kind of RuboCop::AST::BreakNode RuboCop::AST::KeywordSplatNode #value is expected to eq s(:kwsplat, s(:send, nil, :foo)) #hash_rocket? is expected not to be hash rocket .new is expected to be a kind of RuboCop::AST::KeywordSplatNode #colon? is expected not to be colon #key is expected to eq s(:kwsplat, s(:send, nil, :foo)) #value_delta when using hash rocket delimiters when keyword splat is behind is expected to eq 0 when keyword splat is ahead is expected to eq 0 when keyword splat is on the same line is expected to eq 0 when keyword splat is left aligned is expected to eq 0 when using colon delimiters when keyword splat is behind is expected to eq 0 when keyword splat is on the same line is expected to eq 0 when keyword splat is ahead is expected to eq 0 when keyword splat is left aligned is expected to eq 0 #key_delta with alignment set to :right when using hash rocket delimiters when keyword splat is behind is expected to eq 0 when keyword splat is aligned is expected to eq 0 when keyword splat is on the same line is expected to eq 0 when keyword splat is ahead is expected to eq 0 when using colon delimiters when keyword splat is behind is expected to eq 0 when keyword splat is aligned is expected to eq 0 when keyword splat is ahead is expected to eq 0 when keyword splat is on the same line is expected to eq 0 with alignment set to :left when using colon delimiters when keyword splat is behind is expected to eq -2 when keyword splat is aligned is expected to eq 0 when keyword splat is on the same line is expected to eq 0 when keyword splat is ahead is expected to eq 2 when using hash rocket delimiters when keyword splat is aligned is expected to eq 0 when keyword splat is on the same line is expected to eq 0 when keyword splat is behind is expected to eq -2 when keyword splat is ahead is expected to eq 2 #operator is expected to eq "**" #same_line? when both pairs are on the same line is expected to be same line s(:kwsplat, s(:send, nil, :foo)) when a multiline pair shares the same line is expected to be same line s(:pair, s(:sym, :a), s(:begin)) is expected to be same line s(:kwsplat, s(:send, nil, :foo)) when pairs are on separate lines is expected not to be same line s(:kwsplat, s(:send, nil, :foo)) RuboCop::AST::AliasNode #old_identifier is expected to eq :bar is expected to be sym type .new is expected to be a kind of RuboCop::AST::AliasNode #new_identifier is expected to be sym type is expected to eq :foo RuboCop::AST::LambdaNode #method_name is expected to eq :lambda #arguments is expected to eq 2 #receiver is expected to be nil RuboCop::AST::ProcessedSource with heavily commented source #comment_at_line returns the comment at the given line number returns nil if line has no comment #line_with_comment? returns false for lines without comments returns true for lines with comments #contains_comment? provided source_range on line with comment is expected to equal true provided source_range on line without comment is expected to equal false provided source_range on comment line is expected to equal true provided a multiline source_range with at least one line with comment is expected to equal true #comments_before_line returns comments on or before given line #find_comment yields nil when there is no match yields correct comment #each_comment_in_lines yields the comments #each_comment yields all comments #blank? with source with content returns false with source of no content returns true #path is the path passed to .new #preceding_line returns source of line before token #first_token_of accepts Node as an argument returns first token for node #lines contains lines as string without linefeed has same number of elements as line count is an array #[] when start index and length are passed returns the array of lines when a range is passed returns the array of lines when an index is passed returns the line #file_path returns file path #comments is an array of comments when the source is invalid returns [] #last_token_of accepts Node as an argument returns last token for node .from_file raises a Errno::ENOENT when the file does not exist when the file exists returns an instance of ProcessedSource sets the file path to the instance's #path #tokens has an array of tokens #start_with? with present source returns false when passed string that does not start source returns true when passed string that starts source with blank source returns false #buffer is a source buffer token enumerables #find_token yields correct token yields nil when there is no match #each_token yields all tokens #tokens_within accepts Node as an argument returns tokens for node when heredoc as argument is present returns tokens for heredoc node returns tokens for node after heredoc returns tokens for node before heredoc #following_line returns source of line after token #parser_error when the source could not be parsed due to encoding error returns the error when the source was properly parsed is nil when the source lacks encoding comment and is really utf-8 encoded but has been read as US-ASCII is nil #ast is the root node of AST valid_syntax? when the source could not be parsed due to encoding error returns false when the source is valid but has some warning diagnostics returns true when the source itself is valid encoding but includes strange encoding literals that are accepted by MRI returns true when the source is invalid returns false when the source is completely valid returns true when a line starts with an integer literal tokenizes the source correctly RuboCop::AST::WhenNode #branch_index is expected to eq 1 is expected to eq 2 is expected to eq 0 #body with a then keyword is expected to be sym type without a then keyword is expected to be array type #then? with a then keyword is expected to be then without a then keyword is expected not to be then .new is expected to be a kind of RuboCop::AST::WhenNode #each_condition when passed a block yields all the conditions when not passed a block is expected to be a kind of Enumerator #conditions with a multiple conditions is expected to all be literal is expected to eq 3 with a single condition is expected to eq 1 is expected to all be literal RuboCop::AST::AsgnNode .new with a `cvasgn` node is expected to be a kind of RuboCop::AST::AsgnNode with a `gvasgn` node is expected to be a kind of RuboCop::AST::AsgnNode with a `lvasgn` node is expected to be a kind of RuboCop::AST::AsgnNode with a `ivasgn` node is expected to be a kind of RuboCop::AST::AsgnNode #name with a `cvasgn` node is expected to eq :@@var with a `lvasgn` node is expected to eq :var with a `ivasgn` node is expected to eq :@var with a `gvasgn` node is expected to eq :$var #expression with a `cvasgn` node is expected to eq s(:send, nil, :value) with a `gvasgn` node is expected to eq s(:send, nil, :value) with a `ivasgn` node is expected to eq s(:send, nil, :value) with a `lvasgn` node is expected to eq s(:send, nil, :value) RuboCop::AST::ForNode #void_context? without a do keyword is expected to be void context with a do keyword is expected to be void context #collection is expected to be sym type #body is expected to be sym type .new is expected to be a kind of RuboCop::AST::ForNode #variable is expected to be lvasgn type #loop_keyword? is expected to be loop keyword #keyword is expected to eq "for" #do? with a do keyword is expected to be do without a do keyword is expected not to be do #post_condition_loop? is expected not to be post condition loop RuboCop::AST::Node #parent_module_name when node on singleton class is expected to eq "Foo::#" when node nested in an unknown block is expected to be nil when node on class in singleton class is expected to eq "Foo::#::Bar" when node nested in a class << exp is expected to be nil when node on module is expected to eq "Foo" when node on top level is expected to eq "Object" #struct_constructor? struct definition without block does not match ::Struct matches struct definition with a block matches #numeric_type? when rational literal is true when string literal is true when integer literal is true when complex literal whose imaginary part is a rational is true when complex literal is true when float literal is true #value_used? within a while node is true only for the condition at the end of a block is always true at the top level is false within a module definition node is always true within an array literal at the top level is always false assigned to an ivar is always true within a singleton class node is always true within a method call node is always true within an if...else..end node at the top level is true only for the condition nested in a method call is always true within a class definition node is always true sibling_access returns trivial values for a root node for a node with siblings returns the expected values for a single child returns the expected values #module_definition? nested modules matches namespaced modules matches with ::ModuleName matches using module keyword matches prepend Module.new matches included module definition matches with Module.new matches when using numbered parameter matches #argument_type? method arguments returns true for all argument types block arguments returns true for all argument types #recursive_basic_literal? behaves like literal returns true for `!true` behaves like literal returns true for `{ :a => 1, :b => 2 }` behaves like literal returns true for `{ a: 1, b: 2 }` behaves like non literal returns false for `{ :sym => some_method_call }` behaves like non literal returns false for `/.#{some_method_call}/` behaves like literal returns true for `1` behaves like literal returns true for `[1, 2, 3]` behaves like literal returns true for `/./` behaves like literal returns true for `'str'` behaves like literal returns true for `(1)` behaves like literal returns true for `(false && true)` behaves like non literal returns false for `some_method_call` behaves like literal returns true for `(false <=> true)` behaves like non literal returns false for `(x or false)` behaves like non literal returns false for `%r{abx#{foo}}ixo` behaves like non literal returns false for `(x && false)` behaves like literal returns true for `%r{abx}ixo` behaves like literal returns true for `"#{2}"` behaves like non literal returns false for `{ some_method_call => :sym }` behaves like literal returns true for `nil` behaves like non literal returns false for `[some_method_call]` behaves like non literal returns false for `some_method_call(x, y)` behaves like non literal returns false for `(x == false)` behaves like literal returns true for `(false or true)` behaves like literal returns true for `1.0` behaves like literal returns true for `false` #class_constructor? class definition does not match class definition on outer scope matches class definition with a block matches module definition with a block matches #class_definition? with Struct matches when using numbered parameter matches constant defined as Struct without block does not match with self singleton class matches namespaced class matches with Class.new matches when using numbered parameter matches with ::ClassName matches with inheritance matches with object singleton class matches without inheritance matches #conditional? when `case` node is true when `case_match` node is true when `while` node is true when post condition loop node is false when `until` node is true when `if` node is true #pure? for a method call returns false for a cvar assignment returns false for a hash literal which contains a method call returns false with only literal children returns true for a class definition returns false for an lvar assignment returns false for a nested if where the innermost descendants are local vars and literals returns true where one branch contains a method call returns false where one branch contains an assignment statement returns false for an array literal which contains a method call returns false with only literal children returns true for a gvar assignment returns false for a module definition returns false for an ivar assignment returns false for a regexp with options returns true with interpolated segments returns false with no interpolation returns true for an integer literal returns true RuboCop::AST::FloatNode #value is expected to eq 1.5 #sign? explicit positive float is expected to be sign explicit negative float is expected to be sign .new is expected to be a kind of RuboCop::AST::FloatNode RuboCop::AST::SendNode #nonmutating_unary_operator_method? with a nonmutating unary operator method is expected to be nonmutating unary operator method with a regular method is expected not to be nonmutating unary operator method #non_bare_access_modifier? when node is a non-bare `module_function` is expected to be non bare access modifier when node does not have an argument is expected not to be non bare access modifier when node is not an access modifier is expected not to be non bare access modifier #nonmutating_array_method? with a regular method is expected not to be nonmutating array method with a mutating Array method is expected not to be nonmutating array method with a nonmutating Array method is expected to be nonmutating array method #negation_method? with prefix `not` is expected to be negation method with a non-negated method is expected not to be negation method with suffix `not` is expected not to be negation method with prefix bang is expected to be negation method #const_receiver? with a constant receiver is expected to be const receiver with a non-constant receiver is expected not to be const receiver with a self receiver is expected not to be const receiver #nonmutating_binary_operator_method? with a regular method is expected not to be nonmutating binary operator method with a nonmutating binary operator method is expected to be nonmutating binary operator method with a mutating binary operator method is expected not to be nonmutating binary operator method #command? when argument is a symbol with an implicit receiver is expected to be command :bar with an explicit receiver is expected not to be command :bar when argument is a string with an explicit receiver is expected not to be command "bar" with an implicit receiver is expected to be command "bar" #self_receiver? with a non-self receiver is expected not to be self receiver with a self receiver is expected to be self receiver with an implicit receiver is expected not to be self receiver .new with a safe navigation method send is expected to be a kind of RuboCop::AST::SendNode with a regular method send is expected to be a kind of RuboCop::AST::SendNode #binary_operation?? with a unary operation is expected not to be binary operation with a regular method call is expected not to be binary operation with an implicit call method is expected not to be binary operation with a binary operation is expected to be binary operation #arithmetic_operation? with a unary numeric operation is expected not to be arithmetic operation with a binary arithmetic operation is expected to be arithmetic operation with a regular method call is expected not to be arithmetic operation #lambda_literal? with a lambda method is expected not to be lambda literal with a non-lambda method is expected not to be lambda with `a.() {}` style method is expected not to be lambda with a stabby lambda is expected to be lambda literal #unary_operation? with a unary operation is expected to be unary operation with an implicit call method is expected not to be unary operation with a binary operation is expected not to be unary operation with a regular method call is expected not to be unary operation #last_argument with a single splat argument is expected to be splat type with multiple mixed arguments is expected to be splat type with multiple literal arguments is expected to be sym type with no arguments is expected to be nil with a single literal argument is expected to be sym type #block_argument? with no arguments is expected not to be block argument with mixed arguments is expected to be block argument with regular arguments is expected not to be block argument with a block argument is expected to be block argument #camel_case_method? with a camel case method is expected to be camel case method with a regular method is expected not to be camel case method #nonmutating_hash_method? with a mutating Hash method is expected not to be nonmutating hash method with a regular method is expected not to be nonmutating hash method with a nonmutating Hash method is expected to be nonmutating hash method #arguments with a single literal argument is expected to eq 1 with multiple literal arguments is expected to eq 2 with multiple mixed arguments is expected to eq 2 with a single splat argument is expected to eq 1 with no arguments is expected to be empty #prefix_not? with keyword `not` is expected to be prefix not with a bang method is expected not to be prefix not with a non-negated method is expected not to be prefix not #implicit_call? with an explicit call method is expected not to be implicit call with an implicit call method is expected to be implicit call with a regular method is expected not to be implicit call #lambda? with a non-lambda method is expected not to be lambda with a lambda method is expected to be lambda with a stabby lambda method is expected to be lambda with a method named lambda in a class is expected not to be lambda #bang_method? with a predicate method is expected not to be bang method with a regular method is expected not to be bang method with a bang method is expected to be bang method #def_modifier? with a block containing a method definition is expected not to be def modifier with several prefixed def modifiers is expected to be def modifier with a prefixed def modifier is expected to be def modifier #def_modifier with a prefixed def modifier is expected to eq :bar with call with no argument is expected to be nil with a block containing a method definition is expected to be nil with several prefixed def modifiers is expected to eq :qux #macro? with a receiver when parent is a module is expected not to be macro when parent is a class is expected not to be macro without a receiver when parent is a block in a macro scope is expected to be macro when parent is a class constructor is expected to be macro when parent is a struct constructor is expected to be macro when parent is a keyword begin inside of an class is expected to be macro when in the global scope is expected to be macro when parent is a block not in a macro scope is expected not to be macro when in an if is expected to be macro without a parent is expected to be macro when parent is a begin without a parent is expected to be macro when parent is a class is expected to be macro with Ruby >= 2.7 when parent is a numblock in a macro scope is expected to be macro when the condition of an if is expected not to be macro when parent is a singleton class is expected to be macro when parent is a module is expected to be macro when parent is a method definition is expected not to be macro #method_name with an operator method is expected to eq :== with an implicit call method is expected to eq :call with a setter method is expected to eq :bar= with a plain method is expected to eq :bar #prefix_bang? with a non-negated method is expected not to be prefix bang with a bang method is expected to be prefix bang with keyword `not` is expected not to be prefix bang #loop_keyword? is expected not to be loop keyword #assignment_method? with a bracket assignment method is expected to be assignment method with a regular method is expected not to be assignment method with a comparison method is expected not to be assignment method with an assignment method is expected to be assignment method #bare_access_modifier? when node is a bare `module_function` is expected to be bare access modifier when node has an argument is expected not to be bare access modifier with Ruby >= 2.7 when node is access modifier in block is expected to be bare access modifier when node is access modifier in numblock is expected to be bare access modifier when node is not an access modifier is expected not to be bare access modifier #splat_argument? with no arguments is expected not to be splat argument with a splat argument is expected to be splat argument with mixed arguments is expected to be splat argument with regular arguments is expected not to be splat argument #double_colon? with a double colon is expected to be double colon with a dot is expected not to be double colon without a dot is expected not to be double colon with a unary method is expected not to be double colon #attribute_accessor? with an accessor returns the accessor method and Array] with a call without arguments is expected to be nil #receiver with a variable receiver is expected to be send type with a literal receiver is expected to be str type with no receiver is expected to be nil #predicate_method? with a regular method is expected not to be predicate method with a predicate method is expected to be predicate method with a bang method is expected not to be predicate method #access_modifier? when node is not an access modifier is expected not to be bare access modifier when node is a bare `module_function` is expected to be access modifier when node is a non-bare `module_function` is expected to be access modifier #nonmutating_string_method? with a regular method is expected not to be nonmutating string method with a mutating String method is expected not to be nonmutating string method with a nonmutating String method is expected to be nonmutating string method #first_argument with a single literal argument is expected to be sym type with a single splat argument is expected to be splat type with multiple literal arguments is expected to be sym type with multiple mixed arguments is expected to be sym type with no arguments is expected to be nil #parenthesized? with no arguments when not using parentheses is expected not to be parenthesized when using parentheses is expected to be parenthesized with arguments when using parentheses is expected to be parenthesized when not using parentheses is expected not to be parenthesized #method? when message matches when argument is a symbol is expected to be method :bar when argument is a string is expected to be method "bar" when message does not match when argument is a string is expected not to be method "foo" when argument is a symbol is expected not to be method :foo #block_node with no block is expected to be nil with a block literal is expected to be block type with a block argument is expected to be nil with Ruby >= 2.7 with a numblock literal is expected to be numblock type #enumerable_method? with an enumerable method is expected to be enumerable method with a regular method is expected not to be enumerable method #comparison_method? with a negation method is expected not to be comparison method with a regular method is expected not to be comparison method with a comparison method is expected to be comparison method #post_condition_loop? is expected not to be post condition loop #operator_method? with a regular method is expected not to be operator method with a unary operator method is expected to be operator method with a binary operator method is expected to be operator method with a setter method is expected not to be operator method #dot? without a dot is expected not to be dot with a unary method is expected not to be dot with a double colon is expected not to be dot with a dot is expected to be dot #nonmutating_operator_method? with a nonmutating binary operator method is expected to be nonmutating operator method with a nonmutating unary operator method is expected to be nonmutating operator method with a mutating binary operator method is expected not to be nonmutating operator method with a regular method is expected not to be nonmutating operator method #arguments? with multiple mixed arguments is expected to be arguments with no arguments is expected not to be arguments with a single literal argument is expected to be arguments with multiple literal arguments is expected to be arguments with a single splat argument is expected to be arguments #block_literal? with no block is expected not to be block literal with a block literal is expected to be block literal with Ruby >= 2.7 with a numblock literal is expected to be block literal with a block argument is expected not to be block literal #setter_method? with a regular method is expected not to be setter method with an operator method is expected not to be setter method with an indexed setter method is expected to be setter method with a setter method is expected to be setter method RuboCop::AST::DefinedNode #receiver is expected to be nil #arguments is expected to all be sym type is expected to eq 1 #method_name is expected to eq :defined? .new with a defined? node is expected to be a kind of RuboCop::AST::DefinedNode RuboCop::AST::OpAsgnNode #expression is expected to eq s(:send, nil, :value) #assignment_node is expected to be a kind of RuboCop::AST::AsgnNode .new with an `op_asgn_node` node is expected to be a kind of RuboCop::AST::OpAsgnNode #name is expected to eq :var #operator with -= is expected to eq :- with |= is expected to eq :| with **= is expected to eq :** with *= is expected to eq :* with %= is expected to eq :% with /= is expected to eq :/ with += is expected to eq :+ with &= is expected to eq :& RuboCop::AST::IntNode #value is expected to eq 10 #sign? explicit positive int is expected to be sign explicit negative int is expected to be sign .new is expected to be a kind of RuboCop::AST::IntNode RuboCop::AST::SelfClassNode .new is expected to be a kind of RuboCop::AST::SelfClassNode #body with a single expression body is expected to be send type with a multi-expression body is expected to be begin type with an empty body is expected to be nil #identifier is expected to be self type RuboCop::AST::ForwardArgsNode when using Ruby 2.7 or newer #to_a is expected to contain exactly (be forward arg type) RuboCop::AST::DstrNode #value with a multiline string is expected to eq "this is a multiline string" with implicit concatenation is expected to eq "foo bar baz" with interpolation is expected to eq "foo \#{bar} baz" RuboCop::AST::OrAsgnNode .new is expected to be a kind of RuboCop::AST::OrAsgnNode #expression is expected to eq s(:send, nil, :value) #assignment_node is expected to be a kind of RuboCop::AST::AsgnNode #operator is expected to eq :"||" #name is expected to eq :var RuboCop::AST::NextNode behaves like wrapped arguments node #arguments with no arguments and braces is expected to be empty with multiple literal arguments is expected to eq 2 with no arguments is expected to be empty with a single splat argument is expected to eq 1 with a single argument and braces is expected to eq 1 with a single argument is expected to eq 1 .new with arguments is expected to be a kind of RuboCop::AST::NextNode without arguments is expected to be a kind of RuboCop::AST::NextNode RuboCop::AST::ArgsNode #empty_and_without_delimiters? with delimiters with a lambda literal is expected to equal false with a block is expected to equal false with a method definition is expected to equal false with arguments with a lambda literal is expected to equal false with a method definition is expected to equal false with empty arguments with a lambda literal is expected to equal true with a block is expected to equal true with a method definition is expected to equal true #argument_list is expected to eq [s(:arg, :a), s(:optarg, :b, s(:int, 42)), s(:arg, :c), s(:restarg, :d), s(:kwarg, :e), s(:kwoptarg, :f, s(:int, 42)), s(:kwrestarg, :g), s(:blockarg, :h), s(:shadowarg, :i)] when using Ruby 2.7 or newer with argument forwarding is expected to eq [s(:forward_arg)] .new with a block is expected to be a kind of RuboCop::AST::ArgsNode with a method definition is expected to be a kind of RuboCop::AST::ArgsNode with a lambda literal is expected to be a kind of RuboCop::AST::ArgsNode RuboCop::AST::SymbolNode #value is expected to eq :foo .new with a symbol node is expected to be a kind of RuboCop::AST::SymbolNode RuboCop::AST::Token #end_pos returns index of last char in token range of entire source #begin_pos returns index of first char in token range of entire source .from_parser_token returns a #to_s useful for debugging sets parser token's range to rubocop token's pos sets parser token's type to rubocop token's type sets parser token's text to rubocop token's text #space_after returns truthy MatchData when there is a space after token returns nil when there is not a space after token type predicates #left_ref_bracket? returns false for non left_ref_bracket tokens returns true for left_ref_bracket tokens #dot? returns true for dot tokens returns false for non dot tokens #equals_sign? returns true for equals sign tokens returns false for non equals sign tokens #comment? returns false for non comment tokens returns true for comment tokens #end? returns true for end tokens returns false for non end tokens #new_line? returns false for non new line tokens returns true for new line tokens #right_bracket? returns true for all right_bracket tokens returns false for non right_bracket tokens with braces & parens #left_parens? returns true for left parens tokens returns false for non left parens tokens #right_curly_brace? returns true for all right brace tokens returns false for non right brace tokens #right_parens? returns false for non right parens tokens returns true for right parens tokens #left_brace? returns true for left hash brace tokens returns false for non left hash brace tokens #left_curly_brace? returns true for left block brace tokens returns false for non left block brace tokens #regexp_dots? returns true for regexp tokens returns false for non comma tokens #semicolon? returns false for non semicolon tokens returns true for semicolon tokens #left_array_bracket? returns true for left_array_bracket tokens returns false for non left_array_bracket tokens #left_brace? returns true for right_bracket tokens returns false for non right_bracket tokens #rescue_modifier? returns true for rescue modifier tokens returns false for non rescue modifier tokens #left_bracket? returns false for non left_bracket tokens returns true for all left_bracket tokens #comma? returns false for non comma tokens returns true for comma tokens #to_s returns string of token data #line returns line of token #column returns index of first char in token range on that line #space_before returns nil when it is on the first line returns nil when there is not a space before token returns truthy MatchData when there is a space before token RuboCop::AST::CaseNode #when_branches is expected to all be when type is expected to eq 3 #branches when there is an else returns all the bodies with an empty else returns all the bodies when compared to an IfNode returns the same when there is no else keyword returns only then when bodies #keyword is expected to eq "case" .new is expected to be a kind of RuboCop::AST::CaseNode #else? without an else statement is expected not to be else with an else statement is expected to be else #else_branch #else? with an else statement is expected to be sym type with an empty else statement is expected to be nil without an else statement is expected to be nil #each_when when passed a block yields all the conditions when not passed a block is expected to be a kind of Enumerator RuboCop::AST::CasgnNode #name is expected to eq :VAR #expression is expected to eq s(:send, nil, :value) .new with a `casgn` node is expected to be a kind of RuboCop::AST::CasgnNode #namespace when the parent is a `cbase` is expected to eq s(:cbase) when the parent is a `const` is expected to eq s(:const, nil, :FOO) when there is no parent is expected to be nil RuboCop::AST::ModuleNode #body with a single expression body is expected to be send type with a multi-expression body is expected to be begin type with an empty body is expected to be nil #identifier is expected to be const type .new is expected to be a kind of RuboCop::AST::ModuleNode RuboCop::AST::NodePattern::Parser sequences parses unions of literals as a set parses capture vs repetition with correct priority parses simple sequences properly expands ... in sequence head deep inside unions generates specialized nodes parses function calls Set#=== tests for inclusion RuboCop::AST::NodePattern::Lexer provides tokens via next_token when given a regexp /test/ round trips when given a regexp /back\\slash/ round trips with $type+ is parsed as `$ int + x` when given arithmetic symbols is parsed as `:&` when given node types and constants distinguishes them when given a regexp ending with a backslash does not lexes it properly when given a regexp /[abc]+\/()?/x round trips RuboCop::AST::ConstNode #module_name? is expected not to be module name with a constant with a lowercase letter is expected to be module name #each_path yields all parts of the namespace #short_name is expected to eq :BAZ #namespace is expected to eq "::Foo::Bar" #absolute? is expected to be absolute with a non-namespaced constant is expected not to be absolute with a constant not starting with :: is expected not to be absolute #relative? with a non-namespaced constant is expected to be relative RuboCop::AST::BlockNode #braces? when enclosed in do-end keywords is expected not to be braces when enclosed in braces is expected to be braces #void_context? when block method is tap is expected to be void context when block method is not each is expected not to be void context when block method is each is expected to be void context #arguments? with a single argument is expected to be arguments with multiple mixed arguments is expected to be arguments with no arguments is expected not to be arguments with a single splat argument is expected to be arguments >= Ruby 2.7 using numbered parameters is expected not to be arguments with destructuring arguments is expected to be arguments #arguments >= Ruby 2.7 using numbered parameters is expected to be empty with destructured arguments is expected to eq 2 with no arguments is expected to be empty with a single literal argument is expected to eq 1 with multiple mixed arguments is expected to eq 2 with a single splat argument is expected to eq 1 #multiline? when block is on a single line is expected not to be multiline when block is on several lines is expected to be multiline #closing_delimiter when enclosed in do-end keywords is expected to eq "end" when enclosed in braces is expected to eq "}" .new is expected to be a kind of RuboCop::AST::BlockNode #argument_list with no arguments is expected to be empty all argument types is expected to eq [:a, :b, :c, :d, :e, :f, :g, :h, :i] >= Ruby 2.7 using numbered parameters with skipped params is expected to eq [:_1, :_2, :_3, :_4, :_5, :_6, :_7] with sequential params is expected to eq [:_1, :_2] #delimiters when enclosed in do-end keywords is expected to eq ["do", "end"] when enclosed in braces is expected to eq ["{", "}"] #opening_delimiter when enclosed in braces is expected to eq "{" when enclosed in do-end keywords is expected to eq "do" #keywords? when enclosed in do-end keywords is expected to be keywords when enclosed in braces is expected not to be keywords #single_line? when block is on several lines is expected not to be single line when block is on a single line is expected to be single line #lambda? when block belongs to a method lambda is expected to be lambda when block belongs to a stabby lambda is expected to be lambda when block belongs to a non-lambda method is expected not to be lambda #receiver with dot operator call is expected to eq "foo" with safe navigation operator call is expected to eq "foo" RuboCop::AST::RuboCopCompatibility when ran from a compatible version of Rubocop issues a warning when ran from an incompatible version of Rubocop issues a warning RuboCop::AST::OrNode #inverse_operator with a semantic or node is expected to eq "and" with a logical or node is expected to eq "&&" .new with a semantic or node is expected to be a kind of RuboCop::AST::OrNode with a logical or node is expected to be a kind of RuboCop::AST::OrNode #logical_operator? with a semantic or node is expected not to be logical operator with a logical or node is expected to be logical operator #semantic_operator? with a logical or node is expected not to be semantic operator with a semantic or node is expected to be semantic operator #lhs with a logical or node is expected to be sym type with a semantic or node is expected to be sym type #rhs with a semantic or node is expected to be int type with a logical or node is expected to be int type #alternate_operator with a semantic or node is expected to eq "||" with a logical or node is expected to eq "or" #operator with a logical or node is expected to eq "||" with a semantic or node is expected to eq "or" RuboCop::AST::UntilNode #do? with a do keyword is expected to be do without a do keyword is expected not to be do #keyword is expected to eq "until" #loop_keyword? with a statement until is expected to be loop keyword with a modifier until is expected to be loop keyword #post_condition_loop? with a statement until is expected not to be post condition loop with a modifier until is expected to be post condition loop .new with a modifier until is expected to be a kind of RuboCop::AST::UntilNode with a statement until is expected to be a kind of RuboCop::AST::UntilNode #inverse_keyword is expected to eq "while" RuboCop::AST::ClassNode #parent_class when no parent class is specified is expected to be nil when a parent class is specified is expected to be const type #identifier is expected to be const type .new is expected to be a kind of RuboCop::AST::ClassNode #body with an empty body is expected to be nil with a multi-expression body is expected to be begin type with a single expression body is expected to be send type RuboCop::AST::Procarg0Node #name is expected to eq :x .new with a block is expected to be a kind of RuboCop::AST::ArgNode RuboCop::AST::NodePattern::Sets is expected not to eq "::RuboCop::AST::NodePattern::Sets::SET_1_2_3_ETC_2" is expected to eq "::RuboCop::AST::NodePattern::Sets::SET_1_2_3_ETC" is expected to eq "::RuboCop::AST::NodePattern::Sets::SET_1_2_3_ETC" creates a constant with the right value RuboCop::AST::PairNode #value_delta when using hash rocket delimiters when values are aligned when both pairs are explicit pairs is expected to eq 0 when second pair is a keyword splat is expected to eq 0 when receiver value is ahead is expected to eq 2 when receiver value is behind is expected to eq -2 when both pairs are on the same line is expected to eq 0 when using colon delimiters when receiver value is ahead is expected to eq 2 when both pairs are on the same line is expected to eq 0 when values are aligned when both pairs are explicit pairs is expected to eq 0 when second pair is a keyword splat is expected to eq 0 when receiver value is behind is expected to eq -2 #key when using a string key is expected to be str type when using a symbol key is expected to be sym type #key_delta with alignment set to :right when using hash rocket delimiters when keys are aligned when second key is a keyword splat is expected to eq 0 when both keys are explicit keys is expected to eq 0 when both keys are on the same line when both pairs are explicit pairs is expected to eq 0 when second pair is a keyword splat is expected to eq 0 when receiver key is ahead when second pair is a keyword splat is expected to eq 0 when both pairs are explicit pairs is expected to eq 2 when receiver key is behind when second pair is a keyword splat is expected to eq 0 when both pairs are explicit pairs is expected to eq -2 when using colon delimiters when receiver key is ahead when second pair is a keyword splat is expected to eq 0 when both pairs are explicit pairs is expected to eq 2 when both keys are on the same line when both pairs are explicit pairs is expected to eq 0 when second pair is a keyword splat is expected to eq 0 when keys are aligned when second pair is a keyword splat is expected to eq 0 when both pairs are explicit pairs is expected to eq 0 when receiver key is behind when both pairs are reail pairs is expected to eq -2 when second pair is a keyword splat is expected to eq 0 with alignment set to :left when using hash rocket delimiters when receiver key is behind when both pairs are explicit pairs is expected to eq -2 when second pair is a keyword splat is expected to eq -2 when keys are aligned when second key is a keyword splat is expected to eq 0 when both keys are explicit keys is expected to eq 0 when receiver key is ahead when second pair is a keyword splat is expected to eq 2 when both pairs are explicit pairs is expected to eq 2 when both keys are on the same line when second pair is a keyword splat is expected to eq 0 when both pairs are explicit pairs is expected to eq 0 when using colon delimiters when keys are aligned when both pairs are explicit pairs is expected to eq 0 when second pair is a keyword splat is expected to eq 0 when receiver key is ahead when both pairs are explicit pairs is expected to eq 2 when second pair is a keyword splat is expected to eq 2 when receiver key is behind when both pairs are reail pairs is expected to eq -2 when second pair is a keyword splat is expected to eq -2 when both keys are on the same line when second pair is a keyword splat is expected to eq 0 when both pairs are explicit pairs is expected to eq 0 #inverse_delimiter when using a hash rocket delimiter is expected to eq ":" is expected to eq ": " when using a colon delimiter is expected to eq "=>" is expected to eq " => " #value is expected to be int type #colon? when using a hash rocket delimiter is expected not to be colon when using a colon delimiter is expected to be colon #delimiter when using a colon delimiter is expected to eq ":" is expected to eq ": " when using a hash rocket delimiter is expected to eq " => " is expected to eq "=>" #value_omission? when using hash value omission is expected to be value omission when not using hash value omission is expected not to be value omission #hash_rocket? when using a colon delimiter is expected not to be hash rocket when using a hash rocket delimiter is expected to be hash rocket #same_line? when pairs are on separate lines when both pairs are explicit pairs is expected not to be same line s(:pair, s(:sym, :b), s(:int, 2)) when last pair is a keyword splat is expected not to be same line s(:kwsplat, s(:send, nil, :foo)) when a multiline pair shares the same line when last pair is a keyword splat is expected to be same line s(:kwsplat, s(:send, nil, :foo)) is expected to be same line s(:pair, s(:sym, :a), s(:begin)) when both pairs are explicit pairs is expected to be same line s(:pair, s(:sym, :b), s(:int, 2)) is expected to be same line s(:pair, s(:sym, :a), s(:begin)) when both pairs are on the same line when both pairs are explicit pairs is expected to be same line s(:pair, s(:sym, :b), s(:int, 2)) when both pair is a keyword splat is expected to be same line s(:kwsplat, s(:send, nil, :foo)) #value_on_new_line? when pair is on a single line is expected not to be value on new line when value spans multiple lines is expected not to be value on new line when value starts on a new line is expected to be value on new line .new is expected to be a kind of RuboCop::AST::PairNode RuboCop::AST::ResbodyNode #exceptions with multiple exceptions is expected to all be const type is expected to eq 2 without exception is expected to eq 0 with a single exception is expected to all be const type is expected to eq 1 #branch_index is expected to eq 2 is expected to eq 1 is expected to eq 0 #body is expected to be sym type #exception_variable when an exception variable is not given is expected to be nil for an explicit rescue is expected to eq "ex" for an implicit rescue is expected to eq "ex" .new is expected to be a kind of RuboCop::AST::ResbodyNode Finished in 3.21 seconds (files took 1.19 seconds to load) 2392 examples, 0 failures Randomized with seed 46231 ┌──────────────────────────────────────────────────────────────────────────────┐ │ dh_ruby --install finished │ └──────────────────────────────────────────────────────────────────────────────┘ dh_installdocs -O--buildsystem=ruby dh_ruby_fixdocs -O--buildsystem=ruby debian/rules override_dh_installchangelogs make[1]: Entering directory '/build/reproducible-path/ruby-rubocop-ast-1.24.0' dh_installchangelogs CHANGELOG.md make[1]: Leaving directory '/build/reproducible-path/ruby-rubocop-ast-1.24.0' dh_installsystemduser -O--buildsystem=ruby dh_perl -O--buildsystem=ruby dh_link -O--buildsystem=ruby dh_strip_nondeterminism -O--buildsystem=ruby dh_compress -X.rb -O--buildsystem=ruby dh_fixperms -O--buildsystem=ruby dh_missing -O--buildsystem=ruby dh_ruby_fixdepends -O--buildsystem=ruby dh_installdeb -O--buildsystem=ruby dh_gencontrol -O--buildsystem=ruby dpkg-gencontrol: warning: Depends field of package ruby-rubocop-ast: substitution variable ${shlibs:Depends} used, but is not defined dpkg-gencontrol: warning: package ruby-rubocop-ast: substitution variable ${ruby:Versions} used, but is not defined dh_md5sums -O--buildsystem=ruby dh_builddeb -O--buildsystem=ruby dpkg-deb: building package 'ruby-rubocop-ast' in '../ruby-rubocop-ast_1.24.0-2_all.deb'. dpkg-genbuildinfo --build=binary -O../ruby-rubocop-ast_1.24.0-2_arm64.buildinfo dpkg-genchanges --build=binary -O../ruby-rubocop-ast_1.24.0-2_arm64.changes dpkg-genchanges: info: binary-only upload (no source code included) dpkg-source --after-build . dpkg-buildpackage: info: binary-only upload (no source included) dpkg-genchanges: info: not including original source code in upload I: copying local configuration I: unmounting dev/ptmx filesystem I: unmounting dev/pts filesystem I: unmounting dev/shm filesystem I: unmounting proc filesystem I: unmounting sys filesystem I: cleaning the build env I: removing directory /srv/workspace/pbuilder/2893848 and its subdirectories I: Current time: Fri May 29 13:18:44 -12 2026 I: pbuilder-time-stamp: 1780103924 Sat Apr 26 18:55:46 UTC 2025 I: 1st build successful. Starting 2nd build on remote node codethink04-arm64.debian.net. Sat Apr 26 18:55:46 UTC 2025 I: Preparing to do remote build '2' on codethink04-arm64.debian.net. Sat Apr 26 18:55:46 UTC 2025 - checking /var/lib/jenkins/offline_nodes if codethink04-arm64.debian.net is marked as down. Sat Apr 26 18:55:46 UTC 2025 - checking via ssh if codethink04-arm64.debian.net is up. removed '/tmp/read-only-fs-test-vQx34p' ==================================================================================== Sat Apr 26 18:55:47 UTC 2025 - running /srv/jenkins/bin/reproducible_build.sh (for job /srv/jenkins/bin/reproducible_build.sh) on codethink04-arm64, called using "2 ruby-rubocop-ast unstable /srv/reproducible-results/rbuild-debian/r-b-build.XpjqCx9r 1.24.0-2" as arguments. Sat Apr 26 18:55:47 UTC 2025 - actually running "reproducible_build.sh" (md5sum 68e686e434c9ab7bc3ec047d8b309cbc) as "/tmp/jenkins-script-ZtowLMUS" $ git clone https://salsa.debian.org/qa/jenkins.debian.net.git ; more CONTRIBUTING Sat Apr 26 18:55:47 UTC 2025 I: Downloading source for unstable/ruby-rubocop-ast=1.24.0-2 Reading package lists... NOTICE: 'ruby-rubocop-ast' packaging is maintained in the 'Git' version control system at: https://salsa.debian.org/ruby-team/ruby-rubocop-ast.git Please use: git clone https://salsa.debian.org/ruby-team/ruby-rubocop-ast.git to retrieve the latest (possibly unreleased) updates to the package. Need to get 134 kB of source archives. Get:1 http://deb.debian.org/debian unstable/main ruby-rubocop-ast 1.24.0-2 (dsc) [2224 B] Get:2 http://deb.debian.org/debian unstable/main ruby-rubocop-ast 1.24.0-2 (tar) [128 kB] Get:3 http://deb.debian.org/debian unstable/main ruby-rubocop-ast 1.24.0-2 (diff) [3600 B] Fetched 134 kB in 0s (7592 kB/s) Download complete and in download only mode Reading package lists... NOTICE: 'ruby-rubocop-ast' packaging is maintained in the 'Git' version control system at: https://salsa.debian.org/ruby-team/ruby-rubocop-ast.git Please use: git clone https://salsa.debian.org/ruby-team/ruby-rubocop-ast.git to retrieve the latest (possibly unreleased) updates to the package. Need to get 134 kB of source archives. Get:1 http://deb.debian.org/debian unstable/main ruby-rubocop-ast 1.24.0-2 (dsc) [2224 B] Get:2 http://deb.debian.org/debian unstable/main ruby-rubocop-ast 1.24.0-2 (tar) [128 kB] Get:3 http://deb.debian.org/debian unstable/main ruby-rubocop-ast 1.24.0-2 (diff) [3600 B] Fetched 134 kB in 0s (7592 kB/s) Download complete and in download only mode ============================================================================= Re-Building ruby-rubocop-ast in unstable on arm64 on codethink04-arm64 now. Date: Sat Apr 26 19:55:48 BST 2025 Date UTC: Sat Apr 26 18:55:48 UTC 2025 ============================================================================= ++ mktemp -t pbuilderrc_XXXX --tmpdir=/srv/reproducible-results/rbuild-debian/r-b-build.XpjqCx9r + local TMPCFG=/srv/reproducible-results/rbuild-debian/r-b-build.XpjqCx9r/pbuilderrc_Pgl6 + case ${ARCH} in + case $ARCH in + locale=nl_BE + language=nl + case "${SUITE}" in + reproducible_buildflags=+all + extra_deb_build_options= + case "${SRCPACKAGE}" in + cat + echo BUILDDIR=/build/reproducible-path + '[' ruby-rubocop-ast = debian-installer -o ruby-rubocop-ast = debian-installer-netboot-images ']' + pbuilder_options=() + local pbuilder_options + DEBBUILDOPTS=-b + BINARYTARGET= + '[' ruby-rubocop-ast = u-boot ']' + case "${SRCPACKAGE}" in + PBUILDERTIMEOUT=24 + local PRESULT=0 + sudo timeout -k 24.1h 24h /usr/bin/ionice -c 3 /usr/bin/nice -n 11 /usr/bin/unshare --uts -- /usr/sbin/pbuilder --build --configfile /srv/reproducible-results/rbuild-debian/r-b-build.XpjqCx9r/pbuilderrc_Pgl6 --distribution unstable --hookdir /etc/pbuilder/rebuild-hooks --debbuildopts -b --basetgz /var/cache/pbuilder/unstable-reproducible-base.tgz --buildresult /srv/reproducible-results/rbuild-debian/r-b-build.XpjqCx9r/b2 --logfile b2/build.log ruby-rubocop-ast_1.24.0-2.dsc W: /root/.pbuilderrc does not exist I: Logging to b2/build.log I: pbuilder: network access will be disabled during build I: Current time: Sun Apr 27 08:55:48 +14 2025 I: pbuilder-time-stamp: 1745693748 I: Building the build Environment I: extracting base tarball [/var/cache/pbuilder/unstable-reproducible-base.tgz] I: copying local configuration W: --override-config is not set; not updating apt.conf Read the manpage for details. I: mounting /proc filesystem I: mounting /sys filesystem I: creating /{dev,run}/shm I: mounting /dev/pts filesystem I: redirecting /dev/ptmx to /dev/pts/ptmx I: policy-rc.d already exists I: Copying source file I: copying [ruby-rubocop-ast_1.24.0-2.dsc] I: copying [./ruby-rubocop-ast_1.24.0.orig.tar.gz] I: copying [./ruby-rubocop-ast_1.24.0-2.debian.tar.xz] I: Extracting source dpkg-source: warning: cannot verify inline signature for ./ruby-rubocop-ast_1.24.0-2.dsc: unsupported subcommand dpkg-source: info: extracting ruby-rubocop-ast in ruby-rubocop-ast-1.24.0 dpkg-source: info: unpacking ruby-rubocop-ast_1.24.0.orig.tar.gz dpkg-source: info: unpacking ruby-rubocop-ast_1.24.0-2.debian.tar.xz dpkg-source: info: using patch list from debian/patches/series dpkg-source: info: applying 0001-gemspec-drop-git-usage.patch dpkg-source: info: applying 0002-Fix-compile-task.patch I: Not using root during the build. I: Installing the build-deps I: user script /srv/workspace/pbuilder/433812/tmp/hooks/D01_modify_environment starting debug: Running on codethink04-arm64. I: Changing host+domainname to test build reproducibility I: Adding a custom variable just for the fun of it... I: Changing /bin/sh to bash '/bin/sh' -> '/bin/bash' lrwxrwxrwx 1 root root 9 Apr 26 18:55 /bin/sh -> /bin/bash I: Setting pbuilder2's login shell to /bin/bash I: Setting pbuilder2's GECOS to second user,second room,second work-phone,second home-phone,second other I: user script /srv/workspace/pbuilder/433812/tmp/hooks/D01_modify_environment finished I: user script /srv/workspace/pbuilder/433812/tmp/hooks/D02_print_environment starting I: set BASH=/bin/sh BASHOPTS=checkwinsize:cmdhist:complete_fullquote:extquote:force_fignore:globasciiranges:globskipdots:hostcomplete:interactive_comments:patsub_replacement:progcomp:promptvars:sourcepath BASH_ALIASES=() BASH_ARGC=() BASH_ARGV=() BASH_CMDS=() BASH_LINENO=([0]="12" [1]="0") BASH_LOADABLES_PATH=/usr/local/lib/bash:/usr/lib/bash:/opt/local/lib/bash:/usr/pkg/lib/bash:/opt/pkg/lib/bash:. BASH_SOURCE=([0]="/tmp/hooks/D02_print_environment" [1]="/tmp/hooks/D02_print_environment") BASH_VERSINFO=([0]="5" [1]="2" [2]="37" [3]="1" [4]="release" [5]="aarch64-unknown-linux-gnu") BASH_VERSION='5.2.37(1)-release' BUILDDIR=/build/reproducible-path BUILDUSERGECOS='second user,second room,second work-phone,second home-phone,second other' BUILDUSERNAME=pbuilder2 BUILD_ARCH=arm64 DEBIAN_FRONTEND=noninteractive DEB_BUILD_OPTIONS='buildinfo=+all reproducible=+all parallel=12 ' DIRSTACK=() DISTRIBUTION=unstable EUID=0 FUNCNAME=([0]="Echo" [1]="main") GROUPS=() HOME=/root HOSTNAME=i-capture-the-hostname HOSTTYPE=aarch64 HOST_ARCH=arm64 IFS=' ' INVOCATION_ID=0928debd5c3c471fb97bdedfb6a3449a LANG=C LANGUAGE=nl_BE:nl LC_ALL=C MACHTYPE=aarch64-unknown-linux-gnu MAIL=/var/mail/root OPTERR=1 OPTIND=1 OSTYPE=linux-gnu PATH=/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/i/capture/the/path PBCURRENTCOMMANDLINEOPERATION=build PBUILDER_OPERATION=build PBUILDER_PKGDATADIR=/usr/share/pbuilder PBUILDER_PKGLIBDIR=/usr/lib/pbuilder PBUILDER_SYSCONFDIR=/etc PIPESTATUS=([0]="0") POSIXLY_CORRECT=y PPID=433812 PS4='+ ' PWD=/ SHELL=/bin/bash SHELLOPTS=braceexpand:errexit:hashall:interactive-comments:posix SHLVL=3 SUDO_COMMAND='/usr/bin/timeout -k 24.1h 24h /usr/bin/ionice -c 3 /usr/bin/nice -n 11 /usr/bin/unshare --uts -- /usr/sbin/pbuilder --build --configfile /srv/reproducible-results/rbuild-debian/r-b-build.XpjqCx9r/pbuilderrc_Pgl6 --distribution unstable --hookdir /etc/pbuilder/rebuild-hooks --debbuildopts -b --basetgz /var/cache/pbuilder/unstable-reproducible-base.tgz --buildresult /srv/reproducible-results/rbuild-debian/r-b-build.XpjqCx9r/b2 --logfile b2/build.log ruby-rubocop-ast_1.24.0-2.dsc' SUDO_GID=109 SUDO_UID=104 SUDO_USER=jenkins TERM=unknown TZ=/usr/share/zoneinfo/Etc/GMT-14 UID=0 USER=root _='I: set' http_proxy=http://192.168.101.4:3128 I: uname -a Linux i-capture-the-hostname 6.1.0-33-cloud-arm64 #1 SMP Debian 6.1.133-1 (2025-04-10) aarch64 GNU/Linux I: ls -l /bin lrwxrwxrwx 1 root root 7 Mar 4 11:20 /bin -> usr/bin I: user script /srv/workspace/pbuilder/433812/tmp/hooks/D02_print_environment finished -> Attempting to satisfy build-dependencies -> Creating pbuilder-satisfydepends-dummy package Package: pbuilder-satisfydepends-dummy Version: 0.invalid.0 Architecture: arm64 Maintainer: Debian Pbuilder Team Description: Dummy package to satisfy dependencies with aptitude - created by pbuilder This package was created automatically by pbuilder to satisfy the build-dependencies of the package being currently built. Depends: debhelper-compat (= 13), gem2deb (>= 1), racc, rake, ruby-oedipus-lex, ruby-rspec, ruby-whitequark-parser (>= 3.1.1.0) dpkg-deb: building package 'pbuilder-satisfydepends-dummy' in '/tmp/satisfydepends-aptitude/pbuilder-satisfydepends-dummy.deb'. Selecting previously unselected package pbuilder-satisfydepends-dummy. (Reading database ... 19953 files and directories currently installed.) Preparing to unpack .../pbuilder-satisfydepends-dummy.deb ... Unpacking pbuilder-satisfydepends-dummy (0.invalid.0) ... dpkg: pbuilder-satisfydepends-dummy: dependency problems, but configuring anyway as you requested: pbuilder-satisfydepends-dummy depends on debhelper-compat (= 13); however: Package debhelper-compat is not installed. pbuilder-satisfydepends-dummy depends on gem2deb (>= 1); however: Package gem2deb is not installed. pbuilder-satisfydepends-dummy depends on racc; however: Package racc is not installed. pbuilder-satisfydepends-dummy depends on rake; however: Package rake is not installed. pbuilder-satisfydepends-dummy depends on ruby-oedipus-lex; however: Package ruby-oedipus-lex is not installed. pbuilder-satisfydepends-dummy depends on ruby-rspec; however: Package ruby-rspec is not installed. pbuilder-satisfydepends-dummy depends on ruby-whitequark-parser (>= 3.1.1.0); however: Package ruby-whitequark-parser is not installed. Setting up pbuilder-satisfydepends-dummy (0.invalid.0) ... Reading package lists... Building dependency tree... Reading state information... Initializing package states... Writing extended state information... Building tag database... pbuilder-satisfydepends-dummy is already installed at the requested version (0.invalid.0) pbuilder-satisfydepends-dummy is already installed at the requested version (0.invalid.0) The following NEW packages will be installed: autoconf{a} automake{a} autopoint{a} autotools-dev{a} bsdextrautils{a} ca-certificates{a} debhelper{a} devscripts{a} dh-autoreconf{a} dh-strip-nondeterminism{a} dwz{a} file{a} gem2deb{a} gem2deb-test-runner{a} gettext{a} gettext-base{a} gpg{a} gpg-agent{a} gpgconf{a} gpgv{a} groff-base{a} intltool-debian{a} libarchive-zip-perl{a} libassuan9{a} libb-hooks-op-check-perl{a} libclass-method-modifiers-perl{a} libclass-xsaccessor-perl{a} libclone-perl{a} libdebhelper-perl{a} libdevel-callchecker-perl{a} libdynaloader-functions-perl{a} libelf1t64{a} libencode-locale-perl{a} libexpat1{a} libffi8{a} libfile-dirlist-perl{a} libfile-homedir-perl{a} libfile-listing-perl{a} libfile-stripnondeterminism-perl{a} libfile-touch-perl{a} libfile-which-perl{a} libgcrypt20{a} libgmp-dev{a} libgmpxx4ldbl{a} libgpg-error0{a} libhtml-parser-perl{a} libhtml-tagset-perl{a} libhtml-tree-perl{a} libhttp-cookies-perl{a} libhttp-date-perl{a} libhttp-message-perl{a} libhttp-negotiate-perl{a} libimport-into-perl{a} libio-html-perl{a} libio-socket-ssl-perl{a} libksba8{a} liblwp-mediatypes-perl{a} liblwp-protocol-https-perl{a} libmagic-mgc{a} libmagic1t64{a} libmodule-runtime-perl{a} libmoo-perl{a} libnet-http-perl{a} libnet-ssleay-perl{a} libnpth0t64{a} libparams-classify-perl{a} libpipeline1{a} libpython3-stdlib{a} libpython3.13-minimal{a} libpython3.13-stdlib{a} libreadline8t64{a} librole-tiny-perl{a} libruby{a} libruby3.3{a} libsub-quote-perl{a} libtimedate-perl{a} libtool{a} libtry-tiny-perl{a} libuchardet0{a} libunistring5{a} liburi-perl{a} libwww-perl{a} libwww-robotrules-perl{a} libxml2{a} libyaml-0-2{a} m4{a} man-db{a} media-types{a} netbase{a} openssl{a} patchutils{a} perl-openssl-defaults{a} pinentry-curses{a} po-debconf{a} python3{a} python3-minimal{a} python3.13{a} python3.13-minimal{a} racc{a} rake{a} readline-common{a} ruby{a} ruby-all-dev{a} ruby-ast{a} ruby-csv{a} ruby-did-you-mean{a} ruby-diff-lcs{a} ruby-minitest{a} ruby-net-telnet{a} ruby-oedipus-lex{a} ruby-power-assert{a} ruby-rspec{a} ruby-rspec-core{a} ruby-rspec-expectations{a} ruby-rspec-mocks{a} ruby-rspec-support{a} ruby-ruby2-keywords{a} ruby-rubygems{a} ruby-test-unit{a} ruby-webrick{a} ruby-whitequark-parser{a} ruby-xmlrpc{a} ruby3.3{a} ruby3.3-dev{a} rubygems-integration{a} sensible-utils{a} sopv-gpgv{a} tzdata{a} wdiff{a} The following packages are RECOMMENDED but will NOT be installed: apt-file curl dctrl-tools debian-keyring dput dput-ng dupload equivs fonts-lato gnupg libarchive-cpio-perl libdata-dump-perl libdistro-info-perl libgit-wrapper-perl libgitlab-api-v4-perl libgpg-error-l10n libhtml-form-perl libhtml-format-perl libhttp-daemon-perl libio-compress-brotli-perl libjs-jquery libjson-perl liblist-compare-perl libltdl-dev libmail-sendmail-perl libmailtools-perl libnamespace-clean-perl libsoap-lite-perl libstring-shellquote-perl libxstring-perl licensecheck lintian lynx lzip pristine-tar python3-apt python3-argcomplete python3-debian python3-magic python3-requests python3-unidiff python3-xdg ruby-sdbm ruby3.3-doc sopv-doc strace unzip wget zip 0 packages upgraded, 129 newly installed, 0 to remove and 0 not upgraded. Need to get 35.0 MB of archives. After unpacking 148 MB will be used. Writing extended state information... Get: 1 http://deb.debian.org/debian unstable/main arm64 libpython3.13-minimal arm64 3.13.3-2 [855 kB] Get: 2 http://deb.debian.org/debian unstable/main arm64 libexpat1 arm64 2.7.1-1 [93.3 kB] Get: 3 http://deb.debian.org/debian unstable/main arm64 python3.13-minimal arm64 3.13.3-2 [1998 kB] Get: 4 http://deb.debian.org/debian unstable/main arm64 python3-minimal arm64 3.13.3-1 [27.2 kB] Get: 5 http://deb.debian.org/debian unstable/main arm64 media-types all 13.0.0 [29.3 kB] Get: 6 http://deb.debian.org/debian unstable/main arm64 netbase all 6.5 [12.4 kB] Get: 7 http://deb.debian.org/debian unstable/main arm64 tzdata all 2025b-2 [260 kB] Get: 8 http://deb.debian.org/debian unstable/main arm64 libffi8 arm64 3.4.8-2 [21.3 kB] Get: 9 http://deb.debian.org/debian unstable/main arm64 readline-common all 8.2-6 [69.4 kB] Get: 10 http://deb.debian.org/debian unstable/main arm64 libreadline8t64 arm64 8.2-6 [159 kB] Get: 11 http://deb.debian.org/debian unstable/main arm64 libpython3.13-stdlib arm64 3.13.3-2 [1890 kB] Get: 12 http://deb.debian.org/debian unstable/main arm64 python3.13 arm64 3.13.3-2 [751 kB] Get: 13 http://deb.debian.org/debian unstable/main arm64 libpython3-stdlib arm64 3.13.3-1 [10.2 kB] Get: 14 http://deb.debian.org/debian unstable/main arm64 python3 arm64 3.13.3-1 [28.2 kB] Get: 15 http://deb.debian.org/debian unstable/main arm64 sensible-utils all 0.0.25 [25.0 kB] Get: 16 http://deb.debian.org/debian unstable/main arm64 openssl arm64 3.5.0-1 [1454 kB] Get: 17 http://deb.debian.org/debian unstable/main arm64 ca-certificates all 20250419 [162 kB] Get: 18 http://deb.debian.org/debian unstable/main arm64 libmagic-mgc arm64 1:5.46-5 [338 kB] Get: 19 http://deb.debian.org/debian unstable/main arm64 libmagic1t64 arm64 1:5.46-5 [103 kB] Get: 20 http://deb.debian.org/debian unstable/main arm64 file arm64 1:5.46-5 [43.7 kB] Get: 21 http://deb.debian.org/debian unstable/main arm64 gettext-base arm64 0.23.1-1 [241 kB] Get: 22 http://deb.debian.org/debian unstable/main arm64 libuchardet0 arm64 0.0.8-1+b2 [69.2 kB] Get: 23 http://deb.debian.org/debian unstable/main arm64 groff-base arm64 1.23.0-7 [1129 kB] Get: 24 http://deb.debian.org/debian unstable/main arm64 bsdextrautils arm64 2.41-4 [93.9 kB] Get: 25 http://deb.debian.org/debian unstable/main arm64 libpipeline1 arm64 1.5.8-1 [40.2 kB] Get: 26 http://deb.debian.org/debian unstable/main arm64 man-db arm64 2.13.0-1 [1404 kB] Get: 27 http://deb.debian.org/debian unstable/main arm64 m4 arm64 1.4.19-8 [285 kB] Get: 28 http://deb.debian.org/debian unstable/main arm64 autoconf all 2.72-3.1 [494 kB] Get: 29 http://deb.debian.org/debian unstable/main arm64 autotools-dev all 20240727.1 [60.2 kB] Get: 30 http://deb.debian.org/debian unstable/main arm64 automake all 1:1.17-4 [862 kB] Get: 31 http://deb.debian.org/debian unstable/main arm64 autopoint all 0.23.1-1 [770 kB] Get: 32 http://deb.debian.org/debian unstable/main arm64 libdebhelper-perl all 13.24.2 [90.9 kB] Get: 33 http://deb.debian.org/debian unstable/main arm64 libtool all 2.5.4-4 [539 kB] Get: 34 http://deb.debian.org/debian unstable/main arm64 dh-autoreconf all 20 [17.1 kB] Get: 35 http://deb.debian.org/debian unstable/main arm64 libarchive-zip-perl all 1.68-1 [104 kB] Get: 36 http://deb.debian.org/debian unstable/main arm64 libfile-stripnondeterminism-perl all 1.14.1-2 [19.7 kB] Get: 37 http://deb.debian.org/debian unstable/main arm64 dh-strip-nondeterminism all 1.14.1-2 [8620 B] Get: 38 http://deb.debian.org/debian unstable/main arm64 libelf1t64 arm64 0.192-4 [189 kB] Get: 39 http://deb.debian.org/debian unstable/main arm64 dwz arm64 0.15-1+b1 [102 kB] Get: 40 http://deb.debian.org/debian unstable/main arm64 libunistring5 arm64 1.3-2 [453 kB] Get: 41 http://deb.debian.org/debian unstable/main arm64 libxml2 arm64 2.12.7+dfsg+really2.9.14-0.4 [629 kB] Get: 42 http://deb.debian.org/debian unstable/main arm64 gettext arm64 0.23.1-1 [1610 kB] Get: 43 http://deb.debian.org/debian unstable/main arm64 intltool-debian all 0.35.0+20060710.6 [22.9 kB] Get: 44 http://deb.debian.org/debian unstable/main arm64 po-debconf all 1.0.21+nmu1 [248 kB] Get: 45 http://deb.debian.org/debian unstable/main arm64 debhelper all 13.24.2 [919 kB] Get: 46 http://deb.debian.org/debian unstable/main arm64 libgpg-error0 arm64 1.51-4 [78.5 kB] Get: 47 http://deb.debian.org/debian unstable/main arm64 libassuan9 arm64 3.0.2-2 [59.1 kB] Get: 48 http://deb.debian.org/debian unstable/main arm64 libgcrypt20 arm64 1.11.0-7 [742 kB] Get: 49 http://deb.debian.org/debian unstable/main arm64 gpgconf arm64 2.4.7-15 [121 kB] Get: 50 http://deb.debian.org/debian unstable/main arm64 libksba8 arm64 1.6.7-2+b1 [125 kB] Get: 51 http://deb.debian.org/debian unstable/main arm64 libnpth0t64 arm64 1.8-3 [22.9 kB] Get: 52 http://deb.debian.org/debian unstable/main arm64 gpg arm64 2.4.7-15 [577 kB] Get: 53 http://deb.debian.org/debian unstable/main arm64 pinentry-curses arm64 1.3.1-2 [83.5 kB] Get: 54 http://deb.debian.org/debian unstable/main arm64 gpg-agent arm64 2.4.7-15 [248 kB] Get: 55 http://deb.debian.org/debian unstable/main arm64 libfile-dirlist-perl all 0.05-3 [7600 B] Get: 56 http://deb.debian.org/debian unstable/main arm64 libfile-which-perl all 1.27-2 [15.1 kB] Get: 57 http://deb.debian.org/debian unstable/main arm64 libfile-homedir-perl all 1.006-2 [42.4 kB] Get: 58 http://deb.debian.org/debian unstable/main arm64 libfile-touch-perl all 0.12-2 [8816 B] Get: 59 http://deb.debian.org/debian unstable/main arm64 libclass-method-modifiers-perl all 2.15-1 [18.0 kB] Get: 60 http://deb.debian.org/debian unstable/main arm64 libclass-xsaccessor-perl arm64 1.19-4+b5 [34.9 kB] Get: 61 http://deb.debian.org/debian unstable/main arm64 libb-hooks-op-check-perl arm64 0.22-3+b2 [10.6 kB] Get: 62 http://deb.debian.org/debian unstable/main arm64 libdynaloader-functions-perl all 0.004-2 [12.2 kB] Get: 63 http://deb.debian.org/debian unstable/main arm64 libdevel-callchecker-perl arm64 0.009-2 [15.7 kB] Get: 64 http://deb.debian.org/debian unstable/main arm64 libparams-classify-perl arm64 0.015-2+b4 [22.3 kB] Get: 65 http://deb.debian.org/debian unstable/main arm64 libmodule-runtime-perl all 0.018-1 [17.8 kB] Get: 66 http://deb.debian.org/debian unstable/main arm64 libimport-into-perl all 1.002005-2 [11.3 kB] Get: 67 http://deb.debian.org/debian unstable/main arm64 librole-tiny-perl all 2.002004-1 [21.4 kB] Get: 68 http://deb.debian.org/debian unstable/main arm64 libsub-quote-perl all 2.006008-1 [21.8 kB] Get: 69 http://deb.debian.org/debian unstable/main arm64 libmoo-perl all 2.005005-1 [58.0 kB] Get: 70 http://deb.debian.org/debian unstable/main arm64 libencode-locale-perl all 1.05-3 [12.9 kB] Get: 71 http://deb.debian.org/debian unstable/main arm64 libtimedate-perl all 2.3300-2 [39.3 kB] Get: 72 http://deb.debian.org/debian unstable/main arm64 libhttp-date-perl all 6.06-1 [10.7 kB] Get: 73 http://deb.debian.org/debian unstable/main arm64 libfile-listing-perl all 6.16-1 [12.4 kB] Get: 74 http://deb.debian.org/debian unstable/main arm64 libhtml-tagset-perl all 3.24-1 [14.7 kB] Get: 75 http://deb.debian.org/debian unstable/main arm64 liburi-perl all 5.30-1 [105 kB] Get: 76 http://deb.debian.org/debian unstable/main arm64 libhtml-parser-perl arm64 3.83-1+b2 [97.5 kB] Get: 77 http://deb.debian.org/debian unstable/main arm64 libhtml-tree-perl all 5.07-3 [211 kB] Get: 78 http://deb.debian.org/debian unstable/main arm64 libclone-perl arm64 0.47-1+b1 [13.7 kB] Get: 79 http://deb.debian.org/debian unstable/main arm64 libio-html-perl all 1.004-3 [16.2 kB] Get: 80 http://deb.debian.org/debian unstable/main arm64 liblwp-mediatypes-perl all 6.04-2 [20.2 kB] Get: 81 http://deb.debian.org/debian unstable/main arm64 libhttp-message-perl all 7.00-2 [79.8 kB] Get: 82 http://deb.debian.org/debian unstable/main arm64 libhttp-cookies-perl all 6.11-1 [19.1 kB] Get: 83 http://deb.debian.org/debian unstable/main arm64 libhttp-negotiate-perl all 6.01-2 [13.1 kB] Get: 84 http://deb.debian.org/debian unstable/main arm64 perl-openssl-defaults arm64 7+b2 [6712 B] Get: 85 http://deb.debian.org/debian unstable/main arm64 libnet-ssleay-perl arm64 1.94-3 [323 kB] Get: 86 http://deb.debian.org/debian unstable/main arm64 libio-socket-ssl-perl all 2.089-1 [223 kB] Get: 87 http://deb.debian.org/debian unstable/main arm64 libnet-http-perl all 6.23-1 [23.9 kB] Get: 88 http://deb.debian.org/debian unstable/main arm64 liblwp-protocol-https-perl all 6.14-1 [10.8 kB] Get: 89 http://deb.debian.org/debian unstable/main arm64 libtry-tiny-perl all 0.32-1 [22.9 kB] Get: 90 http://deb.debian.org/debian unstable/main arm64 libwww-robotrules-perl all 6.02-1 [12.9 kB] Get: 91 http://deb.debian.org/debian unstable/main arm64 libwww-perl all 6.78-1 [183 kB] Get: 92 http://deb.debian.org/debian unstable/main arm64 patchutils arm64 0.4.2-1+b1 [71.3 kB] Get: 93 http://deb.debian.org/debian unstable/main arm64 gpgv arm64 2.4.7-15 [219 kB] Get: 94 http://deb.debian.org/debian unstable/main arm64 sopv-gpgv all 0.1.4-1 [11.3 kB] Get: 95 http://deb.debian.org/debian unstable/main arm64 wdiff arm64 1.2.2-9 [122 kB] Get: 96 http://deb.debian.org/debian unstable/main arm64 devscripts all 2.25.10 [1062 kB] Get: 97 http://deb.debian.org/debian unstable/main arm64 rubygems-integration all 1.19 [5488 B] Get: 98 http://deb.debian.org/debian unstable/main arm64 ruby-csv all 3.3.4-1 [42.2 kB] Get: 99 http://deb.debian.org/debian unstable/main arm64 ruby-did-you-mean all 1.6.3-2 [20.9 kB] Get: 100 http://deb.debian.org/debian unstable/main arm64 ruby-minitest all 5.25.4-2 [66.2 kB] Get: 101 http://deb.debian.org/debian unstable/main arm64 ruby-net-telnet all 0.2.0-1 [13.1 kB] Get: 102 http://deb.debian.org/debian unstable/main arm64 ruby-ruby2-keywords all 0.0.5-1 [4300 B] Get: 103 http://deb.debian.org/debian unstable/main arm64 ruby-power-assert all 2.0.3-1 [11.8 kB] Get: 104 http://deb.debian.org/debian unstable/main arm64 ruby-test-unit all 3.6.2-1 [79.1 kB] Get: 105 http://deb.debian.org/debian unstable/main arm64 ruby-webrick all 1.9.1-1 [59.6 kB] Get: 106 http://deb.debian.org/debian unstable/main arm64 ruby-xmlrpc all 0.3.3-2 [24.4 kB] Get: 107 http://deb.debian.org/debian unstable/main arm64 libyaml-0-2 arm64 0.2.5-2 [49.2 kB] Get: 108 http://deb.debian.org/debian unstable/main arm64 libruby3.3 arm64 3.3.8-1 [6140 kB] Get: 109 http://deb.debian.org/debian unstable/main arm64 ruby3.3 arm64 3.3.8-1 [834 kB] Get: 110 http://deb.debian.org/debian unstable/main arm64 libruby arm64 1:3.3+b1 [5436 B] Get: 111 http://deb.debian.org/debian unstable/main arm64 ruby-rubygems all 3.6.7-2 [407 kB] Get: 112 http://deb.debian.org/debian unstable/main arm64 ruby arm64 1:3.3+b1 [6560 B] Get: 113 http://deb.debian.org/debian unstable/main arm64 rake all 13.2.1-1 [65.2 kB] Get: 114 http://deb.debian.org/debian unstable/main arm64 gem2deb-test-runner arm64 2.2.5 [17.9 kB] Get: 115 http://deb.debian.org/debian unstable/main arm64 libgmpxx4ldbl arm64 2:6.3.0+dfsg-3 [329 kB] Get: 116 http://deb.debian.org/debian unstable/main arm64 libgmp-dev arm64 2:6.3.0+dfsg-3 [621 kB] Get: 117 http://deb.debian.org/debian unstable/main arm64 ruby3.3-dev arm64 3.3.8-1 [1045 kB] Get: 118 http://deb.debian.org/debian unstable/main arm64 ruby-all-dev arm64 1:3.3+b1 [6496 B] Get: 119 http://deb.debian.org/debian unstable/main arm64 gem2deb arm64 2.2.5 [48.0 kB] Get: 120 http://deb.debian.org/debian unstable/main arm64 racc all 1.8.1-1 [75.4 kB] Get: 121 http://deb.debian.org/debian unstable/main arm64 ruby-ast all 2.4.3-1 [10.7 kB] Get: 122 http://deb.debian.org/debian unstable/main arm64 ruby-diff-lcs all 1.5.1-1 [28.1 kB] Get: 123 http://deb.debian.org/debian unstable/main arm64 ruby-oedipus-lex all 2.6.0-2 [19.1 kB] Get: 124 http://deb.debian.org/debian unstable/main arm64 ruby-rspec-support all 3.13.0c0e0m0s1-2 [28.5 kB] Get: 125 http://deb.debian.org/debian unstable/main arm64 ruby-rspec-core all 3.13.0c0e0m0s1-2 [164 kB] Get: 126 http://deb.debian.org/debian unstable/main arm64 ruby-rspec-expectations all 3.13.0c0e0m0s1-2 [90.2 kB] Get: 127 http://deb.debian.org/debian unstable/main arm64 ruby-rspec-mocks all 3.13.0c0e0m0s1-2 [81.3 kB] Get: 128 http://deb.debian.org/debian unstable/main arm64 ruby-rspec all 3.13.0c0e0m0s1-2 [5184 B] Get: 129 http://deb.debian.org/debian unstable/main arm64 ruby-whitequark-parser all 3.3.4.2-2 [507 kB] Fetched 35.0 MB in 0s (154 MB/s) Preconfiguring packages ... Selecting previously unselected package libpython3.13-minimal:arm64. (Reading database ... (Reading database ... 5% (Reading database ... 10% (Reading database ... 15% (Reading database ... 20% (Reading database ... 25% (Reading database ... 30% (Reading database ... 35% (Reading database ... 40% (Reading database ... 45% (Reading database ... 50% (Reading database ... 55% (Reading database ... 60% (Reading database ... 65% (Reading database ... 70% (Reading database ... 75% (Reading database ... 80% (Reading database ... 85% (Reading database ... 90% (Reading database ... 95% (Reading database ... 100% (Reading database ... 19953 files and directories currently installed.) Preparing to unpack .../libpython3.13-minimal_3.13.3-2_arm64.deb ... Unpacking libpython3.13-minimal:arm64 (3.13.3-2) ... Selecting previously unselected package libexpat1:arm64. Preparing to unpack .../libexpat1_2.7.1-1_arm64.deb ... Unpacking libexpat1:arm64 (2.7.1-1) ... Selecting previously unselected package python3.13-minimal. Preparing to unpack .../python3.13-minimal_3.13.3-2_arm64.deb ... Unpacking python3.13-minimal (3.13.3-2) ... Setting up libpython3.13-minimal:arm64 (3.13.3-2) ... Setting up libexpat1:arm64 (2.7.1-1) ... Setting up python3.13-minimal (3.13.3-2) ... Selecting previously unselected package python3-minimal. (Reading database ... (Reading database ... 5% (Reading database ... 10% (Reading database ... 15% (Reading database ... 20% (Reading database ... 25% (Reading database ... 30% (Reading database ... 35% (Reading database ... 40% (Reading database ... 45% (Reading database ... 50% (Reading database ... 55% (Reading database ... 60% (Reading database ... 65% (Reading database ... 70% (Reading database ... 75% (Reading database ... 80% (Reading database ... 85% (Reading database ... 90% (Reading database ... 95% (Reading database ... 100% (Reading database ... 20287 files and directories currently installed.) Preparing to unpack .../0-python3-minimal_3.13.3-1_arm64.deb ... Unpacking python3-minimal (3.13.3-1) ... Selecting previously unselected package media-types. Preparing to unpack .../1-media-types_13.0.0_all.deb ... Unpacking media-types (13.0.0) ... Selecting previously unselected package netbase. Preparing to unpack .../2-netbase_6.5_all.deb ... Unpacking netbase (6.5) ... Selecting previously unselected package tzdata. Preparing to unpack .../3-tzdata_2025b-2_all.deb ... Unpacking tzdata (2025b-2) ... Selecting previously unselected package libffi8:arm64. Preparing to unpack .../4-libffi8_3.4.8-2_arm64.deb ... Unpacking libffi8:arm64 (3.4.8-2) ... Selecting previously unselected package readline-common. Preparing to unpack .../5-readline-common_8.2-6_all.deb ... Unpacking readline-common (8.2-6) ... Selecting previously unselected package libreadline8t64:arm64. Preparing to unpack .../6-libreadline8t64_8.2-6_arm64.deb ... Adding 'diversion of /lib/aarch64-linux-gnu/libhistory.so.8 to /lib/aarch64-linux-gnu/libhistory.so.8.usr-is-merged by libreadline8t64' Adding 'diversion of /lib/aarch64-linux-gnu/libhistory.so.8.2 to /lib/aarch64-linux-gnu/libhistory.so.8.2.usr-is-merged by libreadline8t64' Adding 'diversion of /lib/aarch64-linux-gnu/libreadline.so.8 to /lib/aarch64-linux-gnu/libreadline.so.8.usr-is-merged by libreadline8t64' Adding 'diversion of /lib/aarch64-linux-gnu/libreadline.so.8.2 to /lib/aarch64-linux-gnu/libreadline.so.8.2.usr-is-merged by libreadline8t64' Unpacking libreadline8t64:arm64 (8.2-6) ... Selecting previously unselected package libpython3.13-stdlib:arm64. Preparing to unpack .../7-libpython3.13-stdlib_3.13.3-2_arm64.deb ... Unpacking libpython3.13-stdlib:arm64 (3.13.3-2) ... Selecting previously unselected package python3.13. Preparing to unpack .../8-python3.13_3.13.3-2_arm64.deb ... Unpacking python3.13 (3.13.3-2) ... Selecting previously unselected package libpython3-stdlib:arm64. Preparing to unpack .../9-libpython3-stdlib_3.13.3-1_arm64.deb ... Unpacking libpython3-stdlib:arm64 (3.13.3-1) ... Setting up python3-minimal (3.13.3-1) ... Selecting previously unselected package python3. (Reading database ... (Reading database ... 5% (Reading database ... 10% (Reading database ... 15% (Reading database ... 20% (Reading database ... 25% (Reading database ... 30% (Reading database ... 35% (Reading database ... 40% (Reading database ... 45% (Reading database ... 50% (Reading database ... 55% (Reading database ... 60% (Reading database ... 65% (Reading database ... 70% (Reading database ... 75% (Reading database ... 80% (Reading database ... 85% (Reading database ... 90% (Reading database ... 95% (Reading database ... 100% (Reading database ... 21299 files and directories currently installed.) Preparing to unpack .../000-python3_3.13.3-1_arm64.deb ... Unpacking python3 (3.13.3-1) ... Selecting previously unselected package sensible-utils. Preparing to unpack .../001-sensible-utils_0.0.25_all.deb ... Unpacking sensible-utils (0.0.25) ... Selecting previously unselected package openssl. Preparing to unpack .../002-openssl_3.5.0-1_arm64.deb ... Unpacking openssl (3.5.0-1) ... Selecting previously unselected package ca-certificates. Preparing to unpack .../003-ca-certificates_20250419_all.deb ... Unpacking ca-certificates (20250419) ... Selecting previously unselected package libmagic-mgc. Preparing to unpack .../004-libmagic-mgc_1%3a5.46-5_arm64.deb ... Unpacking libmagic-mgc (1:5.46-5) ... Selecting previously unselected package libmagic1t64:arm64. Preparing to unpack .../005-libmagic1t64_1%3a5.46-5_arm64.deb ... Unpacking libmagic1t64:arm64 (1:5.46-5) ... Selecting previously unselected package file. Preparing to unpack .../006-file_1%3a5.46-5_arm64.deb ... Unpacking file (1:5.46-5) ... Selecting previously unselected package gettext-base. Preparing to unpack .../007-gettext-base_0.23.1-1_arm64.deb ... Unpacking gettext-base (0.23.1-1) ... Selecting previously unselected package libuchardet0:arm64. Preparing to unpack .../008-libuchardet0_0.0.8-1+b2_arm64.deb ... Unpacking libuchardet0:arm64 (0.0.8-1+b2) ... Selecting previously unselected package groff-base. Preparing to unpack .../009-groff-base_1.23.0-7_arm64.deb ... Unpacking groff-base (1.23.0-7) ... Selecting previously unselected package bsdextrautils. Preparing to unpack .../010-bsdextrautils_2.41-4_arm64.deb ... Unpacking bsdextrautils (2.41-4) ... Selecting previously unselected package libpipeline1:arm64. Preparing to unpack .../011-libpipeline1_1.5.8-1_arm64.deb ... Unpacking libpipeline1:arm64 (1.5.8-1) ... Selecting previously unselected package man-db. Preparing to unpack .../012-man-db_2.13.0-1_arm64.deb ... Unpacking man-db (2.13.0-1) ... Selecting previously unselected package m4. Preparing to unpack .../013-m4_1.4.19-8_arm64.deb ... Unpacking m4 (1.4.19-8) ... Selecting previously unselected package autoconf. Preparing to unpack .../014-autoconf_2.72-3.1_all.deb ... Unpacking autoconf (2.72-3.1) ... Selecting previously unselected package autotools-dev. Preparing to unpack .../015-autotools-dev_20240727.1_all.deb ... Unpacking autotools-dev (20240727.1) ... Selecting previously unselected package automake. Preparing to unpack .../016-automake_1%3a1.17-4_all.deb ... Unpacking automake (1:1.17-4) ... Selecting previously unselected package autopoint. Preparing to unpack .../017-autopoint_0.23.1-1_all.deb ... Unpacking autopoint (0.23.1-1) ... Selecting previously unselected package libdebhelper-perl. Preparing to unpack .../018-libdebhelper-perl_13.24.2_all.deb ... Unpacking libdebhelper-perl (13.24.2) ... Selecting previously unselected package libtool. Preparing to unpack .../019-libtool_2.5.4-4_all.deb ... Unpacking libtool (2.5.4-4) ... Selecting previously unselected package dh-autoreconf. Preparing to unpack .../020-dh-autoreconf_20_all.deb ... Unpacking dh-autoreconf (20) ... Selecting previously unselected package libarchive-zip-perl. Preparing to unpack .../021-libarchive-zip-perl_1.68-1_all.deb ... Unpacking libarchive-zip-perl (1.68-1) ... Selecting previously unselected package libfile-stripnondeterminism-perl. Preparing to unpack .../022-libfile-stripnondeterminism-perl_1.14.1-2_all.deb ... Unpacking libfile-stripnondeterminism-perl (1.14.1-2) ... Selecting previously unselected package dh-strip-nondeterminism. Preparing to unpack .../023-dh-strip-nondeterminism_1.14.1-2_all.deb ... Unpacking dh-strip-nondeterminism (1.14.1-2) ... Selecting previously unselected package libelf1t64:arm64. Preparing to unpack .../024-libelf1t64_0.192-4_arm64.deb ... Unpacking libelf1t64:arm64 (0.192-4) ... Selecting previously unselected package dwz. Preparing to unpack .../025-dwz_0.15-1+b1_arm64.deb ... Unpacking dwz (0.15-1+b1) ... Selecting previously unselected package libunistring5:arm64. Preparing to unpack .../026-libunistring5_1.3-2_arm64.deb ... Unpacking libunistring5:arm64 (1.3-2) ... Selecting previously unselected package libxml2:arm64. Preparing to unpack .../027-libxml2_2.12.7+dfsg+really2.9.14-0.4_arm64.deb ... Unpacking libxml2:arm64 (2.12.7+dfsg+really2.9.14-0.4) ... Selecting previously unselected package gettext. Preparing to unpack .../028-gettext_0.23.1-1_arm64.deb ... Unpacking gettext (0.23.1-1) ... Selecting previously unselected package intltool-debian. Preparing to unpack .../029-intltool-debian_0.35.0+20060710.6_all.deb ... Unpacking intltool-debian (0.35.0+20060710.6) ... Selecting previously unselected package po-debconf. Preparing to unpack .../030-po-debconf_1.0.21+nmu1_all.deb ... Unpacking po-debconf (1.0.21+nmu1) ... Selecting previously unselected package debhelper. Preparing to unpack .../031-debhelper_13.24.2_all.deb ... Unpacking debhelper (13.24.2) ... Selecting previously unselected package libgpg-error0:arm64. Preparing to unpack .../032-libgpg-error0_1.51-4_arm64.deb ... Unpacking libgpg-error0:arm64 (1.51-4) ... Selecting previously unselected package libassuan9:arm64. Preparing to unpack .../033-libassuan9_3.0.2-2_arm64.deb ... Unpacking libassuan9:arm64 (3.0.2-2) ... Selecting previously unselected package libgcrypt20:arm64. Preparing to unpack .../034-libgcrypt20_1.11.0-7_arm64.deb ... Unpacking libgcrypt20:arm64 (1.11.0-7) ... Selecting previously unselected package gpgconf. Preparing to unpack .../035-gpgconf_2.4.7-15_arm64.deb ... Unpacking gpgconf (2.4.7-15) ... Selecting previously unselected package libksba8:arm64. Preparing to unpack .../036-libksba8_1.6.7-2+b1_arm64.deb ... Unpacking libksba8:arm64 (1.6.7-2+b1) ... Selecting previously unselected package libnpth0t64:arm64. Preparing to unpack .../037-libnpth0t64_1.8-3_arm64.deb ... Unpacking libnpth0t64:arm64 (1.8-3) ... Selecting previously unselected package gpg. Preparing to unpack .../038-gpg_2.4.7-15_arm64.deb ... Unpacking gpg (2.4.7-15) ... Selecting previously unselected package pinentry-curses. Preparing to unpack .../039-pinentry-curses_1.3.1-2_arm64.deb ... Unpacking pinentry-curses (1.3.1-2) ... Selecting previously unselected package gpg-agent. Preparing to unpack .../040-gpg-agent_2.4.7-15_arm64.deb ... Unpacking gpg-agent (2.4.7-15) ... Selecting previously unselected package libfile-dirlist-perl. Preparing to unpack .../041-libfile-dirlist-perl_0.05-3_all.deb ... Unpacking libfile-dirlist-perl (0.05-3) ... Selecting previously unselected package libfile-which-perl. Preparing to unpack .../042-libfile-which-perl_1.27-2_all.deb ... Unpacking libfile-which-perl (1.27-2) ... Selecting previously unselected package libfile-homedir-perl. Preparing to unpack .../043-libfile-homedir-perl_1.006-2_all.deb ... Unpacking libfile-homedir-perl (1.006-2) ... Selecting previously unselected package libfile-touch-perl. Preparing to unpack .../044-libfile-touch-perl_0.12-2_all.deb ... Unpacking libfile-touch-perl (0.12-2) ... Selecting previously unselected package libclass-method-modifiers-perl. Preparing to unpack .../045-libclass-method-modifiers-perl_2.15-1_all.deb ... Unpacking libclass-method-modifiers-perl (2.15-1) ... Selecting previously unselected package libclass-xsaccessor-perl. Preparing to unpack .../046-libclass-xsaccessor-perl_1.19-4+b5_arm64.deb ... Unpacking libclass-xsaccessor-perl (1.19-4+b5) ... Selecting previously unselected package libb-hooks-op-check-perl:arm64. Preparing to unpack .../047-libb-hooks-op-check-perl_0.22-3+b2_arm64.deb ... Unpacking libb-hooks-op-check-perl:arm64 (0.22-3+b2) ... Selecting previously unselected package libdynaloader-functions-perl. Preparing to unpack .../048-libdynaloader-functions-perl_0.004-2_all.deb ... Unpacking libdynaloader-functions-perl (0.004-2) ... Selecting previously unselected package libdevel-callchecker-perl:arm64. Preparing to unpack .../049-libdevel-callchecker-perl_0.009-2_arm64.deb ... Unpacking libdevel-callchecker-perl:arm64 (0.009-2) ... Selecting previously unselected package libparams-classify-perl:arm64. Preparing to unpack .../050-libparams-classify-perl_0.015-2+b4_arm64.deb ... Unpacking libparams-classify-perl:arm64 (0.015-2+b4) ... Selecting previously unselected package libmodule-runtime-perl. Preparing to unpack .../051-libmodule-runtime-perl_0.018-1_all.deb ... Unpacking libmodule-runtime-perl (0.018-1) ... Selecting previously unselected package libimport-into-perl. Preparing to unpack .../052-libimport-into-perl_1.002005-2_all.deb ... Unpacking libimport-into-perl (1.002005-2) ... Selecting previously unselected package librole-tiny-perl. Preparing to unpack .../053-librole-tiny-perl_2.002004-1_all.deb ... Unpacking librole-tiny-perl (2.002004-1) ... Selecting previously unselected package libsub-quote-perl. Preparing to unpack .../054-libsub-quote-perl_2.006008-1_all.deb ... Unpacking libsub-quote-perl (2.006008-1) ... Selecting previously unselected package libmoo-perl. Preparing to unpack .../055-libmoo-perl_2.005005-1_all.deb ... Unpacking libmoo-perl (2.005005-1) ... Selecting previously unselected package libencode-locale-perl. Preparing to unpack .../056-libencode-locale-perl_1.05-3_all.deb ... Unpacking libencode-locale-perl (1.05-3) ... Selecting previously unselected package libtimedate-perl. Preparing to unpack .../057-libtimedate-perl_2.3300-2_all.deb ... Unpacking libtimedate-perl (2.3300-2) ... Selecting previously unselected package libhttp-date-perl. Preparing to unpack .../058-libhttp-date-perl_6.06-1_all.deb ... Unpacking libhttp-date-perl (6.06-1) ... Selecting previously unselected package libfile-listing-perl. Preparing to unpack .../059-libfile-listing-perl_6.16-1_all.deb ... Unpacking libfile-listing-perl (6.16-1) ... Selecting previously unselected package libhtml-tagset-perl. Preparing to unpack .../060-libhtml-tagset-perl_3.24-1_all.deb ... Unpacking libhtml-tagset-perl (3.24-1) ... Selecting previously unselected package liburi-perl. Preparing to unpack .../061-liburi-perl_5.30-1_all.deb ... Unpacking liburi-perl (5.30-1) ... Selecting previously unselected package libhtml-parser-perl:arm64. Preparing to unpack .../062-libhtml-parser-perl_3.83-1+b2_arm64.deb ... Unpacking libhtml-parser-perl:arm64 (3.83-1+b2) ... Selecting previously unselected package libhtml-tree-perl. Preparing to unpack .../063-libhtml-tree-perl_5.07-3_all.deb ... Unpacking libhtml-tree-perl (5.07-3) ... Selecting previously unselected package libclone-perl:arm64. Preparing to unpack .../064-libclone-perl_0.47-1+b1_arm64.deb ... Unpacking libclone-perl:arm64 (0.47-1+b1) ... Selecting previously unselected package libio-html-perl. Preparing to unpack .../065-libio-html-perl_1.004-3_all.deb ... Unpacking libio-html-perl (1.004-3) ... Selecting previously unselected package liblwp-mediatypes-perl. Preparing to unpack .../066-liblwp-mediatypes-perl_6.04-2_all.deb ... Unpacking liblwp-mediatypes-perl (6.04-2) ... Selecting previously unselected package libhttp-message-perl. Preparing to unpack .../067-libhttp-message-perl_7.00-2_all.deb ... Unpacking libhttp-message-perl (7.00-2) ... Selecting previously unselected package libhttp-cookies-perl. Preparing to unpack .../068-libhttp-cookies-perl_6.11-1_all.deb ... Unpacking libhttp-cookies-perl (6.11-1) ... Selecting previously unselected package libhttp-negotiate-perl. Preparing to unpack .../069-libhttp-negotiate-perl_6.01-2_all.deb ... Unpacking libhttp-negotiate-perl (6.01-2) ... Selecting previously unselected package perl-openssl-defaults:arm64. Preparing to unpack .../070-perl-openssl-defaults_7+b2_arm64.deb ... Unpacking perl-openssl-defaults:arm64 (7+b2) ... Selecting previously unselected package libnet-ssleay-perl:arm64. Preparing to unpack .../071-libnet-ssleay-perl_1.94-3_arm64.deb ... Unpacking libnet-ssleay-perl:arm64 (1.94-3) ... Selecting previously unselected package libio-socket-ssl-perl. Preparing to unpack .../072-libio-socket-ssl-perl_2.089-1_all.deb ... Unpacking libio-socket-ssl-perl (2.089-1) ... Selecting previously unselected package libnet-http-perl. Preparing to unpack .../073-libnet-http-perl_6.23-1_all.deb ... Unpacking libnet-http-perl (6.23-1) ... Selecting previously unselected package liblwp-protocol-https-perl. Preparing to unpack .../074-liblwp-protocol-https-perl_6.14-1_all.deb ... Unpacking liblwp-protocol-https-perl (6.14-1) ... Selecting previously unselected package libtry-tiny-perl. Preparing to unpack .../075-libtry-tiny-perl_0.32-1_all.deb ... Unpacking libtry-tiny-perl (0.32-1) ... Selecting previously unselected package libwww-robotrules-perl. Preparing to unpack .../076-libwww-robotrules-perl_6.02-1_all.deb ... Unpacking libwww-robotrules-perl (6.02-1) ... Selecting previously unselected package libwww-perl. Preparing to unpack .../077-libwww-perl_6.78-1_all.deb ... Unpacking libwww-perl (6.78-1) ... Selecting previously unselected package patchutils. Preparing to unpack .../078-patchutils_0.4.2-1+b1_arm64.deb ... Unpacking patchutils (0.4.2-1+b1) ... Selecting previously unselected package gpgv. Preparing to unpack .../079-gpgv_2.4.7-15_arm64.deb ... Unpacking gpgv (2.4.7-15) ... Selecting previously unselected package sopv-gpgv. Preparing to unpack .../080-sopv-gpgv_0.1.4-1_all.deb ... Unpacking sopv-gpgv (0.1.4-1) ... Selecting previously unselected package wdiff. Preparing to unpack .../081-wdiff_1.2.2-9_arm64.deb ... Unpacking wdiff (1.2.2-9) ... Selecting previously unselected package devscripts. Preparing to unpack .../082-devscripts_2.25.10_all.deb ... Unpacking devscripts (2.25.10) ... Selecting previously unselected package rubygems-integration. Preparing to unpack .../083-rubygems-integration_1.19_all.deb ... Unpacking rubygems-integration (1.19) ... Selecting previously unselected package ruby-csv. Preparing to unpack .../084-ruby-csv_3.3.4-1_all.deb ... Unpacking ruby-csv (3.3.4-1) ... Selecting previously unselected package ruby-did-you-mean. Preparing to unpack .../085-ruby-did-you-mean_1.6.3-2_all.deb ... Unpacking ruby-did-you-mean (1.6.3-2) ... Selecting previously unselected package ruby-minitest. Preparing to unpack .../086-ruby-minitest_5.25.4-2_all.deb ... Unpacking ruby-minitest (5.25.4-2) ... Selecting previously unselected package ruby-net-telnet. Preparing to unpack .../087-ruby-net-telnet_0.2.0-1_all.deb ... Unpacking ruby-net-telnet (0.2.0-1) ... Selecting previously unselected package ruby-ruby2-keywords. Preparing to unpack .../088-ruby-ruby2-keywords_0.0.5-1_all.deb ... Unpacking ruby-ruby2-keywords (0.0.5-1) ... Selecting previously unselected package ruby-power-assert. Preparing to unpack .../089-ruby-power-assert_2.0.3-1_all.deb ... Unpacking ruby-power-assert (2.0.3-1) ... Selecting previously unselected package ruby-test-unit. Preparing to unpack .../090-ruby-test-unit_3.6.2-1_all.deb ... Unpacking ruby-test-unit (3.6.2-1) ... Selecting previously unselected package ruby-webrick. Preparing to unpack .../091-ruby-webrick_1.9.1-1_all.deb ... Unpacking ruby-webrick (1.9.1-1) ... Selecting previously unselected package ruby-xmlrpc. Preparing to unpack .../092-ruby-xmlrpc_0.3.3-2_all.deb ... Unpacking ruby-xmlrpc (0.3.3-2) ... Selecting previously unselected package libyaml-0-2:arm64. Preparing to unpack .../093-libyaml-0-2_0.2.5-2_arm64.deb ... Unpacking libyaml-0-2:arm64 (0.2.5-2) ... Selecting previously unselected package libruby3.3:arm64. Preparing to unpack .../094-libruby3.3_3.3.8-1_arm64.deb ... Unpacking libruby3.3:arm64 (3.3.8-1) ... Selecting previously unselected package ruby3.3. Preparing to unpack .../095-ruby3.3_3.3.8-1_arm64.deb ... Unpacking ruby3.3 (3.3.8-1) ... Selecting previously unselected package libruby:arm64. Preparing to unpack .../096-libruby_1%3a3.3+b1_arm64.deb ... Unpacking libruby:arm64 (1:3.3+b1) ... Selecting previously unselected package ruby-rubygems. Preparing to unpack .../097-ruby-rubygems_3.6.7-2_all.deb ... Unpacking ruby-rubygems (3.6.7-2) ... Selecting previously unselected package ruby. Preparing to unpack .../098-ruby_1%3a3.3+b1_arm64.deb ... Unpacking ruby (1:3.3+b1) ... Selecting previously unselected package rake. Preparing to unpack .../099-rake_13.2.1-1_all.deb ... Unpacking rake (13.2.1-1) ... Selecting previously unselected package gem2deb-test-runner. Preparing to unpack .../100-gem2deb-test-runner_2.2.5_arm64.deb ... Unpacking gem2deb-test-runner (2.2.5) ... Selecting previously unselected package libgmpxx4ldbl:arm64. Preparing to unpack .../101-libgmpxx4ldbl_2%3a6.3.0+dfsg-3_arm64.deb ... Unpacking libgmpxx4ldbl:arm64 (2:6.3.0+dfsg-3) ... Selecting previously unselected package libgmp-dev:arm64. Preparing to unpack .../102-libgmp-dev_2%3a6.3.0+dfsg-3_arm64.deb ... Unpacking libgmp-dev:arm64 (2:6.3.0+dfsg-3) ... Selecting previously unselected package ruby3.3-dev:arm64. Preparing to unpack .../103-ruby3.3-dev_3.3.8-1_arm64.deb ... Unpacking ruby3.3-dev:arm64 (3.3.8-1) ... Selecting previously unselected package ruby-all-dev:arm64. Preparing to unpack .../104-ruby-all-dev_1%3a3.3+b1_arm64.deb ... Unpacking ruby-all-dev:arm64 (1:3.3+b1) ... Selecting previously unselected package gem2deb. Preparing to unpack .../105-gem2deb_2.2.5_arm64.deb ... Unpacking gem2deb (2.2.5) ... Selecting previously unselected package racc. Preparing to unpack .../106-racc_1.8.1-1_all.deb ... Unpacking racc (1.8.1-1) ... Selecting previously unselected package ruby-ast. Preparing to unpack .../107-ruby-ast_2.4.3-1_all.deb ... Unpacking ruby-ast (2.4.3-1) ... Selecting previously unselected package ruby-diff-lcs. Preparing to unpack .../108-ruby-diff-lcs_1.5.1-1_all.deb ... Unpacking ruby-diff-lcs (1.5.1-1) ... Selecting previously unselected package ruby-oedipus-lex. Preparing to unpack .../109-ruby-oedipus-lex_2.6.0-2_all.deb ... Unpacking ruby-oedipus-lex (2.6.0-2) ... Selecting previously unselected package ruby-rspec-support. Preparing to unpack .../110-ruby-rspec-support_3.13.0c0e0m0s1-2_all.deb ... Unpacking ruby-rspec-support (3.13.0c0e0m0s1-2) ... Selecting previously unselected package ruby-rspec-core. Preparing to unpack .../111-ruby-rspec-core_3.13.0c0e0m0s1-2_all.deb ... Unpacking ruby-rspec-core (3.13.0c0e0m0s1-2) ... Selecting previously unselected package ruby-rspec-expectations. Preparing to unpack .../112-ruby-rspec-expectations_3.13.0c0e0m0s1-2_all.deb ... Unpacking ruby-rspec-expectations (3.13.0c0e0m0s1-2) ... Selecting previously unselected package ruby-rspec-mocks. Preparing to unpack .../113-ruby-rspec-mocks_3.13.0c0e0m0s1-2_all.deb ... Unpacking ruby-rspec-mocks (3.13.0c0e0m0s1-2) ... Selecting previously unselected package ruby-rspec. Preparing to unpack .../114-ruby-rspec_3.13.0c0e0m0s1-2_all.deb ... Unpacking ruby-rspec (3.13.0c0e0m0s1-2) ... Selecting previously unselected package ruby-whitequark-parser. Preparing to unpack .../115-ruby-whitequark-parser_3.3.4.2-2_all.deb ... Unpacking ruby-whitequark-parser (3.3.4.2-2) ... Setting up media-types (13.0.0) ... Setting up libpipeline1:arm64 (1.5.8-1) ... Setting up wdiff (1.2.2-9) ... Setting up libfile-which-perl (1.27-2) ... Setting up libnpth0t64:arm64 (1.8-3) ... Setting up ruby-ruby2-keywords (0.0.5-1) ... Setting up ruby-oedipus-lex (2.6.0-2) ... Setting up bsdextrautils (2.41-4) ... Setting up libgpg-error0:arm64 (1.51-4) ... Setting up libdynaloader-functions-perl (0.004-2) ... Setting up libclass-method-modifiers-perl (2.15-1) ... Setting up ruby-power-assert (2.0.3-1) ... Setting up libmagic-mgc (1:5.46-5) ... Setting up libclone-perl:arm64 (0.47-1+b1) ... Setting up libarchive-zip-perl (1.68-1) ... Setting up libyaml-0-2:arm64 (0.2.5-2) ... Setting up libhtml-tagset-perl (3.24-1) ... Setting up libdebhelper-perl (13.24.2) ... Setting up liblwp-mediatypes-perl (6.04-2) ... Setting up libmagic1t64:arm64 (1:5.46-5) ... Setting up libtry-tiny-perl (0.32-1) ... Setting up perl-openssl-defaults:arm64 (7+b2) ... Setting up gettext-base (0.23.1-1) ... Setting up m4 (1.4.19-8) ... Setting up libgcrypt20:arm64 (1.11.0-7) ... Setting up libencode-locale-perl (1.05-3) ... Setting up file (1:5.46-5) ... Setting up libelf1t64:arm64 (0.192-4) ... Setting up tzdata (2025b-2) ... Current default time zone: 'Etc/UTC' Local time is now: Sat Apr 26 18:56:08 UTC 2025. Universal Time is now: Sat Apr 26 18:56:08 UTC 2025. Run 'dpkg-reconfigure tzdata' if you wish to change it. Setting up ruby-minitest (5.25.4-2) ... Setting up autotools-dev (20240727.1) ... Setting up libgmpxx4ldbl:arm64 (2:6.3.0+dfsg-3) ... Setting up ruby-test-unit (3.6.2-1) ... Setting up ruby-ast (2.4.3-1) ... Setting up ruby-net-telnet (0.2.0-1) ... Setting up ruby-csv (3.3.4-1) ... Setting up libunistring5:arm64 (1.3-2) ... Setting up libio-html-perl (1.004-3) ... Setting up autopoint (0.23.1-1) ... Setting up libb-hooks-op-check-perl:arm64 (0.22-3+b2) ... Setting up autoconf (2.72-3.1) ... Setting up ruby-rspec-support (3.13.0c0e0m0s1-2) ... Setting up libtimedate-perl (2.3300-2) ... Setting up ruby-webrick (1.9.1-1) ... Setting up libffi8:arm64 (3.4.8-2) ... Setting up dwz (0.15-1+b1) ... Setting up sensible-utils (0.0.25) ... Setting up gpgv (2.4.7-15) ... Setting up libuchardet0:arm64 (0.0.8-1+b2) ... Setting up libassuan9:arm64 (3.0.2-2) ... Setting up librole-tiny-perl (2.002004-1) ... Setting up netbase (6.5) ... Setting up libsub-quote-perl (2.006008-1) ... Setting up libclass-xsaccessor-perl (1.19-4+b5) ... Setting up ruby-did-you-mean (1.6.3-2) ... Setting up libfile-dirlist-perl (0.05-3) ... Setting up libfile-homedir-perl (1.006-2) ... Setting up openssl (3.5.0-1) ... Setting up readline-common (8.2-6) ... Setting up ruby-xmlrpc (0.3.3-2) ... Setting up libxml2:arm64 (2.12.7+dfsg+really2.9.14-0.4) ... Setting up liburi-perl (5.30-1) ... Setting up libfile-touch-perl (0.12-2) ... Setting up libnet-ssleay-perl:arm64 (1.94-3) ... Setting up automake (1:1.17-4) ... update-alternatives: using /usr/bin/automake-1.17 to provide /usr/bin/automake (automake) in auto mode Setting up libksba8:arm64 (1.6.7-2+b1) ... Setting up pinentry-curses (1.3.1-2) ... Setting up libfile-stripnondeterminism-perl (1.14.1-2) ... Setting up libhttp-date-perl (6.06-1) ... Setting up gettext (0.23.1-1) ... Setting up libgmp-dev:arm64 (2:6.3.0+dfsg-3) ... Setting up libfile-listing-perl (6.16-1) ... Setting up libtool (2.5.4-4) ... Setting up libnet-http-perl (6.23-1) ... Setting up libdevel-callchecker-perl:arm64 (0.009-2) ... Setting up intltool-debian (0.35.0+20060710.6) ... Setting up dh-autoreconf (20) ... Setting up patchutils (0.4.2-1+b1) ... Setting up ca-certificates (20250419) ... Updating certificates in /etc/ssl/certs... 150 added, 0 removed; done. Setting up libreadline8t64:arm64 (8.2-6) ... Setting up dh-strip-nondeterminism (1.14.1-2) ... Setting up libwww-robotrules-perl (6.02-1) ... Setting up groff-base (1.23.0-7) ... Setting up libhtml-parser-perl:arm64 (3.83-1+b2) ... Setting up gpgconf (2.4.7-15) ... Setting up libpython3.13-stdlib:arm64 (3.13.3-2) ... Setting up libio-socket-ssl-perl (2.089-1) ... Setting up gpg (2.4.7-15) ... Setting up libpython3-stdlib:arm64 (3.13.3-1) ... Setting up libhttp-message-perl (7.00-2) ... Setting up libhttp-negotiate-perl (6.01-2) ... Setting up gpg-agent (2.4.7-15) ... Setting up libhttp-cookies-perl (6.11-1) ... Setting up python3.13 (3.13.3-2) ... Setting up po-debconf (1.0.21+nmu1) ... Setting up libhtml-tree-perl (5.07-3) ... Setting up libparams-classify-perl:arm64 (0.015-2+b4) ... Setting up python3 (3.13.3-1) ... Setting up rubygems-integration (1.19) ... Setting up sopv-gpgv (0.1.4-1) ... update-alternatives: using /usr/bin/sopv-gpgv to provide /usr/bin/sopv (sopv) in auto mode Setting up man-db (2.13.0-1) ... Not building database; man-db/auto-update is not 'true'. Setting up libmodule-runtime-perl (0.018-1) ... Setting up libimport-into-perl (1.002005-2) ... Setting up libmoo-perl (2.005005-1) ... Setting up debhelper (13.24.2) ... Setting up rake (13.2.1-1) ... Setting up liblwp-protocol-https-perl (6.14-1) ... Setting up libwww-perl (6.78-1) ... Setting up libruby3.3:arm64 (3.3.8-1) ... Setting up ruby-rubygems (3.6.7-2) ... Setting up devscripts (2.25.10) ... Setting up ruby3.3-dev:arm64 (3.3.8-1) ... Setting up ruby3.3 (3.3.8-1) ... Setting up libruby:arm64 (1:3.3+b1) ... Setting up ruby-all-dev:arm64 (1:3.3+b1) ... Setting up ruby (1:3.3+b1) ... Setting up racc (1.8.1-1) ... Setting up ruby-rspec-core (3.13.0c0e0m0s1-2) ... Setting up ruby-diff-lcs (1.5.1-1) ... Setting up ruby-whitequark-parser (3.3.4.2-2) ... Setting up gem2deb-test-runner (2.2.5) ... Setting up ruby-rspec-expectations (3.13.0c0e0m0s1-2) ... Setting up ruby-rspec-mocks (3.13.0c0e0m0s1-2) ... Setting up gem2deb (2.2.5) ... Setting up ruby-rspec (3.13.0c0e0m0s1-2) ... Processing triggers for libc-bin (2.41-7) ... Processing triggers for ca-certificates (20250419) ... Updating certificates in /etc/ssl/certs... 0 added, 0 removed; done. Running hooks in /etc/ca-certificates/update.d... done. Reading package lists... Building dependency tree... Reading state information... Reading extended state information... Initializing package states... Writing extended state information... Building tag database... -> Finished parsing the build-deps I: Building the package I: user script /srv/workspace/pbuilder/433812/tmp/hooks/A99_set_merged_usr starting Not re-configuring usrmerge for unstable I: user script /srv/workspace/pbuilder/433812/tmp/hooks/A99_set_merged_usr finished hostname: Name or service not known I: Running cd /build/reproducible-path/ruby-rubocop-ast-1.24.0/ && env PATH="/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/i/capture/the/path" HOME="/nonexistent/second-build" dpkg-buildpackage -us -uc -b && env PATH="/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/i/capture/the/path" HOME="/nonexistent/second-build" dpkg-genchanges -S > ../ruby-rubocop-ast_1.24.0-2_source.changes dpkg-buildpackage: info: source package ruby-rubocop-ast dpkg-buildpackage: info: source version 1.24.0-2 dpkg-buildpackage: info: source distribution unstable dpkg-buildpackage: info: source changed by Lucas Kanashiro dpkg-source --before-build . dpkg-buildpackage: info: host architecture arm64 debian/rules clean dh clean --buildsystem=ruby --with ruby dh_auto_clean -O--buildsystem=ruby dh_ruby --clean W: XS-Ruby-Versions is deprecated, and will be ignored dh_autoreconf_clean -O--buildsystem=ruby dh_clean -O--buildsystem=ruby debian/rules binary dh binary --buildsystem=ruby --with ruby dh_update_autotools_config -O--buildsystem=ruby dh_autoreconf -O--buildsystem=ruby dh_auto_configure -O--buildsystem=ruby dh_ruby --configure debian/rules override_dh_auto_build make[1]: Entering directory '/build/reproducible-path/ruby-rubocop-ast-1.24.0' rake -f tasks/compile.rake generate Generating lib/rubocop/ast/node_pattern/lexer.rex.rb from lib/rubocop/ast/node_pattern/lexer.rex racc -l -v -o lib/rubocop/ast/node_pattern/parser.racc.rb lib/rubocop/ast/node_pattern/parser.y dh_auto_build dh_ruby --build make[1]: Leaving directory '/build/reproducible-path/ruby-rubocop-ast-1.24.0' dh_auto_test -O--buildsystem=ruby dh_ruby --test create-stamp debian/debhelper-build-stamp dh_testroot -O--buildsystem=ruby dh_prep -O--buildsystem=ruby dh_auto_install --destdir=debian/ruby-rubocop-ast/ -O--buildsystem=ruby dh_ruby --install /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast ┌──────────────────────────────────────────────────────────────────────────────┐ │ ruby-rubocop-ast: Installing files and building extensions for ruby3.3 │ └──────────────────────────────────────────────────────────────────────────────┘ /usr/bin/ruby3.3 -S gem build --config-file /dev/null --verbose /tmp/d20250427-443914-v9ocuu/gemspec WARNING: open-ended dependency on parser (>= 3.1.1.0) is not recommended if parser is semantically versioned, use: add_runtime_dependency "parser", "~> 3.1", ">= 3.1.1.0" WARNING: See https://guides.rubygems.org/specification-reference/ for help Successfully built RubyGem Name: rubocop-ast Version: 1.24.0 File: rubocop-ast-1.24.0.gem /usr/bin/ruby3.3 -S gem install --config-file /dev/null --verbose --local --verbose --no-document --ignore-dependencies --install-dir debian/ruby-rubocop-ast/usr/share/rubygems-integration/all /tmp/d20250427-443914-v9ocuu/rubocop-ast-1.24.0.gem /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop-ast.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/builder.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/ext/range.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/ext/range_min_max.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/alias_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/and_asgn_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/and_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/arg_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/args_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/array_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/asgn_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/block_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/break_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/case_match_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/case_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/casgn_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/class_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/const_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/def_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/defined_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/dstr_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/ensure_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/float_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/for_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/forward_args_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/hash_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/if_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/in_pattern_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/index_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/indexasgn_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/int_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/keyword_splat_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/lambda_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/mixin/basic_literal_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/mixin/binary_operator_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/mixin/collection_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/mixin/conditional_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/mixin/descendence.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/mixin/hash_element_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/mixin/method_dispatch_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/mixin/method_identifier_predicates.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/mixin/modifier_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/mixin/numeric_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/mixin/parameterized_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/mixin/predicate_operator_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/module_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/next_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/op_asgn_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/or_asgn_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/or_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/pair_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/procarg0_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/range_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/regexp_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/resbody_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/rescue_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/return_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/self_class_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/send_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/str_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/super_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/symbol_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/until_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/when_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/while_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node/yield_node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node_pattern.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node_pattern/builder.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node_pattern/comment.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node_pattern/compiler.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node_pattern/compiler/atom_subcompiler.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node_pattern/compiler/binding.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node_pattern/compiler/debug.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node_pattern/compiler/node_pattern_subcompiler.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node_pattern/compiler/sequence_subcompiler.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node_pattern/compiler/subcompiler.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node_pattern/lexer.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node_pattern/lexer.rex.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node_pattern/method_definer.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node_pattern/node.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node_pattern/parser.racc.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node_pattern/parser.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node_pattern/sets.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/node_pattern/with_meta.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/processed_source.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/rubocop_compatibility.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/sexp.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/token.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/traversal.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/version.rb Successfully installed rubocop-ast-1.24.0 1 gem installed cd debian/ruby-rubocop-ast/usr/share/rubygems-integration/all rm -rf bin rm -rf build_info rm -rf cache rm -rf doc rm -rf extensions rmdir plugins cd gems/rubocop-ast-1.24.0 rm -f chmod 644 lib/rubocop/ast/builder.rb lib/rubocop/ast/ext/range.rb lib/rubocop/ast/ext/range_min_max.rb lib/rubocop/ast/node/alias_node.rb lib/rubocop/ast/node/and_asgn_node.rb lib/rubocop/ast/node/and_node.rb lib/rubocop/ast/node/arg_node.rb lib/rubocop/ast/node/args_node.rb lib/rubocop/ast/node/array_node.rb lib/rubocop/ast/node/asgn_node.rb lib/rubocop/ast/node/block_node.rb lib/rubocop/ast/node/break_node.rb lib/rubocop/ast/node/case_match_node.rb lib/rubocop/ast/node/case_node.rb lib/rubocop/ast/node/casgn_node.rb lib/rubocop/ast/node/class_node.rb lib/rubocop/ast/node/const_node.rb lib/rubocop/ast/node/def_node.rb lib/rubocop/ast/node/defined_node.rb lib/rubocop/ast/node/dstr_node.rb lib/rubocop/ast/node/ensure_node.rb lib/rubocop/ast/node/float_node.rb lib/rubocop/ast/node/for_node.rb lib/rubocop/ast/node/forward_args_node.rb lib/rubocop/ast/node/hash_node.rb lib/rubocop/ast/node/if_node.rb lib/rubocop/ast/node/in_pattern_node.rb lib/rubocop/ast/node/index_node.rb lib/rubocop/ast/node/indexasgn_node.rb lib/rubocop/ast/node/int_node.rb lib/rubocop/ast/node/keyword_splat_node.rb lib/rubocop/ast/node/lambda_node.rb lib/rubocop/ast/node/mixin/basic_literal_node.rb lib/rubocop/ast/node/mixin/binary_operator_node.rb lib/rubocop/ast/node/mixin/collection_node.rb lib/rubocop/ast/node/mixin/conditional_node.rb lib/rubocop/ast/node/mixin/descendence.rb lib/rubocop/ast/node/mixin/hash_element_node.rb lib/rubocop/ast/node/mixin/method_dispatch_node.rb lib/rubocop/ast/node/mixin/method_identifier_predicates.rb lib/rubocop/ast/node/mixin/modifier_node.rb lib/rubocop/ast/node/mixin/numeric_node.rb lib/rubocop/ast/node/mixin/parameterized_node.rb lib/rubocop/ast/node/mixin/predicate_operator_node.rb lib/rubocop/ast/node/module_node.rb lib/rubocop/ast/node/next_node.rb lib/rubocop/ast/node/op_asgn_node.rb lib/rubocop/ast/node/or_asgn_node.rb lib/rubocop/ast/node/or_node.rb lib/rubocop/ast/node/pair_node.rb lib/rubocop/ast/node/procarg0_node.rb lib/rubocop/ast/node/range_node.rb lib/rubocop/ast/node/regexp_node.rb lib/rubocop/ast/node/resbody_node.rb lib/rubocop/ast/node/rescue_node.rb lib/rubocop/ast/node/return_node.rb lib/rubocop/ast/node/self_class_node.rb lib/rubocop/ast/node/send_node.rb lib/rubocop/ast/node/str_node.rb lib/rubocop/ast/node/super_node.rb lib/rubocop/ast/node/symbol_node.rb lib/rubocop/ast/node/until_node.rb lib/rubocop/ast/node/when_node.rb lib/rubocop/ast/node/while_node.rb lib/rubocop/ast/node/yield_node.rb lib/rubocop/ast/node.rb lib/rubocop/ast/node_pattern/builder.rb lib/rubocop/ast/node_pattern/comment.rb lib/rubocop/ast/node_pattern/compiler/atom_subcompiler.rb lib/rubocop/ast/node_pattern/compiler/binding.rb lib/rubocop/ast/node_pattern/compiler/debug.rb lib/rubocop/ast/node_pattern/compiler/node_pattern_subcompiler.rb lib/rubocop/ast/node_pattern/compiler/sequence_subcompiler.rb lib/rubocop/ast/node_pattern/compiler/subcompiler.rb lib/rubocop/ast/node_pattern/compiler.rb lib/rubocop/ast/node_pattern/lexer.rb lib/rubocop/ast/node_pattern/lexer.rex.rb lib/rubocop/ast/node_pattern/method_definer.rb lib/rubocop/ast/node_pattern/node.rb lib/rubocop/ast/node_pattern/parser.racc.rb lib/rubocop/ast/node_pattern/parser.rb lib/rubocop/ast/node_pattern/sets.rb lib/rubocop/ast/node_pattern/with_meta.rb lib/rubocop/ast/node_pattern.rb lib/rubocop/ast/processed_source.rb lib/rubocop/ast/rubocop_compatibility.rb lib/rubocop/ast/sexp.rb lib/rubocop/ast/token.rb lib/rubocop/ast/traversal.rb lib/rubocop/ast/version.rb lib/rubocop/ast.rb lib/rubocop-ast.rb find lib/ -type d -empty -delete cd - cd - dh_installchangelogs -pruby-rubocop-ast /build/reproducible-path/ruby-rubocop-ast-1.24.0/CHANGELOG.md upstream /usr/bin/ruby3.3 /usr/bin/gem2deb-test-runner ┌──────────────────────────────────────────────────────────────────────────────┐ │ Checking Rubygems dependency resolution on ruby3.3 │ └──────────────────────────────────────────────────────────────────────────────┘ RUBYLIB=. GEM_PATH=/build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all:/build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/.debhelper/generated/_source/home/.local/share/gem/ruby/3.3.0:/var/lib/gems/3.3.0:/usr/local/lib/ruby/gems/3.3.0:/usr/lib/ruby/gems/3.3.0:/usr/lib/aarch64-linux-gnu/ruby/gems/3.3.0:/usr/share/rubygems-integration/3.3.0:/usr/share/rubygems-integration/all:/usr/lib/aarch64-linux-gnu/rubygems-integration/3.3.0 ruby3.3 -e gem\ \"rubocop-ast\" ┌──────────────────────────────────────────────────────────────────────────────┐ │ Run tests for ruby3.3 from debian/ruby-tests.rake │ └──────────────────────────────────────────────────────────────────────────────┘ RUBYLIB=. GEM_PATH=/build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all:/build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/.debhelper/generated/_source/home/.local/share/gem/ruby/3.3.0:/var/lib/gems/3.3.0:/usr/local/lib/ruby/gems/3.3.0:/usr/lib/ruby/gems/3.3.0:/usr/lib/aarch64-linux-gnu/ruby/gems/3.3.0:/usr/share/rubygems-integration/3.3.0:/usr/share/rubygems-integration/all:/usr/lib/aarch64-linux-gnu/rubygems-integration/3.3.0 ruby3.3 -S rake --rakelibdir /gem2deb-nonexistent -f debian/ruby-tests.rake /usr/bin/ruby3.3 -ruri -I/usr/share/rubygems-integration/all/gems/rspec-support-3.13.1/lib:/usr/share/rubygems-integration/all/gems/rspec-core-3.13.0/lib /usr/share/rubygems-integration/all/gems/rspec-core-3.13.0/exe/rspec --pattern ./spec/\*\*/\*_spec.rb --format documentation warning: parser/current is loading parser/ruby33, which recognizes 3.3.4-compliant syntax, but you are running 3.3.8. Please see https://github.com/whitequark/parser#compatibility-with-ruby-mri. Randomized with seed 34457 RuboCop::AST::Ext::Range #line_span accepts an `exclude_end` keyword argument returns the range of lines a range occupies RuboCop::AST::DstrNode #value with interpolation is expected to eq "foo \#{bar} baz" with a multiline string is expected to eq "this is a multiline string" with implicit concatenation is expected to eq "foo bar baz" RuboCop::AST::BreakNode behaves like wrapped arguments node #arguments with a single argument and braces is expected to eq 1 with a single splat argument is expected to eq 1 with multiple literal arguments is expected to eq 2 with a single argument is expected to eq 1 with no arguments is expected to be empty with no arguments and braces is expected to be empty .new without arguments is expected to be a kind of RuboCop::AST::BreakNode with arguments is expected to be a kind of RuboCop::AST::BreakNode RuboCop::AST::Token #column returns index of first char in token range on that line .from_parser_token sets parser token's range to rubocop token's pos sets parser token's type to rubocop token's type returns a #to_s useful for debugging sets parser token's text to rubocop token's text #line returns line of token #to_s returns string of token data #end_pos returns index of last char in token range of entire source #space_after returns truthy MatchData when there is a space after token returns nil when there is not a space after token #begin_pos returns index of first char in token range of entire source #space_before returns nil when it is on the first line returns truthy MatchData when there is a space before token returns nil when there is not a space before token type predicates #left_array_bracket? returns true for left_array_bracket tokens returns false for non left_array_bracket tokens with braces & parens #left_brace? returns false for non left hash brace tokens returns true for left hash brace tokens #right_curly_brace? returns true for all right brace tokens returns false for non right brace tokens #left_parens? returns true for left parens tokens returns false for non left parens tokens #right_parens? returns true for right parens tokens returns false for non right parens tokens #left_curly_brace? returns true for left block brace tokens returns false for non left block brace tokens #left_ref_bracket? returns true for left_ref_bracket tokens returns false for non left_ref_bracket tokens #regexp_dots? returns false for non comma tokens returns true for regexp tokens #comment? returns true for comment tokens returns false for non comment tokens #semicolon? returns true for semicolon tokens returns false for non semicolon tokens #new_line? returns false for non new line tokens returns true for new line tokens #left_brace? returns true for right_bracket tokens returns false for non right_bracket tokens #left_bracket? returns true for all left_bracket tokens returns false for non left_bracket tokens #equals_sign? returns true for equals sign tokens returns false for non equals sign tokens #rescue_modifier? returns false for non rescue modifier tokens returns true for rescue modifier tokens #end? returns false for non end tokens returns true for end tokens #right_bracket? returns true for all right_bracket tokens returns false for non right_bracket tokens #dot? returns false for non dot tokens returns true for dot tokens #comma? returns false for non comma tokens returns true for comma tokens RuboCop::AST::CasgnNode .new with a `casgn` node is expected to be a kind of RuboCop::AST::CasgnNode #expression is expected to eq s(:send, nil, :value) #name is expected to eq :VAR #namespace when there is no parent is expected to be nil when the parent is a `const` is expected to eq s(:const, nil, :FOO) when the parent is a `cbase` is expected to eq s(:cbase) RuboCop::AST::AliasNode #old_identifier is expected to be sym type is expected to eq :bar .new is expected to be a kind of RuboCop::AST::AliasNode #new_identifier is expected to be sym type is expected to eq :foo RuboCop::AST::RuboCopCompatibility when ran from a compatible version of Rubocop issues a warning when ran from an incompatible version of Rubocop issues a warning RuboCop::AST::AndNode #lhs with a logical and node is expected to be sym type with a semantic and node is expected to be sym type .new with a logical and node is expected to be a kind of RuboCop::AST::AndNode with a semantic and node is expected to be a kind of RuboCop::AST::AndNode #logical_operator? with a semantic and node is expected not to be logical operator with a logical and node is expected to be logical operator #semantic_operator? with a logical and node is expected not to be semantic operator with a semantic and node is expected to be semantic operator #inverse_operator with a semantic and node is expected to eq "or" with a logical and node is expected to eq "||" #operator with a logical and node is expected to eq "&&" with a semantic and node is expected to eq "and" #rhs with a semantic and node is expected to be int type with a logical and node is expected to be int type #alternate_operator with a logical and node is expected to eq "and" with a semantic and node is expected to eq "&&" RuboCop::AST::AsgnNode #name with a `cvasgn` node is expected to eq :@@var with a `ivasgn` node is expected to eq :@var with a `gvasgn` node is expected to eq :$var with a `lvasgn` node is expected to eq :var #expression with a `cvasgn` node is expected to eq s(:send, nil, :value) with a `gvasgn` node is expected to eq s(:send, nil, :value) with a `lvasgn` node is expected to eq s(:send, nil, :value) with a `ivasgn` node is expected to eq s(:send, nil, :value) .new with a `ivasgn` node is expected to be a kind of RuboCop::AST::AsgnNode with a `lvasgn` node is expected to be a kind of RuboCop::AST::AsgnNode with a `cvasgn` node is expected to be a kind of RuboCop::AST::AsgnNode with a `gvasgn` node is expected to be a kind of RuboCop::AST::AsgnNode RuboCop::AST::StrNode .new with a string with interpolation is expected to be a kind of RuboCop::AST::StrNode with a heredoc is expected to be a kind of RuboCop::AST::StrNode with a normal string is expected to be a kind of RuboCop::AST::StrNode #character_literal? with a character literal is expected to be character literal with a normal string literal is expected not to be character literal with a heredoc is expected not to be character literal #heredoc? with a normal string is expected not to be heredoc with a heredoc is expected to be heredoc with a string with interpolation is expected not to be heredoc RuboCop::AST::RescueNode #body is expected to be send type #resbody_branches is expected to all be resbody type is expected to eq 2 #else_branch with an else statement is expected to be send type without an else statement is expected to be nil #else? without an else statement is expected not to be else with an else statement is expected to be else #branches when there is no else keyword returns only then rescue bodies when there is an else returns all the bodies with an empty else returns all the bodies .new is expected to be a kind of RuboCop::AST::RescueNode RuboCop::AST::OrAsgnNode .new is expected to be a kind of RuboCop::AST::OrAsgnNode #assignment_node is expected to be a kind of RuboCop::AST::AsgnNode #operator is expected to eq :"||" #name is expected to eq :var #expression is expected to eq s(:send, nil, :value) RuboCop::AST::WhileNode #keyword is expected to eq "while" .new with a statement while is expected to be a kind of RuboCop::AST::WhileNode with a modifier while is expected to be a kind of RuboCop::AST::WhileNode #post_condition_loop? with a statement while is expected not to be post condition loop with a modifier while is expected to be post condition loop #inverse_keyword is expected to eq "until" #loop_keyword? with a statement while is expected to be loop keyword with a modifier while is expected to be loop keyword #do? without a do keyword is expected not to be do with a do keyword is expected to be do RuboCop::AST::IfNode #else_branch with an unless statement is expected to be int type with a ternary operator is expected to be int type with an if statement is expected to be int type #modifier_form? with a modifier unless statement is expected to be modifier form with a modifier if statement is expected to be modifier form with a non-modifier if statement is expected not to be modifier form with a ternary operator is expected not to be modifier form with a non-modifier unless statement is expected not to be modifier form #keyword with an unless statement is expected to eq "unless" with a ternary operator is expected to eq "" with an if statement is expected to eq "if" #if? with a ternary operator is expected not to be if with an unless statement is expected not to be if with an if statement is expected to be if #branches with an elsif statement is expected to all be literal is expected to eq 3 with an unless statement is expected to all be literal is expected to eq 1 with an else statement is expected to eq 2 is expected to all be literal with a ternary operator is expected to all be literal is expected to eq 2 with an if statement is expected to eq 1 is expected to all be literal #unless? with an if statement is expected not to be unless with an unless statement is expected to be unless with a ternary operator is expected not to be unless #if_branch with a ternary operator is expected to be sym type with an if statement is expected to be sym type with an unless statement is expected to be sym type #each_branch when passed a block yields all the branches when not passed a block is expected to be a kind of Enumerator #inverse_keyword? with an unless statement is expected to eq "if" with an if statement is expected to eq "unless" with a ternary operator is expected to eq "" #nested_conditional? with nested conditionals in if clause is expected to be nested conditional with nested conditionals in else clause is expected to be nested conditional with nested conditionals in elsif clause is expected to be nested conditional with no nested conditionals is expected not to be nested conditional with nested ternary operators when nested in the truthy branch is expected to be nested conditional when nested in the falsey branch is expected to be nested conditional #elsif? with an elsif statement is expected to be elsif without an elsif statement is expected not to be elsif with an if statement comtaining an elsif is expected not to be elsif #ternary? with an unless statement is expected not to be ternary with an if statement is expected not to be ternary with a ternary operator is expected to be ternary .new with a modifier statement is expected to be a kind of RuboCop::AST::IfNode with a regular if statement is expected to be a kind of RuboCop::AST::IfNode with a ternary operator is expected to be a kind of RuboCop::AST::IfNode #else? without an else statement is expected not to be elsif with an elsif statement is expected to be else #elsif_conditional? with one elsif conditional is expected to be elsif conditional with multiple elsif conditionals is expected to be elsif conditional with nested conditionals in else clause is expected not to be elsif conditional with nested conditionals in if clause is expected not to be elsif conditional with nested ternary operators when nested in the truthy branch is expected not to be elsif conditional when nested in the falsey branch is expected not to be elsif conditional RuboCop::AST::YieldNode #receiver is expected to be nil #double_colon? is expected not to be double colon #method? when message does not match when argument is a symbol is expected not to be method :foo when argument is a string is expected not to be method "foo" when message matches when argument is a symbol is expected to be method :yield when argument is a string is expected to be method "yield" #command? when argument is a string is expected to be command "yield" when argument is a symbol is expected to be command :yield #arguments? with a single literal argument is expected to be arguments with multiple mixed arguments is expected to be arguments with a single splat argument is expected to be arguments with multiple literal arguments is expected to be arguments with no arguments is expected not to be arguments #block_node is expected to be nil #assignment_method? is expected not to be assignment method #camel_case_method? is expected not to be camel case method #splat_argument? with a splat argument is expected to be splat argument with no arguments is expected not to be splat argument with regular arguments is expected not to be splat argument with mixed arguments is expected to be splat argument #predicate_method? is expected not to be predicate method .new is expected to be a kind of RuboCop::AST::YieldNode #macro? is expected not to be macro #last_argument with no arguments is expected to be nil with multiple mixed arguments is expected to be splat type with multiple literal arguments is expected to be sym type with a single literal argument is expected to be sym type with a single splat argument is expected to be splat type #first_argument with a single literal argument is expected to be sym type with no arguments is expected to be nil with a single splat argument is expected to be splat type with multiple literal arguments is expected to be sym type with multiple mixed arguments is expected to be sym type #const_receiver? is expected not to be const receiver #comparison_method? is expected not to be comparison method #method_name is expected to eq :yield #self_receiver? is expected not to be self receiver #dot? is expected not to be dot #setter_method? is expected not to be setter method #block_argument? is expected not to be block argument #arguments with multiple mixed arguments is expected to eq 2 with a single literal argument is expected to eq 1 with no arguments is expected to be empty with multiple literal arguments is expected to eq 2 with a single splat argument is expected to eq 1 #block_literal? is expected not to be block literal #bang_method? is expected not to be bang method #operator_method? is expected not to be operator method #parenthesized? with no arguments when using parentheses is expected to be parenthesized when not using parentheses is expected not to be parenthesized with arguments when not using parentheses is expected not to be parenthesized when using parentheses is expected to be parenthesized #implicit_call? is expected not to be implicit call RuboCop::AST::Traversal knows all current node types for example < *args do end traverses all nodes for example 1.33 traverses all nodes for example @var = 10 traverses all nodes for example *b = bar traverses all nodes for example foo[1, 2] traverses all nodes for example meth 1 do end.fun bar traverses all nodes for example f{ |o=1, &b| } traverses all nodes for example ((b, )) = foo traverses all nodes for example foo * 1 traverses all nodes for example !/wat/ traverses all nodes for example !foo traverses all nodes for example [*foo] traverses all nodes for example case foo; in [x, y, *] then true; end traverses all nodes for example meth 1 do end::fun(bar) traverses all nodes for example case foo; in A[] then true; end traverses all nodes for example %w[ #@@1 ] traverses all nodes for example %r{a\ b} traverses all nodes for example f (g rescue nil) traverses all nodes for example Foo = 10 traverses all nodes for example meth do; foo; rescue; bar; end traverses all nodes for example !(foo..bar) traverses all nodes for example case foo; in [x, *, y] then true; end traverses all nodes for example "a\ b" traverses all nodes for example fun! traverses all nodes for example case foo; in "a": then true; end traverses all nodes for example true ? 1.tap do |n| p n end : 0 traverses all nodes for example foo, bar = 1, 2 traverses all nodes for example -foo traverses all nodes for example (foo, bar) = 1, 2 traverses all nodes for example defined? foo traverses all nodes for example case foo; in ** then true; end traverses all nodes for example [1, *foo] traverses all nodes for example fun(1) traverses all nodes for example f{ |;a| } traverses all nodes for example foo[m bar] traverses all nodes for example if foo...bar; end traverses all nodes for example break traverses all nodes for example self::a, foo = foo traverses all nodes for example m [], 1 do end traverses all nodes for example f{ |o=1, *r, p, &b| } traverses all nodes for example <<-'HERE' #@@1 HERE traverses all nodes for example f { || a:b } traverses all nodes for example 42 traverses all nodes for example begin; meth; rescue; baz; else foo; ensure; bar end traverses all nodes for example foo[0, 1] += m foo traverses all nodes for example /source/im traverses all nodes for example def f a, o=1, &b; end traverses all nodes for example def f a, o=1, *r, &b; end traverses all nodes for example m { |foo| } traverses all nodes for example let (:a) { m do; end } traverses all nodes for example %r{#@@1} traverses all nodes for example class << foo; nil; end traverses all nodes for example 'a\ b' traverses all nodes for example f{ |*s| } traverses all nodes for example f{ |a, o=1, o1=2, *r, &b| } traverses all nodes for example meth 1 do end.fun bar do end traverses all nodes for example proc {|_3|} traverses all nodes for example case foo; in "#{ 'a' }": 1 then true; end traverses all nodes for example proc {_1 = nil} traverses all nodes for example case foo; in [x,] then nil; end traverses all nodes when a class defines `on_block_pass` calls it for all block-pass arguments for example foo::A += m foo traverses all nodes for example case foo; in A then true; end traverses all nodes for example f{ |a, o=1, *r, p, &b| } traverses all nodes for example %s{#@1} traverses all nodes for example p <<~E x y E traverses all nodes for example <<-`HERE` a\ b HERE traverses all nodes for example ->{ } traverses all nodes for example 1.. traverses all nodes for example while foo do meth end traverses all nodes for example fun(:foo => 1, &baz) traverses all nodes for example p <<~E x y E traverses all nodes for example case foo; in { a: 1, } then true; end traverses all nodes for example -> do end traverses all nodes for example ->(**nil) {} traverses all nodes for example [1, *foo, 2] traverses all nodes for example f{ |a, *, &b| } traverses all nodes for example +2.0 ** 10 traverses all nodes for example def _5; end traverses all nodes for example a, * = bar traverses all nodes for example @a |= 1 traverses all nodes for example case foo; in x then x; end traverses all nodes for example def String::foo; end traverses all nodes for example meth while foo traverses all nodes for example alias $a $+ traverses all nodes for example def f a, *r, p, &b; end traverses all nodes for example a b{c d}, 1.0 do end traverses all nodes for example %s{a\ b} traverses all nodes for example $10 traverses all nodes for example def f foo: ; end traverses all nodes for example foo ? 1 : 2 traverses all nodes for example foo::Fun() traverses all nodes for example { 'foo': 2 } traverses all nodes for example class A < B end traverses all nodes for example a b(c d), :e do end traverses all nodes for example def f (((a))); end traverses all nodes for example foo[:baz => 1,] traverses all nodes for example def a b: return end traverses all nodes for example foo.a += m foo traverses all nodes for example foo && (a, b = bar) traverses all nodes for example foo[bar,] traverses all nodes for example def f(**); end traverses all nodes for example @@var = 10 traverses all nodes for example f{ |foo: 1, bar: 2, **baz, &b| } traverses all nodes for example %q(foobar) traverses all nodes for example A += 1 traverses all nodes for example for a, b in foo; p a, b; end traverses all nodes for example case foo; in { a: 1 } then true; end traverses all nodes for example foo[bar, :baz => 1,] traverses all nodes for example p begin 1.times do 1 end end traverses all nodes for example ->(a; foo, bar) { } traverses all nodes for example foo::m += raise(bar) rescue nil traverses all nodes for example Bar::Foo traverses all nodes for example def f ((a, *r, p)); end traverses all nodes for example -> (a) { } traverses all nodes for example foo = *bar traverses all nodes for example "#@a #@@a #$a" traverses all nodes for example assert dogs traverses all nodes for example foo[0] += raise bar rescue nil traverses all nodes for example foo::(1) traverses all nodes for example case foo; in "#{ %q{a} }": 1 then true; end traverses all nodes for example fun (1).to_i traverses all nodes for example ->{ } traverses all nodes for example begin ensure end traverses all nodes for example %i[ #@@1 ] traverses all nodes for example p <<~E x \ y E traverses all nodes for example f{ |*r, p, &b| } traverses all nodes for example case foo; in x, then nil; end traverses all nodes for example fun (1) {} traverses all nodes for example foo << 1 traverses all nodes for example foo || bar traverses all nodes for example { 1 => 2 } traverses all nodes for example <<-"HERE" a\ b HERE traverses all nodes for example for a in foo; p a; end traverses all nodes for example "#{-> foo {}}" traverses all nodes for example case foo; in 1, "a", [], {} then nil; end traverses all nodes for example foo | 1 traverses all nodes for example def f ((*, p)); end traverses all nodes for example foo === 1 traverses all nodes for example foo[0, 1] ||= 2 traverses all nodes for example %q{#@@1} traverses all nodes for example /\xa8/n =~ "" traverses all nodes for example m def x(); end; 1.tap do end traverses all nodes for example def f o=1, *r, &b; end traverses all nodes for example if (a, b = foo); end traverses all nodes for example foo.a &&= 1 traverses all nodes for example a b{c(d)}, /x/m do end traverses all nodes for example traverses all nodes for example +42 traverses all nodes for example super() traverses all nodes for example a b(c(d)), 1 do end traverses all nodes for example true traverses all nodes for example case foo; in [*, x] then true; end traverses all nodes for example return fun foo do end traverses all nodes for example foo[1, 2] = 3 traverses all nodes for example 1...2 traverses all nodes for example m { _1 + _9 } traverses all nodes for example f{ || } traverses all nodes for example %I() traverses all nodes for example p <<~"E" x\n y E traverses all nodes for example def f **baz, &b; end traverses all nodes for example foo, bar = m foo traverses all nodes for example while not (true) do end traverses all nodes for example def String; end traverses all nodes for example def (foo).foo; end traverses all nodes for example while def self.foo a = tap do end; end; break; end traverses all nodes for example self.A, foo = foo traverses all nodes for example next() traverses all nodes for example %i[] traverses all nodes for example if foo then bar; else baz; end traverses all nodes for example f{ |o=1, p, &b| } traverses all nodes for example %i[ #@1 ] traverses all nodes for example if /wat/; end traverses all nodes for example ::A += 1 traverses all nodes for example redo traverses all nodes for example fun (f bar) traverses all nodes for example B::A += 1 traverses all nodes for example "foo#{bar}baz" traverses all nodes for example foo.A += 1 traverses all nodes for example foo >= 1 traverses all nodes for example foo = meth rescue bar traverses all nodes for example *, c, d = bar traverses all nodes for example foo + 1 traverses all nodes for example a b(c(d)), 1.0 do end traverses all nodes for example alias :foo bar traverses all nodes for example foo[0, 1] += 2 traverses all nodes for example foo = raise(bar) rescue nil traverses all nodes for example module Bar::Foo; end traverses all nodes for example unless foo; bar; else baz; end traverses all nodes for example fun(*bar, &baz) traverses all nodes for example /#@@1/ traverses all nodes for example %I[#@@1] traverses all nodes for example case foo; in 1 => a then true; end traverses all nodes for example def f *r, &b; end traverses all nodes for example :'#@1' traverses all nodes for example case foo; in [x, *y, z] then true; end traverses all nodes for example def f(foo=1, bar=2); end traverses all nodes for example case foo; in x unless true; nil; end traverses all nodes for example f{ |a,| } traverses all nodes for example def f ((a, a1)); end traverses all nodes for example a b(c(d)), 1.0r do end traverses all nodes for example def f foo = 1; end traverses all nodes for example foo::a += 1 traverses all nodes for example def f a, &b; end traverses all nodes for example f(a ? "a":1) traverses all nodes for example case foo; in a: 1, b: 2 then true; end traverses all nodes for example def foo raise; raise A::B, ''; end traverses all nodes for example %q{a\ b} traverses all nodes for example foo::a += m foo traverses all nodes for example foo "#{(1+1).to_i}" do; end traverses all nodes for example __ENCODING__ traverses all nodes for example <<`HERE` foo bar HERE traverses all nodes for example [ 1, 2 => 3 ] traverses all nodes for example a b{c(d)}, 1.0i do end traverses all nodes for example case foo; in {a: 1 } false ; end traverses all nodes for example f{ |a, *| } traverses all nodes for example def foo a:b end traverses all nodes for example -> do _1 + _9 end traverses all nodes for example while foo; meth end traverses all nodes for example unless foo then bar; else baz; end traverses all nodes for example def String.foo; end traverses all nodes for example %i{a\ b} traverses all nodes for example false ? raise {} : tap {} traverses all nodes for example a += b += raise :x traverses all nodes for example %Q{#@1} traverses all nodes for example foo ^ 1 traverses all nodes for example f <<-TABLE do TABLE end traverses all nodes for example foo.fun (1) {} traverses all nodes for example ->(a) { } traverses all nodes for example def foo(...); end traverses all nodes for example self::A, foo = foo traverses all nodes for example %x{a\ b} traverses all nodes for example foo, bar = meth rescue [1, 2] traverses all nodes for example td (1_500).toString(); td.num do; end traverses all nodes for example foo::a = 1 traverses all nodes for example foo traverses all nodes for example <<-E 1 \ 2 3 E traverses all nodes for example a b(c d), 1 do end traverses all nodes for example foo::fun traverses all nodes for example case foo; in x, *y, z then nil; end traverses all nodes for example %W[#@@1] traverses all nodes for example def f *, **; end traverses all nodes for example if (bar; a, b = foo); end traverses all nodes for example case foo; in **a then true; end traverses all nodes for example p <<~E x y E traverses all nodes for example %w[ #@1 ] traverses all nodes for example fun(1) { } traverses all nodes for example :"a\ b" traverses all nodes for example begin; meth; rescue; foo; end traverses all nodes for example meth (-1.3).abs traverses all nodes for example m do _1 + _9 end traverses all nodes for example case foo; in A() then true; end traverses all nodes for example a # # .foo traverses all nodes for example f{ |a, o=1, &b| } traverses all nodes for example END { 1 } traverses all nodes for example Bar::Foo = 10 traverses all nodes for example class Foo end traverses all nodes for example foo - 1 traverses all nodes for example case foo; in x, y, then nil; end traverses all nodes for example foo[0, 1] &&= 2 traverses all nodes for example while def self.foo; tap do end; end; break; end traverses all nodes for example begin; meth; rescue => @ex; bar; end traverses all nodes for example m a + b do end traverses all nodes for example fun () {} traverses all nodes for example %w[] traverses all nodes for example case foo; when 'bar'; bar; else baz; end traverses all nodes for example class Foo < Bar; end traverses all nodes for example until foo; meth end traverses all nodes for example def BEGIN; end traverses all nodes for example begin; meth; rescue => ex; bar; end traverses all nodes for example case foo; in a:, b: then true; end traverses all nodes for example case foo; in A[1, 2] then true; end traverses all nodes for example def f(foo: 1); end traverses all nodes for example case foo; in x if true; nil; end traverses all nodes for example def f(**foo); end traverses all nodes for example a b{c d}, 1.0r do end traverses all nodes for example p ->() do a() do end end traverses all nodes for example /a\ b/ traverses all nodes for example a += 1 traverses all nodes for example super traverses all nodes for example return foo traverses all nodes for example case foo; in x, y then nil; end traverses all nodes for example f{ |*| } traverses all nodes for example f{ |; a | } traverses all nodes for example case foo; in [*x, y] then true; end traverses all nodes for example break(foo) traverses all nodes for example defined?(foo) traverses all nodes for example %w{a\ b} traverses all nodes for example -> { _1 + _9} traverses all nodes for example f{ |foo: 1, &b| } traverses all nodes for example case foo; in A[x:] then true; end traverses all nodes for example a b(c d), 1.0 do end traverses all nodes for example %Q{a\ b} traverses all nodes for example @foo, @@bar = *foo traverses all nodes for example f{ |*, &b| } traverses all nodes for example case foo; in A::B then true; end traverses all nodes for example false ? raise do end : tap do end traverses all nodes for example f{ |a, b,| } traverses all nodes for example a = b = raise :x traverses all nodes for example foo = bar = m foo traverses all nodes for example yield(foo) traverses all nodes for example case; when foo; 'foo'; end traverses all nodes for example case foo; in 1...2 then true; end traverses all nodes for example case foo; in 1..2 then true; end traverses all nodes for example foo&.bar {} traverses all nodes for example 'foobar' traverses all nodes for example *b, c = bar traverses all nodes for example f{ |a| } traverses all nodes for example `a\ b` traverses all nodes for example p <<~E x y E traverses all nodes for example case foo; in ..2 then true; end traverses all nodes for example module ::Foo; end traverses all nodes for example a = 1; a b: 1 traverses all nodes for example :'a\ b' traverses all nodes for example foo::m += raise bar rescue nil traverses all nodes for example # coding:utf-8 "\xD0\xBF\xD1\x80\xD0\xBE\xD0\xB2\xD0\xB5\xD1\x80\xD0\xBA\xD0\xB0" traverses all nodes for example case foo; when 'bar', 'baz'; bar; end traverses all nodes for example p <<~E x y E traverses all nodes for example case 1; in 2; 3; else; end traverses all nodes for example ...100 traverses all nodes for example class A; _1; end traverses all nodes for example begin; rescue LoadError; else; end traverses all nodes for example m ->(a: ->{_1}) {a} traverses all nodes for example super foo traverses all nodes for example nil traverses all nodes for example begin end traverses all nodes for example foo (-1.3).abs traverses all nodes for example {a: if true then 42 end} traverses all nodes for example case foo; in 1.. then true; end traverses all nodes for example next fun foo do end traverses all nodes for example case foo; in 1... then true; end traverses all nodes for example @foo traverses all nodes for example def x; self::A ||= 1; end traverses all nodes for example m "#{[]}" traverses all nodes for example foo += raise(bar) rescue nil traverses all nodes for example foo.a = 1 traverses all nodes for example meth until foo traverses all nodes for example if foo; bar; elsif baz; 1; else 2; end traverses all nodes for example a &&= 1 traverses all nodes for example <<~E 1 \ 2 3 E traverses all nodes for example fun(*bar) traverses all nodes for example case foo; in a: 1, _a:, ** then true; end traverses all nodes for example %W{a\ b} traverses all nodes for example %I[foo #{bar}] traverses all nodes for example def until; end traverses all nodes for example a b(c d), /x/m do end traverses all nodes for example foo::C ||= raise bar rescue nil traverses all nodes for example case foo; in "#{ 'a' }": then true; end traverses all nodes for example def self.foo; end traverses all nodes for example %I[#@1] traverses all nodes for example f{ |o=1, *r, &b| } traverses all nodes for example '#@@1' traverses all nodes for example def f ((a, *r)); end traverses all nodes for example f{ |foo:| } traverses all nodes for example %Q{#@@1} traverses all nodes for example foo / 1 traverses all nodes for example not foo traverses all nodes for example begin; meth; ensure; bar; end traverses all nodes for example if foo then bar; end traverses all nodes for example "#@@1" traverses all nodes for example %{#@1} traverses all nodes for example module A; _1; end traverses all nodes for example case foo; in {a: 2} false ; end traverses all nodes for example :"#@1" traverses all nodes for example f x: -> do meth do end end traverses all nodes for example foo && bar traverses all nodes for example case foo; in "#{ %Q{a} }": then true; end traverses all nodes for example foo.(1) traverses all nodes for example foo.a += 1 traverses all nodes for example ..100 traverses all nodes for example break foo traverses all nodes for example return(foo) traverses all nodes for example foo[1, 2] = 3 traverses all nodes for example case foo; in *x then nil; end traverses all nodes for example %{a\ b} traverses all nodes for example if (bar); foo; end traverses all nodes for example case 1; in 2; 3; else; 4; end traverses all nodes for example foo || (a, b = bar) traverses all nodes for example foo =~ 1 traverses all nodes for example { 1 => 2, :foo => "bar" } traverses all nodes for example foo != 1 traverses all nodes for example %r{#@1} traverses all nodes for example !(a, b = foo) traverses all nodes for example !m foo traverses all nodes for example case foo; in {} then true; end traverses all nodes for example case foo; in a: 1 then true; end traverses all nodes for example <<-`HERE` #@1 HERE traverses all nodes for example fun(f bar) traverses all nodes for example while def foo; tap do end; end; break; end traverses all nodes for example case foo; in "#{ %q{a} }": then true; end traverses all nodes for example def f a, o=1, p, &b; end traverses all nodes for example def m; class << self; class C; end; end; end traverses all nodes for example foo = bar, 1 traverses all nodes for example foo == 1 traverses all nodes for example case foo; in ...2 then true; end traverses all nodes for example def foo(...); bar(...); end traverses all nodes for example def String=; end traverses all nodes for example "foo#@a" "bar" traverses all nodes for example fun(foo, *bar) traverses all nodes for example if foo; bar; end traverses all nodes for example foo += m foo traverses all nodes for example a ||= 1 traverses all nodes for example !(foo...bar) traverses all nodes for example self.a, self[1, 2] = foo traverses all nodes for example m "#{}#{()}" traverses all nodes when given an unexpected AST with too few children raises debugging error with too many children raises debugging error for example %W[#@1] traverses all nodes for example `foo#{bar}baz` traverses all nodes for example a&.b = 1 traverses all nodes for example case foo; in "#{ %Q{a} }": 1 then true; end traverses all nodes for example def self.m; _1; end traverses all nodes for example p <<~"E" x #{" y"} E traverses all nodes for example def f foo: -1 ; end traverses all nodes for example :'#@@1' traverses all nodes for example yield() traverses all nodes for example ::Foo = 10 traverses all nodes for example t=1;(foo)?t:T traverses all nodes for example foo, bar, baz = 1, 2 traverses all nodes for example -> do rescue; end traverses all nodes for example break() traverses all nodes for example foo.A += m foo traverses all nodes for example [/()\1/, ?#] traverses all nodes for example %{#@@1} traverses all nodes for example m { |**nil| } traverses all nodes for example a b{c d}, :e do end traverses all nodes for example unless foo; bar; end traverses all nodes for example { foo: 2, **bar } traverses all nodes for example fun (1 ) traverses all nodes for example a b(c(d)), /x/m do end traverses all nodes for example begin; meth; rescue Exception, foo; bar; end traverses all nodes for example -> (arg={}) {} traverses all nodes for example '#@1' traverses all nodes for example f{ |a, &b| } traverses all nodes for example begin; meth; rescue; baz; ensure; bar; end traverses all nodes for example meth 1 do end.fun(bar) traverses all nodes for example begin; meth; rescue foo => ex; bar; end traverses all nodes for example <<-`HERE` #@@1 HERE traverses all nodes for example def a; @@var |= 10; end traverses all nodes for example def foo(_a, _a); end traverses all nodes for example def END; end traverses all nodes for example f{ } traverses all nodes for example def f ((*r)); end traverses all nodes for example m [] do end traverses all nodes for example def f ((*r, p)); end traverses all nodes for example a b{c d}, /x/ do end traverses all nodes for example p :foo, {"a": proc do end, b: proc do end} traverses all nodes for example super(foo) traverses all nodes for example foo::Fun bar traverses all nodes for example p -> { :hello }, a: 1 do end traverses all nodes for example <<-'HERE' a\ b HERE traverses all nodes for example f{ |**baz, &b| } traverses all nodes for example meth[] {} traverses all nodes for example ::A, foo = foo traverses all nodes for example def f a, *r, &b; end traverses all nodes for example a = b += raise :x traverses all nodes for example { 'foo': 2, 'bar': {}} traverses all nodes for example * = bar traverses all nodes for example foo <=> 1 traverses all nodes for example def f ((*)); end traverses all nodes for example def f o=1, *r, p, &b; end traverses all nodes for example %W() traverses all nodes for example def f a, o=1, *r, p, &b; end traverses all nodes for example def f (foo: 1, &b); end traverses all nodes for example yield foo traverses all nodes for example a b{c(d)}, 1.0r do end traverses all nodes for example a&.b &&= 1 traverses all nodes for example class Foo; end traverses all nodes for example bar if foo traverses all nodes for example case foo; in ::A then true; end traverses all nodes for example defined? @foo traverses all nodes for example 42.1r traverses all nodes for example foo::fun bar traverses all nodes for example while class << self; a = tap do end; end; break; end traverses all nodes for example %i[foo bar] traverses all nodes for example 42ri traverses all nodes for example 1... traverses all nodes for example <<~FOO baz\ qux FOO traverses all nodes for example a += b = raise :x traverses all nodes for example class Foo < a:b; end traverses all nodes for example while class << self; tap do end; end; break; end traverses all nodes for example a&.b traverses all nodes for example begin; meth; rescue Exception; bar; end traverses all nodes for example :'foo' traverses all nodes for example tap (proc do end) traverses all nodes for example foo.fun bar traverses all nodes for example p <<~"E" x #{foo} E traverses all nodes for example def f o=1, p, &b; end traverses all nodes for example case foo; in self then true; end traverses all nodes for example fun(foo, :foo => 1) traverses all nodes for example while def foo a = tap do end; end; break; end traverses all nodes for example __ENCODING__ traverses all nodes for example _2 = 1 traverses all nodes for example <<-"HERE" #@1 HERE traverses all nodes for example lambda{|;a|a} traverses all nodes for example <<-'HERE' #@1 HERE traverses all nodes for example %q{#@1} traverses all nodes for example %W"#{1}" traverses all nodes for example fun do end traverses all nodes for example a, b = *foo, bar traverses all nodes for example def x; ::A ||= 1; end traverses all nodes for example :foo traverses all nodes for example %W[foo #{bar}] traverses all nodes for example return() traverses all nodes for example def f ; end traverses all nodes for example meth 1 do end.fun {} traverses all nodes for example case foo; in {Foo: 42 } false ; end traverses all nodes for example while class Foo; tap do end; end; break; end traverses all nodes for example case foo; in * then nil; end traverses all nodes for example foo::A = 1 traverses all nodes for example p :foo, {proc do end => proc do end, b: proc do end} traverses all nodes for example case foo; in ->{ 42 } then true; end traverses all nodes for example p <<~E x y E traverses all nodes for example def f(foo:); end traverses all nodes for example a b{c(d)}, /x/ do end traverses all nodes for example case foo; in a: {b:}, c: p c ; end traverses all nodes for example foo += meth rescue bar traverses all nodes for example begin meth end until foo traverses all nodes for example retry traverses all nodes for example module Foo; end traverses all nodes for example for a in foo do p a; end traverses all nodes for example foo.A = 1 traverses all nodes for example fun(:foo => 1) traverses all nodes for example yield traverses all nodes for example `#@1` traverses all nodes for example [ 1 => 2 ] traverses all nodes for example a b{c(d)}, 1 do end traverses all nodes for example a b{c d}, 1 do end traverses all nodes for example 42.1i traverses all nodes for example foo = baz, *bar traverses all nodes for example f{ |a, *s| } traverses all nodes for example m1 :k => m2 do; m3() do end; end traverses all nodes for example case [__FILE__, __LINE__ + 1, __ENCODING__] in [__FILE__, __LINE__, __ENCODING__] end traverses all nodes for example break fun foo do end traverses all nodes for example $+ traverses all nodes for example fun(foo, *bar, &baz) traverses all nodes for example def f o=1, &b; end traverses all nodes for example f{ |a, c| } traverses all nodes for example p <<~E " y" x E traverses all nodes for example ~foo traverses all nodes for example def self._6; end traverses all nodes for example %W[foo #{bar}foo#@baz] traverses all nodes for example o = { a: 1 } traverses all nodes for example meth 1 do end.fun(bar) {} traverses all nodes for example a # # &.foo traverses all nodes for example case foo; in *x, y, z then nil; end traverses all nodes for example Foo traverses all nodes for example `#@@1` traverses all nodes for example self traverses all nodes for example ::Foo traverses all nodes for example m { |(foo, bar)| } traverses all nodes for example def foo(_, _); end traverses all nodes for example a, *, c = bar traverses all nodes for example def x(_4) end traverses all nodes for example def f(*foo); end traverses all nodes for example ->(scope) {}; scope traverses all nodes for example case foo; in ^foo then nil; end traverses all nodes for example bar unless foo traverses all nodes for example a b(c d), /x/ do end traverses all nodes for example foo % 1 traverses all nodes for example case foo; in {a: } true ; end traverses all nodes for example def foo() a:b end traverses all nodes for example proc {_1 = nil} traverses all nodes for example a b{c d}, "x" do end traverses all nodes for example () traverses all nodes for example :"#@@1" traverses all nodes for example -> a: 1 { } traverses all nodes for example def m; class << self; A = nil; end; end traverses all nodes for example @@foo traverses all nodes for example def f(**nil); end traverses all nodes for example a, (b, c) = foo traverses all nodes for example ?a traverses all nodes for example /foo#{bar}baz/ traverses all nodes for example until foo do meth end traverses all nodes for example p p{p(p);p p}, tap do end traverses all nodes for example a b{c(d)}, 1.0 do end traverses all nodes for example fun(&bar) traverses all nodes for example foo.C += raise(bar) rescue nil traverses all nodes for example undef foo, :bar, :"foo#{1}" traverses all nodes for example if foo..bar; end traverses all nodes for example foo & 1 traverses all nodes for example [1, 2] traverses all nodes for example def self::foo; end traverses all nodes for example def f(*); end traverses all nodes for example let () { m(a) do; end } traverses all nodes for example p <<~E x E traverses all nodes for example /#)/x traverses all nodes for example def f &b; end traverses all nodes for example foo.C += raise bar rescue nil traverses all nodes for example a, *b, c = bar traverses all nodes for example super do end traverses all nodes for example a b{c(d)}, "x" do end traverses all nodes for example a @b do |c|;end traverses all nodes for example f{ |a| } traverses all nodes for example a b(c d), "x" do end traverses all nodes for example <<-"HERE" #@@1 HERE traverses all nodes for example case foo; in [x, y,] then true; end traverses all nodes for example foo = raise bar rescue nil traverses all nodes for example case foo; in A(1, 2) then true; end traverses all nodes for example %s{#@@1} traverses all nodes for example %w[foo bar] traverses all nodes for example assert do: true traverses all nodes for example foo[1, 2] traverses all nodes for example %I{a\ b} traverses all nodes for example foo !~ 1 traverses all nodes for example -1.33 traverses all nodes for example /#@1/ traverses all nodes for example case foo; in 1 | 2 then true; end traverses all nodes for example f{ |*s, &b| } traverses all nodes for example f{ |a, *r, p, &b| } traverses all nodes for example desc "foo" do end traverses all nodes for example def foo(...); bar(...); end traverses all nodes for example case; when foo; 'foo'; else 'bar'; end traverses all nodes for example def f (foo: 1, bar: 2, **baz, &b); end traverses all nodes for example not(foo) traverses all nodes for example def foo(...); super(...); end traverses all nodes for example __LINE__ traverses all nodes for example p <<~E x y E traverses all nodes for example 42i traverses all nodes for example fun() { } traverses all nodes for example /#{1}(?bar)/ =~ 'bar' traverses all nodes for example fun (1) traverses all nodes for example case foo; in [x, y, *z] then true; end traverses all nodes for example begin meth end while foo traverses all nodes for example -> * { } traverses all nodes for example def m; class << self; module M; end; end; end traverses all nodes for example bar def foo; self.each do end end traverses all nodes for example def f(&block); end traverses all nodes for example -2.0 ** 10 traverses all nodes for example -> a: { } traverses all nodes for example var = 10; var traverses all nodes for example a b(c(d)), :e do end traverses all nodes for example while class Foo a = tap do end; end; break; end traverses all nodes for example def foo; end traverses all nodes for example return traverses all nodes for example case foo; in "a": 1 then true; end traverses all nodes for example { } traverses all nodes for example "#@1" traverses all nodes for example <<'HERE' foo bar HERE traverses all nodes for example foo::fun (1) {} traverses all nodes for example def f(foo); end traverses all nodes for example -2 ** 10 traverses all nodes for example begin foo!; bar! end traverses all nodes for example meth rescue bar traverses all nodes for example $var = 10 traverses all nodes for example f{ |a, *s, &b| } traverses all nodes for example %x{#@1} traverses all nodes for example def f ((a, *, p)); end traverses all nodes for example case foo; in [x] then nil; end traverses all nodes for example m ->(a = ->{_1}) {a} traverses all nodes for example __FILE__ traverses all nodes for example BEGIN { 1 } traverses all nodes for example fun { } traverses all nodes for example # Extracted from `parser` gem. # Add the following code at the beginning of `def assert_parses`: # # File.open('./out.rb', 'a+') do |f| # f << code << "\n\n#----\n" if versions.include? '2.7' # end alias $a $b traverses all nodes for example def f(foo, bar); end traverses all nodes for example p <<~E x \ y E traverses all nodes for example /(?bar)/ =~ 'bar'; match traverses all nodes for example case foo; in [x, y] then true; end traverses all nodes when a class defines on_arg calls it for all arguments for example `foobar` traverses all nodes for example f{ | | } traverses all nodes for example a b{c(d)}, :e do end traverses all nodes for example case foo; in **nil then true; end traverses all nodes for example _1 traverses all nodes for example fun(foo, :foo => 1, &baz) traverses all nodes for example foo >> 1 traverses all nodes for example case foo; when 'bar'; bar; end traverses all nodes for example foo.m += raise(bar) rescue nil traverses all nodes for example foo.m += raise bar rescue nil traverses all nodes for example 42.1ri traverses all nodes for example p <<~E E traverses all nodes for example foo += raise bar rescue nil traverses all nodes for example p :foo, {:a => proc do end, b: proc do end} traverses all nodes for example not m foo traverses all nodes for example class << foo; _1; end traverses all nodes for example foo::C ||= raise(bar) rescue nil traverses all nodes for example p <<~`E` x #{foo} E traverses all nodes for example foo > 1 traverses all nodes for example 42r traverses all nodes for example false traverses all nodes for example foo = m foo traverses all nodes for example p :foo, {a: proc do end, b: proc do end} traverses all nodes for example a b{c d}, /x/m do end traverses all nodes for example :"foo#{bar}baz" traverses all nodes for example next traverses all nodes for example if foo; bar; else baz; end traverses all nodes for example case foo; when 'bar' then bar; end traverses all nodes for example def f *r, p, &b; end traverses all nodes for example f{ |&b| } traverses all nodes for example case foo; when 1, *baz; bar; when *foo; end traverses all nodes for example a b(c(d)), "x" do end traverses all nodes for example a b(c(d)), /x/ do end traverses all nodes for example f{ |a| } traverses all nodes for example foo <= 1 traverses all nodes for example a ? b & '': nil traverses all nodes for example f{ |a, o=1, p, &b| } traverses all nodes for example meth 1 do end::fun bar traverses all nodes for example -42 traverses all nodes for example case foo; in a: then true; end traverses all nodes for example { foo: 2 } traverses all nodes for example a # # .foo traverses all nodes for example super foo, bar do end traverses all nodes for example p <<~E E traverses all nodes for example unless foo then bar; end traverses all nodes for example fun traverses all nodes for example @@var |= 10 traverses all nodes for example next foo traverses all nodes for example next(foo) traverses all nodes for example a b(c d), 1.0r do end traverses all nodes for example def f ((a, *)); end traverses all nodes for example case foo; in A(x:) then true; end traverses all nodes for example 1..2 traverses all nodes for example %I[foo#{bar}] traverses all nodes for example +foo traverses all nodes for example not() traverses all nodes for example if foo then bar end traverses all nodes for example case foo; in 1; end traverses all nodes for example foo.a ||= 1 traverses all nodes for example begin; meth; rescue; foo; else; bar; end traverses all nodes for example p :foo, {** proc do end, b: proc do end} traverses all nodes for example 1 in [a]; a traverses all nodes for example a b(c d), 1.0i do end traverses all nodes RuboCop::AST::Procarg0Node #name is expected to eq :x .new with a block is expected to be a kind of RuboCop::AST::ArgNode RuboCop::AST::ForNode #post_condition_loop? is expected not to be post condition loop #loop_keyword? is expected to be loop keyword #body is expected to be sym type #do? with a do keyword is expected to be do without a do keyword is expected not to be do #keyword is expected to eq "for" #collection is expected to be sym type .new is expected to be a kind of RuboCop::AST::ForNode #void_context? without a do keyword is expected to be void context with a do keyword is expected to be void context #variable is expected to be lvasgn type RuboCop::AST::ModuleNode #identifier is expected to be const type .new is expected to be a kind of RuboCop::AST::ModuleNode #body with a multi-expression body is expected to be begin type with an empty body is expected to be nil with a single expression body is expected to be send type RuboCop::AST::InPatternNode when using Ruby 2.7 or newer #then? without a then keyword is expected not to be then with a then keyword is expected to be then #branch_index is expected to eq 2 is expected to eq 1 is expected to eq 0 #body without a then keyword is expected to be array type with a then keyword is expected to be sym type #pattern with an alternative pattern is expected to be match alt type with an array pattern is expected to be array pattern type with an as pattern is expected to be match as type with a value pattern is expected to be int type with a pin operator is expected to be pin type with a hash pattern is expected to be hash pattern type with a variable pattern is expected to be match var type .new is expected to be a kind of RuboCop::AST::InPatternNode RuboCop::AST::CaseNode #when_branches is expected to eq 3 is expected to all be when type #else_branch #else? with an else statement is expected to be sym type with an empty else statement is expected to be nil without an else statement is expected to be nil #branches when compared to an IfNode returns the same when there is no else keyword returns only then when bodies when there is an else returns all the bodies with an empty else returns all the bodies .new is expected to be a kind of RuboCop::AST::CaseNode #each_when when passed a block yields all the conditions when not passed a block is expected to be a kind of Enumerator #keyword is expected to eq "case" #else? with an else statement is expected to be else without an else statement is expected not to be else RuboCop::AST::SelfClassNode #identifier is expected to be self type .new is expected to be a kind of RuboCop::AST::SelfClassNode #body with an empty body is expected to be nil with a multi-expression body is expected to be begin type with a single expression body is expected to be send type RuboCop::AST::FloatNode #sign? explicit positive float is expected to be sign explicit negative float is expected to be sign #value is expected to eq 1.5 .new is expected to be a kind of RuboCop::AST::FloatNode RuboCop::AST::NodePattern::Lexer provides tokens via next_token when given a regexp /back\\slash/ round trips when given a regexp /[abc]+\/()?/x round trips when given node types and constants distinguishes them when given arithmetic symbols is parsed as `:&` with $type+ is parsed as `$ int + x` when given a regexp ending with a backslash does not lexes it properly when given a regexp /test/ round trips RuboCop::AST::KeywordSplatNode #hash_rocket? is expected not to be hash rocket .new is expected to be a kind of RuboCop::AST::KeywordSplatNode #key_delta with alignment set to :left when using colon delimiters when keyword splat is aligned is expected to eq 0 when keyword splat is ahead is expected to eq 2 when keyword splat is behind is expected to eq -2 when keyword splat is on the same line is expected to eq 0 when using hash rocket delimiters when keyword splat is aligned is expected to eq 0 when keyword splat is on the same line is expected to eq 0 when keyword splat is behind is expected to eq -2 when keyword splat is ahead is expected to eq 2 with alignment set to :right when using hash rocket delimiters when keyword splat is behind is expected to eq 0 when keyword splat is on the same line is expected to eq 0 when keyword splat is ahead is expected to eq 0 when keyword splat is aligned is expected to eq 0 when using colon delimiters when keyword splat is ahead is expected to eq 0 when keyword splat is aligned is expected to eq 0 when keyword splat is behind is expected to eq 0 when keyword splat is on the same line is expected to eq 0 #operator is expected to eq "**" #same_line? when pairs are on separate lines is expected not to be same line s(:kwsplat, s(:send, nil, :foo)) when a multiline pair shares the same line is expected to be same line s(:kwsplat, s(:send, nil, :foo)) is expected to be same line s(:pair, s(:sym, :a), s(:begin)) when both pairs are on the same line is expected to be same line s(:kwsplat, s(:send, nil, :foo)) #value is expected to eq s(:kwsplat, s(:send, nil, :foo)) #colon? is expected not to be colon #key is expected to eq s(:kwsplat, s(:send, nil, :foo)) #value_delta when using hash rocket delimiters when keyword splat is ahead is expected to eq 0 when keyword splat is behind is expected to eq 0 when keyword splat is left aligned is expected to eq 0 when keyword splat is on the same line is expected to eq 0 when using colon delimiters when keyword splat is behind is expected to eq 0 when keyword splat is on the same line is expected to eq 0 when keyword splat is ahead is expected to eq 0 when keyword splat is left aligned is expected to eq 0 RuboCop::AST::SendNode #receiver with a variable receiver is expected to be send type with no receiver is expected to be nil with a literal receiver is expected to be str type #parenthesized? with no arguments when not using parentheses is expected not to be parenthesized when using parentheses is expected to be parenthesized with arguments when using parentheses is expected to be parenthesized when not using parentheses is expected not to be parenthesized #method? when message does not match when argument is a string is expected not to be method "foo" when argument is a symbol is expected not to be method :foo when message matches when argument is a symbol is expected to be method :bar when argument is a string is expected to be method "bar" #last_argument with multiple mixed arguments is expected to be splat type with a single literal argument is expected to be sym type with multiple literal arguments is expected to be sym type with a single splat argument is expected to be splat type with no arguments is expected to be nil #negation_method? with suffix `not` is expected not to be negation method with prefix bang is expected to be negation method with a non-negated method is expected not to be negation method with prefix `not` is expected to be negation method #implicit_call? with an explicit call method is expected not to be implicit call with an implicit call method is expected to be implicit call with a regular method is expected not to be implicit call #def_modifier? with several prefixed def modifiers is expected to be def modifier with a prefixed def modifier is expected to be def modifier with a block containing a method definition is expected not to be def modifier #def_modifier with call with no argument is expected to be nil with several prefixed def modifiers is expected to eq :qux with a block containing a method definition is expected to be nil with a prefixed def modifier is expected to eq :bar #nonmutating_array_method? with a nonmutating Array method is expected to be nonmutating array method with a regular method is expected not to be nonmutating array method with a mutating Array method is expected not to be nonmutating array method #setter_method? with an indexed setter method is expected to be setter method with a regular method is expected not to be setter method with an operator method is expected not to be setter method with a setter method is expected to be setter method #first_argument with no arguments is expected to be nil with multiple literal arguments is expected to be sym type with multiple mixed arguments is expected to be sym type with a single splat argument is expected to be splat type with a single literal argument is expected to be sym type #lambda? with a stabby lambda method is expected to be lambda with a lambda method is expected to be lambda with a method named lambda in a class is expected not to be lambda with a non-lambda method is expected not to be lambda #const_receiver? with a non-constant receiver is expected not to be const receiver with a self receiver is expected not to be const receiver with a constant receiver is expected to be const receiver #dot? with a unary method is expected not to be dot with a dot is expected to be dot without a dot is expected not to be dot with a double colon is expected not to be dot #predicate_method? with a predicate method is expected to be predicate method with a regular method is expected not to be predicate method with a bang method is expected not to be predicate method #bare_access_modifier? when node is not an access modifier is expected not to be bare access modifier when node is a bare `module_function` is expected to be bare access modifier with Ruby >= 2.7 when node is access modifier in block is expected to be bare access modifier when node is access modifier in numblock is expected to be bare access modifier when node has an argument is expected not to be bare access modifier #splat_argument? with no arguments is expected not to be splat argument with a splat argument is expected to be splat argument with regular arguments is expected not to be splat argument with mixed arguments is expected to be splat argument #unary_operation? with a binary operation is expected not to be unary operation with an implicit call method is expected not to be unary operation with a regular method call is expected not to be unary operation with a unary operation is expected to be unary operation #bang_method? with a bang method is expected to be bang method with a predicate method is expected not to be bang method with a regular method is expected not to be bang method #lambda_literal? with a lambda method is expected not to be lambda literal with a non-lambda method is expected not to be lambda with a stabby lambda is expected to be lambda literal with `a.() {}` style method is expected not to be lambda #command? when argument is a symbol with an implicit receiver is expected to be command :bar with an explicit receiver is expected not to be command :bar when argument is a string with an explicit receiver is expected not to be command "bar" with an implicit receiver is expected to be command "bar" #attribute_accessor? with an accessor returns the accessor method and Array] with a call without arguments is expected to be nil #enumerable_method? with a regular method is expected not to be enumerable method with an enumerable method is expected to be enumerable method #camel_case_method? with a camel case method is expected to be camel case method with a regular method is expected not to be camel case method #binary_operation?? with a binary operation is expected to be binary operation with an implicit call method is expected not to be binary operation with a regular method call is expected not to be binary operation with a unary operation is expected not to be binary operation #operator_method? with a unary operator method is expected to be operator method with a binary operator method is expected to be operator method with a setter method is expected not to be operator method with a regular method is expected not to be operator method #block_argument? with a block argument is expected to be block argument with no arguments is expected not to be block argument with regular arguments is expected not to be block argument with mixed arguments is expected to be block argument #prefix_bang? with keyword `not` is expected not to be prefix bang with a non-negated method is expected not to be prefix bang with a bang method is expected to be prefix bang #macro? without a receiver when in the global scope is expected to be macro when in an if is expected to be macro when parent is a method definition is expected not to be macro when parent is a keyword begin inside of an class is expected to be macro when parent is a module is expected to be macro when parent is a class is expected to be macro when parent is a block not in a macro scope is expected not to be macro with Ruby >= 2.7 when parent is a numblock in a macro scope is expected to be macro when parent is a begin without a parent is expected to be macro when parent is a block in a macro scope is expected to be macro without a parent is expected to be macro when parent is a struct constructor is expected to be macro when the condition of an if is expected not to be macro when parent is a class constructor is expected to be macro when parent is a singleton class is expected to be macro with a receiver when parent is a module is expected not to be macro when parent is a class is expected not to be macro #block_node with a block literal is expected to be block type with Ruby >= 2.7 with a numblock literal is expected to be numblock type with no block is expected to be nil with a block argument is expected to be nil #arguments with no arguments is expected to be empty with multiple literal arguments is expected to eq 2 with a single literal argument is expected to eq 1 with multiple mixed arguments is expected to eq 2 with a single splat argument is expected to eq 1 #nonmutating_hash_method? with a nonmutating Hash method is expected to be nonmutating hash method with a regular method is expected not to be nonmutating hash method with a mutating Hash method is expected not to be nonmutating hash method #prefix_not? with a bang method is expected not to be prefix not with a non-negated method is expected not to be prefix not with keyword `not` is expected to be prefix not #nonmutating_binary_operator_method? with a regular method is expected not to be nonmutating binary operator method with a mutating binary operator method is expected not to be nonmutating binary operator method with a nonmutating binary operator method is expected to be nonmutating binary operator method #post_condition_loop? is expected not to be post condition loop #method_name with a setter method is expected to eq :bar= with an implicit call method is expected to eq :call with an operator method is expected to eq :== with a plain method is expected to eq :bar #access_modifier? when node is not an access modifier is expected not to be bare access modifier when node is a bare `module_function` is expected to be access modifier when node is a non-bare `module_function` is expected to be access modifier #nonmutating_unary_operator_method? with a nonmutating unary operator method is expected to be nonmutating unary operator method with a regular method is expected not to be nonmutating unary operator method #arithmetic_operation? with a binary arithmetic operation is expected to be arithmetic operation with a regular method call is expected not to be arithmetic operation with a unary numeric operation is expected not to be arithmetic operation #block_literal? with no block is expected not to be block literal with a block argument is expected not to be block literal with Ruby >= 2.7 with a numblock literal is expected to be block literal with a block literal is expected to be block literal #nonmutating_string_method? with a regular method is expected not to be nonmutating string method with a mutating String method is expected not to be nonmutating string method with a nonmutating String method is expected to be nonmutating string method #arguments? with no arguments is expected not to be arguments with multiple literal arguments is expected to be arguments with multiple mixed arguments is expected to be arguments with a single splat argument is expected to be arguments with a single literal argument is expected to be arguments #nonmutating_operator_method? with a nonmutating binary operator method is expected to be nonmutating operator method with a mutating binary operator method is expected not to be nonmutating operator method with a regular method is expected not to be nonmutating operator method with a nonmutating unary operator method is expected to be nonmutating operator method #double_colon? without a dot is expected not to be double colon with a double colon is expected to be double colon with a dot is expected not to be double colon with a unary method is expected not to be double colon #comparison_method? with a comparison method is expected to be comparison method with a regular method is expected not to be comparison method with a negation method is expected not to be comparison method #self_receiver? with an implicit receiver is expected not to be self receiver with a self receiver is expected to be self receiver with a non-self receiver is expected not to be self receiver #assignment_method? with a regular method is expected not to be assignment method with a bracket assignment method is expected to be assignment method with an assignment method is expected to be assignment method with a comparison method is expected not to be assignment method #loop_keyword? is expected not to be loop keyword #non_bare_access_modifier? when node is not an access modifier is expected not to be non bare access modifier when node is a non-bare `module_function` is expected to be non bare access modifier when node does not have an argument is expected not to be non bare access modifier .new with a safe navigation method send is expected to be a kind of RuboCop::AST::SendNode with a regular method send is expected to be a kind of RuboCop::AST::SendNode RuboCop::AST::PairNode #delimiter when using a colon delimiter is expected to eq ":" is expected to eq ": " when using a hash rocket delimiter is expected to eq " => " is expected to eq "=>" #same_line? when pairs are on separate lines when both pairs are explicit pairs is expected not to be same line s(:pair, s(:sym, :b), s(:int, 2)) when last pair is a keyword splat is expected not to be same line s(:kwsplat, s(:send, nil, :foo)) when a multiline pair shares the same line when last pair is a keyword splat is expected to be same line s(:pair, s(:sym, :a), s(:begin)) is expected to be same line s(:kwsplat, s(:send, nil, :foo)) when both pairs are explicit pairs is expected to be same line s(:pair, s(:sym, :a), s(:begin)) is expected to be same line s(:pair, s(:sym, :b), s(:int, 2)) when both pairs are on the same line when both pairs are explicit pairs is expected to be same line s(:pair, s(:sym, :b), s(:int, 2)) when both pair is a keyword splat is expected to be same line s(:kwsplat, s(:send, nil, :foo)) .new is expected to be a kind of RuboCop::AST::PairNode #value_omission? when not using hash value omission is expected not to be value omission when using hash value omission is expected to be value omission #value_delta when using hash rocket delimiters when both pairs are on the same line is expected to eq 0 when values are aligned when second pair is a keyword splat is expected to eq 0 when both pairs are explicit pairs is expected to eq 0 when receiver value is behind is expected to eq -2 when receiver value is ahead is expected to eq 2 when using colon delimiters when both pairs are on the same line is expected to eq 0 when receiver value is behind is expected to eq -2 when values are aligned when second pair is a keyword splat is expected to eq 0 when both pairs are explicit pairs is expected to eq 0 when receiver value is ahead is expected to eq 2 #key when using a symbol key is expected to be sym type when using a string key is expected to be str type #key_delta with alignment set to :left when using colon delimiters when receiver key is ahead when second pair is a keyword splat is expected to eq 2 when both pairs are explicit pairs is expected to eq 2 when keys are aligned when second pair is a keyword splat is expected to eq 0 when both pairs are explicit pairs is expected to eq 0 when both keys are on the same line when both pairs are explicit pairs is expected to eq 0 when second pair is a keyword splat is expected to eq 0 when receiver key is behind when second pair is a keyword splat is expected to eq -2 when both pairs are reail pairs is expected to eq -2 when using hash rocket delimiters when both keys are on the same line when second pair is a keyword splat is expected to eq 0 when both pairs are explicit pairs is expected to eq 0 when keys are aligned when second key is a keyword splat is expected to eq 0 when both keys are explicit keys is expected to eq 0 when receiver key is ahead when both pairs are explicit pairs is expected to eq 2 when second pair is a keyword splat is expected to eq 2 when receiver key is behind when second pair is a keyword splat is expected to eq -2 when both pairs are explicit pairs is expected to eq -2 with alignment set to :right when using hash rocket delimiters when receiver key is behind when second pair is a keyword splat is expected to eq 0 when both pairs are explicit pairs is expected to eq -2 when keys are aligned when second key is a keyword splat is expected to eq 0 when both keys are explicit keys is expected to eq 0 when receiver key is ahead when both pairs are explicit pairs is expected to eq 2 when second pair is a keyword splat is expected to eq 0 when both keys are on the same line when second pair is a keyword splat is expected to eq 0 when both pairs are explicit pairs is expected to eq 0 when using colon delimiters when receiver key is behind when both pairs are reail pairs is expected to eq -2 when second pair is a keyword splat is expected to eq 0 when receiver key is ahead when both pairs are explicit pairs is expected to eq 2 when second pair is a keyword splat is expected to eq 0 when both keys are on the same line when both pairs are explicit pairs is expected to eq 0 when second pair is a keyword splat is expected to eq 0 when keys are aligned when second pair is a keyword splat is expected to eq 0 when both pairs are explicit pairs is expected to eq 0 #colon? when using a colon delimiter is expected to be colon when using a hash rocket delimiter is expected not to be colon #hash_rocket? when using a colon delimiter is expected not to be hash rocket when using a hash rocket delimiter is expected to be hash rocket #value is expected to be int type #value_on_new_line? when value spans multiple lines is expected not to be value on new line when value starts on a new line is expected to be value on new line when pair is on a single line is expected not to be value on new line #inverse_delimiter when using a hash rocket delimiter is expected to eq ":" is expected to eq ": " when using a colon delimiter is expected to eq " => " is expected to eq "=>" RuboCop::AST::DefNode #method? when message matches when argument is a symbol is expected to be method :bar when argument is a string is expected to be method "bar" when message does not match when argument is a symbol is expected not to be method :foo when argument is a string is expected not to be method "foo" #bang_method? with a regular method is expected not to be bang method with a bang method is expected to be bang method with a predicate method is expected not to be bang method #predicate_method? with a regular method is expected not to be predicate method with a predicate method is expected to be predicate method with a bang method is expected not to be predicate method #const_receiver? with a class method definition is expected not to be const receiver with a singleton method definition is expected to be const receiver with an instance method definition is expected not to be const receiver when using Ruby 2.7 or newer #argument_forwarding? is expected to be argument forwarding #body with a multi-expression body is expected to be begin type with a single expression body is expected to be send type with no body is expected to be nil #block_argument? with no arguments is expected not to be block argument with regular arguments is expected not to be block argument with a block argument is expected to be block argument with mixed arguments is expected to be block argument #rest_argument? with mixed arguments is expected to be rest argument with a rest argument is expected to be rest argument with no arguments is expected not to be rest argument with regular arguments is expected not to be rest argument #camel_case_method? with a regular method is expected not to be camel case method with a camel case method is expected to be camel case method #assignment_method? with a regular method is expected not to be assignment method with an assignment method is expected to be assignment method with a comparison method is expected not to be assignment method with a bracket assignment method is expected to be assignment method .new with a defs node is expected to be a kind of RuboCop::AST::DefNode with a def node is expected to be a kind of RuboCop::AST::DefNode #self_receiver? with an instance method definition is expected not to be self receiver with a singleton method definition is expected not to be self receiver with a class method definition is expected to be self receiver #arguments with multiple mixed arguments is expected to eq 2 with no arguments is expected to be empty with a single regular argument is expected to eq 1 with a single rest argument is expected to eq 1 with argument forwarding is expected to eq 1 with multiple regular arguments is expected to eq 2 #arguments? with multiple mixed arguments is expected to be arguments with a single keyword argument is expected to be arguments with multiple regular arguments is expected to be arguments with a single regular argument is expected to be arguments with no arguments is expected not to be arguments with a single rest argument is expected to be arguments #last_argument with no arguments is expected to be nil with a single rest argument is expected to be restarg type with multiple mixed arguments is expected to be restarg type with a single keyword argument is expected to be kwoptarg type with multiple regular arguments is expected to be arg type with a single regular argument is expected to be arg type #comparison_method? with a comparison method is expected to be comparison method with a regular method is expected not to be comparison method #operator_method? with a binary operator method is expected to be operator method with a unary operator method is expected to be operator method with a regular method is expected not to be operator method with a setter method is expected not to be operator method #method_name with a setter method is expected to eq :foo= with an operator method is expected to eq :== with a plain method is expected to eq :foo with a unary method is expected to eq :-@ #endless? with standard method definition is expected not to be endless with endless method definition is expected to be endless #void_context? with a bracket assignment method is expected to be void context with a regular assignment method is expected to be void context with a regular method is expected not to be void context with an initializer method is expected to be void context with a comparison method is expected not to be void context #first_argument with no arguments is expected to be nil with multiple regular arguments is expected to be arg type with a single keyword argument is expected to be kwoptarg type with a single rest argument is expected to be restarg type with a single regular argument is expected to be arg type with multiple mixed arguments is expected to be arg type #receiver with an instance method definition is expected to be nil with a singleton method definition is expected to be const type with a class method definition is expected to be self type RuboCop::AST::ProcessedSource #ast is the root node of AST #start_with? with blank source returns false with present source returns false when passed string that does not start source returns true when passed string that starts source #buffer is a source buffer token enumerables #find_token yields correct token yields nil when there is no match #each_token yields all tokens #comments is an array of comments when the source is invalid returns [] #following_line returns source of line after token #[] when a range is passed returns the array of lines when an index is passed returns the line when start index and length are passed returns the array of lines #tokens_within returns tokens for node accepts Node as an argument when heredoc as argument is present returns tokens for node after heredoc returns tokens for heredoc node returns tokens for node before heredoc #parser_error when the source was properly parsed is nil when the source could not be parsed due to encoding error returns the error when the source lacks encoding comment and is really utf-8 encoded but has been read as US-ASCII is nil valid_syntax? when the source could not be parsed due to encoding error returns false when the source is invalid returns false when the source is valid but has some warning diagnostics returns true when the source itself is valid encoding but includes strange encoding literals that are accepted by MRI returns true when a line starts with an integer literal tokenizes the source correctly when the source is completely valid returns true #tokens has an array of tokens #preceding_line returns source of line before token with heavily commented source #comment_at_line returns nil if line has no comment returns the comment at the given line number #find_comment yields nil when there is no match yields correct comment #each_comment yields all comments #contains_comment? provided source_range on line without comment is expected to equal false provided a multiline source_range with at least one line with comment is expected to equal true provided source_range on line with comment is expected to equal true provided source_range on comment line is expected to equal true #comments_before_line returns comments on or before given line #line_with_comment? returns true for lines with comments returns false for lines without comments #each_comment_in_lines yields the comments #lines has same number of elements as line count is an array contains lines as string without linefeed #blank? with source of no content returns true with source with content returns false #path is the path passed to .new #first_token_of returns first token for node accepts Node as an argument .from_file raises a Errno::ENOENT when the file does not exist when the file exists sets the file path to the instance's #path returns an instance of ProcessedSource #file_path returns file path #last_token_of returns last token for node accepts Node as an argument RuboCop::AST::DefinedNode #receiver is expected to be nil #arguments is expected to eq 1 is expected to all be sym type #method_name is expected to eq :defined? .new with a defined? node is expected to be a kind of RuboCop::AST::DefinedNode RuboCop::AST::ResbodyNode .new is expected to be a kind of RuboCop::AST::ResbodyNode #exception_variable for an implicit rescue is expected to eq "ex" when an exception variable is not given is expected to be nil for an explicit rescue is expected to eq "ex" #branch_index is expected to eq 2 is expected to eq 1 is expected to eq 0 #exceptions with a single exception is expected to eq 1 is expected to all be const type with multiple exceptions is expected to eq 2 is expected to all be const type without exception is expected to eq 0 #body is expected to be sym type RuboCop::AST::HashNode #values with a hash with string keys is expected to eq 2 is expected to all be send type with an empty hash is expected to be empty with a hash with literal values is expected to eq 3 is expected to all be literal #each_pair when not passed a block is expected to be a kind of Enumerator when passed a block yields all the pairs #mixed_delimiters? when all pairs are using a colon delimiter is expected not to be mixed delimiters when pairs are using different delimiters is expected to be mixed delimiters when all pairs are using a hash rocket delimiter is expected not to be mixed delimiters #braces? with braces is expected to be braces as an argument with no braces is expected not to be braces as an argument with braces is expected to be braces #each_value when not passed a block is expected to be a kind of Enumerator when passed a block yields all the pairs .new is expected to be a kind of RuboCop::AST::HashNode #pairs_on_same_line? with some pairs on the same line is expected to be pairs on same line with all pairs on the same line is expected to be pairs on same line with no pairs on the same line is expected not to be pairs on same line #keys with an empty hash is expected to be empty with a hash with symbol keys is expected to all be sym type is expected to eq 3 with a hash with string keys is expected to eq 2 is expected to all be str type #pairs with an empty hash is expected to be empty with a hash of variables is expected to all be pair type is expected to eq 2 with a hash of literals is expected to all be pair type is expected to eq 3 #each_key when passed a block yields all the pairs when not passed a block is expected to be a kind of Enumerator #empty? with an empty hash is expected to be empty with a hash containing a keyword splat is expected not to be empty with a hash containing pairs is expected not to be empty RuboCop::AST::ClassNode .new is expected to be a kind of RuboCop::AST::ClassNode #body with a single expression body is expected to be send type with a multi-expression body is expected to be begin type with an empty body is expected to be nil #parent_class when no parent class is specified is expected to be nil when a parent class is specified is expected to be const type #identifier is expected to be const type RuboCop::AST::NodePattern caret (ascend) within sequence not in head is expected to match code s(:int, 1) and :inc of a sequence is expected to match code s(:int, 1) and :inc in head is expected to match code 1 of a sequence is expected to match code 1 inside a union is expected to match code "abc" used with a node type which matches is expected to match code 1 which doesn't match behaves like nonmatching doesn't match repeated twice is expected to match code 1 using unification to match self within parent with self in the wrong position behaves like nonmatching doesn't match with self in the right position is expected to match code 2 inside an intersection is expected to match code 1 descend with a match multiple levels, depth first behaves like single capture returns captured values if there is no block yields captured value(s) and returns true if there is a block with an immediate match behaves like single capture returns captured values if there is no block yields captured value(s) and returns true if there is a block without match behaves like nonmatching doesn't match nested behaves like single capture returns captured values if there is no block yields captured value(s) and returns true if there is a block with a literal match is expected to match code s(:int, 1) and s(:array, s(:array, s(:int, 2), s(:int, 3), s(:array, s(:array, s(:int, 5)))), s(:int, 4)) in any order with a captured ellipsis nested behaves like multiple capture returns captured values if there is no block yields captured value(s) and returns true if there is a block matching all children behaves like single capture yields captured value(s) and returns true if there is a block returns captured values if there is no block matching non sequential children behaves like single capture yields captured value(s) and returns true if there is a block returns captured values if there is no block captured without ellipsis behaves like single capture returns captured values if there is no block yields captured value(s) and returns true if there is a block without ellipsis with too few children behaves like nonmatching doesn't match with too many children behaves like nonmatching doesn't match with matching children behaves like multiple capture yields captured value(s) and returns true if there is a block returns captured values if there is no block with an ellipsis behaves like single capture yields captured value(s) and returns true if there is a block returns captured values if there is no block invalid nested behaves like invalid is invalid doubled with ellipsis in wrong order behaves like nonmatching doesn't match with an ellipsis inside and outside behaves like multiple capture yields captured value(s) and returns true if there is a block returns captured values if there is no block doubled with ellipsis behaves like multiple capture yields captured value(s) and returns true if there is a block returns captured values if there is no block at the beginning of a sequence behaves like invalid is invalid containing ellipsis not at the end behaves like invalid is invalid doubled separated by an ellipsis behaves like multiple capture returns captured values if there is no block yields captured value(s) and returns true if there is a block separated by fixed argument behaves like multiple capture yields captured value(s) and returns true if there is a block returns captured values if there is no block captures on ... with a remaining sequence at the end behaves like single capture returns captured values if there is no block yields captured value(s) and returns true if there is a block with a remaining set at the end behaves like single capture yields captured value(s) and returns true if there is a block returns captured values if there is no block with a remaining [] at the end behaves like single capture yields captured value(s) and returns true if there is a block returns captured values if there is no block with a remaining wildcard at the end behaves like single capture yields captured value(s) and returns true if there is a block returns captured values if there is no block after a child behaves like single capture returns captured values if there is no block yields captured value(s) and returns true if there is a block with no remaining pattern at the end behaves like single capture yields captured value(s) and returns true if there is a block returns captured values if there is no block with a remaining literal at the end behaves like single capture yields captured value(s) and returns true if there is a block returns captured values if there is no block with a remaining capture at the end behaves like multiple capture returns captured values if there is no block yields captured value(s) and returns true if there is a block with a remaining node type at the end behaves like single capture returns captured values if there is no block yields captured value(s) and returns true if there is a block with remaining patterns at the end behaves like single capture yields captured value(s) and returns true if there is a block returns captured values if there is no block at the very beginning of a sequence behaves like single capture returns captured values if there is no block yields captured value(s) and returns true if there is a block bad syntax with variadic unions where not supported behaves like invalid is invalid with unmatched opening paren and `...` behaves like invalid is invalid with leading comma in arg list behaves like invalid is invalid with doubled ellipsis is expected to match code "foo" with negated closing paren behaves like invalid is invalid with negated closing curly behaves like invalid is invalid with unmatched closing curly behaves like invalid is invalid with unmatched closing paren behaves like invalid is invalid with doubled comma in arg list behaves like invalid is invalid with empty intersection behaves like invalid is invalid with empty union subsequence in seq head behaves like invalid is invalid with negated ellipsis behaves like invalid is invalid with empty union behaves like invalid is invalid with unmatched opening paren behaves like invalid is invalid with empty parentheses behaves like invalid is invalid with unsupported subsequence in seq head within union behaves like invalid is invalid with unmatched opening curly behaves like invalid is invalid bare node type #to_s is instructive #== returns true iff the patterns are similar #dup is expected to match code s(:send, nil, :obj) and :method on a node with a matching, hyphenated type is expected to match code s(:lvasgn, :a), :+, and s(:int, 1) yaml compatibility is expected to match code s(:send, nil, :obj) and :method #pattern returns the pattern on a node with a different type behaves like nonmatching doesn't match marshal compatibility is expected to match code s(:send, nil, :obj) and :method on a node with the same type is expected to match code s(:send, nil, :obj) and :method wildcards named wildcards within a union confined to the union with partial unification that can not be unified behaves like nonmatching doesn't match matching the free branch is expected to match code s(:int, 2) and s(:int, 1) matching the unified branch is expected to match code s(:int, 5) and s(:int, 5) without unification is expected to match code s(:int, 2) and s(:int, 1) with a succeeding unifying constraint with all branches with the wildcard matching the first branch is expected to match code s(:array, s(:int, 1), s(:int, 2)) and s(:int, 2) matching another branch is expected to match code s(:array, s(:int, 2), s(:int, 1)) and s(:int, 2) that can not be unified behaves like nonmatching doesn't match with branches without the wildcard encountered first behaves like invalid is invalid encountered after behaves like invalid is invalid with a preceding unifying constraint matching a branch is expected to match code s(:int, 2) and s(:array, s(:int, 2), s(:int, 1)) that can not be unified behaves like nonmatching doesn't match at the root level is expected to match code s(:sclass, s(:self), s(:def, :something, s(:args), s(:int, 1))) and :freeze in head position of a sequence is expected to match code s(:int, 1), :+, and s(:send, nil, :a) within a sequence with values which can be unified is expected to match code s(:int, 5), :+, and s(:int, 5) with values which cannot be unified behaves like nonmatching doesn't match unifying the node type with an argument is expected to match code s(:send, nil, :obj) and :send within a sequence with other patterns intervening is expected to match code :@abc and s(:int, 22) unnamed wildcards within a sequence with other patterns intervening is expected to match code :@abc and s(:int, 22) within a sequence is expected to match code nil and :Const negated behaves like nonmatching doesn't match at the root level is expected to match code s(:sclass, s(:self), s(:def, :something, s(:args), s(:int, 1))) and :freeze in head position of a sequence is expected to match code s(:int, 1), :+, and s(:send, nil, :a) node type in seq head on a child with a different type behaves like nonmatching doesn't match on a node with the same type is expected to match code s(:ivar, :@ivar), :+, and s(:int, 2) for a child on a child with the same type is expected to match code s(:send, nil, :foo) and :bar on a child with a different type behaves like nonmatching doesn't match on a child litteral behaves like nonmatching doesn't match regexp matches symbols or strings macros with a pattern with a constant is expected to match code :hello when the value is not in the set behaves like nonmatching doesn't match with a pattern without captures def_node_matcher returns the method name when called on matching code is expected to match code :hello when it errors raises an error with the right location when called on non-matching code behaves like nonmatching doesn't match def_node_search returns the method name with a predicate name when called on matching code is expected to match code nil, :foo, s(:sym, :hello), and s(:sym, :world) when called on non-matching code behaves like nonmatching doesn't match when it errors raises an error with the right location without a predicate name when it errors raises an error with the right location when called on matching code returns an enumerator yielding the matches when called on non-matching code returns an enumerator yielding nothing with a pattern with a namespaced call is expected to match code :hello when the value is not in the set behaves like nonmatching doesn't match with a pattern with captures def_node_search with a predicate name when called on matching code is expected to match code nil, :foo, s(:sym, :hello), and s(:sym, :world) when it errors raises an error with the right location when called on non-matching code behaves like nonmatching doesn't match without a predicate name when called on matching code returns an enumerator yielding the captures when the pattern contains keyword_params returns an enumerator yielding the captures when helper is called with default keyword_params is overridden when calling the matcher some defaults are not params raises an error and no value is given to the matcher uses the defaults when called on non-matching code returns an enumerator yielding nothing when it errors raises an error with the right location def_node_matcher when called on matching code is expected to eq :hello when called on non-matching code behaves like nonmatching doesn't match when it errors raises an error with the right location params as named parameters when not provided raises an ArgumentError when extra are provided raises an ArgumentError when provided as argument to match is expected to match code s(:int, 10) and {:foo=>#} when inside a union, with a matching value is expected to match code s(:int, 10) and 10 param number zero in a position which does not match original target node behaves like nonmatching doesn't match in a position which matches original target node is expected to match code 1 when negated, with a matching value behaves like nonmatching doesn't match when negated, with a nonmatching value is expected to match code s(:const, s(:const, nil, :Namespace), :B) and :A when inside a union, with a nonmatching value behaves like nonmatching doesn't match when preceded by ... is expected to match code s(:send, s(:int, 1), :+, s(:int, 10)) and s(:int, 10) when preceded by $... behaves like single capture yields captured value(s) and returns true if there is a block returns captured values if there is no block in root position is expected to match code s(:int, 10) and s(:int, 10) in root position is expected to match code s(:int, 10) and # when captured behaves like single capture yields captured value(s) and returns true if there is a block returns captured values if there is no block when inside an intersection is expected to match code s(:int, 20), 10, and 20 in a nested sequence is expected to match code s(:send, s(:send, s(:int, 5), :dec), :inc), :inc, and :dec without explicit number is expected to match code s(:const, s(:const, nil, :Namespace), :A), :A, and s(:const, nil, :Namespace) negation on a set with a matching value behaves like nonmatching doesn't match with a non-matching value is expected to match code :@a and s(:int, 3) on a symbol with a non-matching symbol, but too many children behaves like nonmatching doesn't match with a non-matching symbol is expected to match code s(:send, nil, :obj) and :xyz with a matching symbol behaves like nonmatching doesn't match on a string with a matching string behaves like nonmatching doesn't match with a non-matching symbol is expected to match code s(:str, "bar") and :upcase when nested in complex ways with (send str :+ (send str :to_i)) is expected to match code s(:str, "abc"), :+, and s(:send, s(:str, "1"), :to_i) with (send str :<< str) behaves like nonmatching doesn't match with (send int :- int) is expected to match code s(:int, 1), :-, and s(:int, 1) on square brackets with a node which meets only 1 requirement of [] is expected to match code 1 with a node which meets all requirements of [] behaves like nonmatching doesn't match on a sequence with a node of different type is expected to match code :@@a and s(:int, 1) with a matching node behaves like nonmatching doesn't match with a node with non-matching children is expected to match code :@b and s(:int, 1) ellipsis preceding a capture behaves like single capture yields captured value(s) and returns true if there is a block returns captured values if there is no block with a nodetype at the end, but no remaining child to match it behaves like nonmatching doesn't match with a set at the end, but no remaining child to match it behaves like nonmatching doesn't match preceding multiple captures behaves like multiple capture yields captured value(s) and returns true if there is a block returns captured values if there is no block with a wildcard at the end, but no remaining child to match it behaves like nonmatching doesn't match with [] at the end, but no remaining child to match it behaves like nonmatching doesn't match at the very beginning of a sequence is expected to match code s(:int, 10), :*, and s(:int, 1) with a nested sequence at the end, but no remaining child behaves like nonmatching doesn't match repeated using + with zero match behaves like nonmatching doesn't match behaves like repeated pattern with an ellipsis in the same sequence is expected to match code "[:hello, 1, 2, 3]" with one match behaves like single capture yields captured value(s) and returns true if there is a block returns captured values if there is no block at beginning of sequence behaves like invalid is invalid with matching children behaves like single capture yields captured value(s) and returns true if there is a block returns captured values if there is no block using ? with zero match behaves like single capture yields captured value(s) and returns true if there is a block returns captured values if there is no block with too many matching children behaves like nonmatching doesn't match behaves like repeated pattern with one match behaves like single capture yields captured value(s) and returns true if there is a block returns captured values if there is no block with an ellipsis in the same sequence is expected to match code "[:hello, 1, 2, 3]" at beginning of sequence behaves like invalid is invalid using * with no match behaves like nonmatching doesn't match behaves like repeated pattern with one match behaves like single capture returns captured values if there is no block yields captured value(s) and returns true if there is a block with an ellipsis in the same sequence is expected to match code "[:hello, 1, 2, 3]" at beginning of sequence behaves like invalid is invalid with multiple subcaptures behaves like multiple capture yields captured value(s) and returns true if there is a block returns captured values if there is no block without capture is expected to match code s(:sym, :hello), s(:int, 1), s(:int, 2), and s(:int, 3) with matching children behaves like single capture yields captured value(s) and returns true if there is a block returns captured values if there is no block nested with multiple subcaptures behaves like multiple capture yields captured value(s) and returns true if there is a block returns captured values if there is no block with zero match behaves like single capture returns captured values if there is no block yields captured value(s) and returns true if there is a block funcalls without extra arguments is expected to match code :a and s(:int, 1) with one argument is expected to match code s(:str, "foo") and "foo" with multiple arguments is expected to match code s(:str, "c"), "a", and "d" comments behaves like single capture returns captured values if there is no block yields captured value(s) and returns true if there is a block commas with commas randomly strewn around behaves like invalid is invalid unions nested inside a sequence is expected to match code s(:const, nil, :Const) and :method variadic multiple works for complex cases with variadic terms works for cases with fixed arity before and after union works for cases with variadic terms after union works for cases with variadic terms before and after union with fixed terms works for cases with fixed arity before and after union works for cases with variadic terms before and after union works for cases with variadic terms after union with a nested sequence is expected to match code s(:const, nil, :Const) and :method at the top level containing string literals is expected to match code s(:str, "a") and :upcase containing mixed node and literals is expected to match code nil and :obj containing multiple [] on a node which meets some requirements but not all behaves like nonmatching doesn't match on a node which meets all requirements of the second [] is expected to match code 2.4 on a node which meets all requirements of the first [] is expected to match code 3 containing symbol literals when the AST does not have a matching symbol behaves like nonmatching doesn't match when the AST has a matching symbol is expected to match code s(:send, nil, :obj) and :b containing integer literals is expected to match code s(:int, 10) and :abs sequence with trailing ... on a node with non-matching children behaves like nonmatching doesn't match on a node with the same type and fewer children behaves like nonmatching doesn't match on a node with a different type behaves like nonmatching doesn't match on a node with the same type and more children with 2 children more is expected to match code s(:int, 1), :blah, s(:int, 1), and s(:sym, :something) with 1 child more is expected to match code s(:int, 1), :blah, and s(:int, 1) on a node with fewer children, with a wildcard preceding behaves like nonmatching doesn't match on a node with the same type and exact number of children is expected to match code s(:int, 1) and :blah captures which also perform a match on a sequence behaves like single capture returns captured values if there is no block yields captured value(s) and returns true if there is a block on a literal behaves like single capture yields captured value(s) and returns true if there is a block returns captured values if there is no block on a set behaves like single capture yields captured value(s) and returns true if there is a block returns captured values if there is no block on a node type behaves like single capture yields captured value(s) and returns true if there is a block returns captured values if there is no block on [] behaves like single capture returns captured values if there is no block yields captured value(s) and returns true if there is a block when nested behaves like multiple capture yields captured value(s) and returns true if there is a block returns captured values if there is no block captures within union with a different number of captures in each branch behaves like invalid is invalid with complex nesting behaves like multiple capture yields captured value(s) and returns true if there is a block returns captured values if there is no block within nested sequences behaves like multiple capture returns captured values if there is no block yields captured value(s) and returns true if there is a block on simple subpatterns behaves like single capture yields captured value(s) and returns true if there is a block returns captured values if there is no block nil nil literals is expected to match code against a node pattern (bug #5470) behaves like nonmatching doesn't match nil value in AST behaves like nonmatching doesn't match nil value in AST, use nil? method is expected to match code nil and :foo simple sequence on a node with the same type and non-matching children with non-matching receiver type behaves like nonmatching doesn't match with non-matching selector behaves like nonmatching doesn't match on a node with the same type and matching children is expected to match code s(:int, 1), :+, and s(:int, 1) with a nested sequence in non-head position is expected to match code s(:send, s(:send, nil, :obj), :a) and :b on a node with too many children behaves like nonmatching doesn't match on a node with a different type behaves like nonmatching doesn't match with a nested sequence in head position behaves like invalid is invalid literals double quoted string literals is expected to match code "foo" bare literal on a matching literal is expected to match code :bar on a node behaves like nonmatching doesn't match single quoted string literals is expected to match code "foo" positive float literals is expected to match code 1.0 negative float literals is expected to match code -2.5 symbol literals is expected to match code :foo negative integer literals is expected to match code -100 .descend yields all children depth first yields the given argument if it is not a Node captures on a wildcard in head position in a sequence against nil (bug #5470) behaves like nonmatching doesn't match in non-head position in a sequence behaves like single capture yields captured value(s) and returns true if there is a block returns captured values if there is no block in a nested sequence behaves like single capture returns captured values if there is no block yields captured value(s) and returns true if there is a block at the root level behaves like single capture returns captured values if there is no block yields captured value(s) and returns true if there is a block nested in any child behaves like multiple capture returns captured values if there is no block yields captured value(s) and returns true if there is a block in head position in a sequence against literal (bug #5470) behaves like nonmatching doesn't match in head position in a sequence behaves like single capture yields captured value(s) and returns true if there is a block returns captured values if there is no block predicates when negated is expected to match code s(:int, 1) and :inc with an expression argument for which the predicate is false behaves like nonmatching doesn't match for which the predicate is true is expected to match code s(:int, 2), :+, and s(:float, 2.0) applied to an integer for which the predicate is false behaves like nonmatching doesn't match with multiple arguments for which the predicate is false behaves like nonmatching doesn't match for which the predicate is true is expected to match code s(:str, "c"), "a", and "d" at head position of a sequence is expected to match code s(:int, 1) and :inc with a named argument for which the predicate is true is expected to match code s(:send, s(:int, 1), :+, s(:int, 2)) and {:param=>1} when not given raises an error with extra arguments raises an error for which the predicate is false behaves like nonmatching doesn't match applied to an integer for which the predicate is true is expected to match code s(:int, 1) and :inc with a constant argument for which the predicate is true is expected to match code s(:int, 1), :+, and s(:int, 2) for which the predicate is false behaves like nonmatching doesn't match with one extra argument for which the predicate is true is expected to match code s(:send, s(:int, 1), :+, s(:int, 2)) and 1 for which the predicate is false behaves like nonmatching doesn't match when captured behaves like single capture yields captured value(s) and returns true if there is a block returns captured values if there is no block in root position is expected to match code s(:int, 1) and :inc with name containing a numeral is expected to match code s(:int, 1) and :inc when in last-child position, but all children have already been matched behaves like nonmatching doesn't match RuboCop::AST::ArgNode #name with an optional argument is expected to eq :x with a nameless double splatted argument is expected to be nil with a regular argument is expected to eq :x with an optional keyword argument is expected to eq :x with a nameless splatted argument is expected to be nil with a keyword argument is expected to eq :x with a double splatted argument is expected to eq :x with argument forwarding with Ruby >= 2.7 is expected to be nil with Ruby >= 3.0 is expected to be nil with a block argument is expected to eq :x with a block is expected to eq :x with a shadow argument is expected to eq :x with a splatted argument is expected to eq :x #default? with an optional keyword argument is expected to equal true with a shadow argument is expected to equal false with a block is expected to equal false with argument forwarding with Ruby >= 3.0 is expected to equal false with Ruby >= 2.7 is expected to equal false with a regular argument is expected to equal false with a splatted argument is expected to equal false with a double splatted argument is expected to equal false with a block argument is expected to equal false with an optional argument is expected to equal true #default_value with a block is expected to be nil with argument forwarding with Ruby >= 2.7 is expected to be nil with Ruby >= 3.0 is expected to be nil with a regular argument is expected to be nil with an optional keyword argument is expected to eq s(:int, 42) with an optional argument is expected to eq s(:int, 42) with a splatted argument is expected to be nil with a block argument is expected to be nil with a shadow argument is expected to be nil with a double splatted argument is expected to be nil .new with a double splatted argument is expected to be a kind of RuboCop::AST::ArgNode with a block argument is expected to be a kind of RuboCop::AST::ArgNode with a lambda literal is expected to be a kind of RuboCop::AST::ArgNode with an optional argument is expected to be a kind of RuboCop::AST::ArgNode with a shadow argument is expected to be a kind of RuboCop::AST::ArgNode with an optional keyword argument is expected to be a kind of RuboCop::AST::ArgNode with a method definition is expected to be a kind of RuboCop::AST::ArgNode with a block is expected to be a kind of RuboCop::AST::ArgNode with a splatted argument is expected to be a kind of RuboCop::AST::ArgNode with argument forwarding with Ruby >= 2.7 is expected to be a kind of RuboCop::AST::ArgNode with Ruby >= 3.0 is expected to be a kind of RuboCop::AST::ArgNode with a keyword argument is expected to be a kind of RuboCop::AST::ArgNode RuboCop::AST::LambdaNode #method_name is expected to eq :lambda #receiver is expected to be nil #arguments is expected to eq 2 RuboCop::AST::ArrayNode #square_brackets? with square brackets is expected to be square brackets with a percent literal is expected not to be square brackets .new is expected to be a kind of RuboCop::AST::ArrayNode #each_value without block is expected to be a kind of Enumerator with block is expected to be a kind of RuboCop::AST::ArrayNode is expected to eq ["(int 1)", "(int 2)", "(int 3)"] #bracketed? with square brackets is expected to be bracketed unbracketed is expected to be nil with a percent literal is expected to be bracketed #values with an empty array is expected to be empty with an array of variables is expected to all be send type is expected to eq 2 with an array of literals is expected to all be literal is expected to eq 3 #percent_literal? with a string percent literal is expected to be percent literal is expected not to be percent literal :symbol is expected to be percent literal :string with a symbol percent literal is expected not to be percent literal :string is expected to be percent literal is expected to be percent literal :symbol with square brackets is expected not to be percent literal :symbol is expected not to be percent literal :string is expected not to be percent literal RuboCop::AST::UntilNode #do? without a do keyword is expected not to be do with a do keyword is expected to be do #loop_keyword? with a modifier until is expected to be loop keyword with a statement until is expected to be loop keyword .new with a statement until is expected to be a kind of RuboCop::AST::UntilNode with a modifier until is expected to be a kind of RuboCop::AST::UntilNode #post_condition_loop? with a statement until is expected not to be post condition loop with a modifier until is expected to be post condition loop #inverse_keyword is expected to eq "while" #keyword is expected to eq "until" RuboCop::AST::ReturnNode behaves like wrapped arguments node .new without arguments is expected to be a kind of RuboCop::AST::ReturnNode with arguments is expected to be a kind of RuboCop::AST::ReturnNode #arguments with multiple literal arguments is expected to eq 2 with a single splat argument is expected to eq 1 with no arguments is expected to be empty with a single argument and braces is expected to eq 1 with no arguments and braces is expected to be empty with a single argument is expected to eq 1 RuboCop::AST::NextNode behaves like wrapped arguments node .new with arguments is expected to be a kind of RuboCop::AST::NextNode without arguments is expected to be a kind of RuboCop::AST::NextNode #arguments with multiple literal arguments is expected to eq 2 with a single argument and braces is expected to eq 1 with no arguments is expected to be empty with no arguments and braces is expected to be empty with a single argument is expected to eq 1 with a single splat argument is expected to eq 1 RuboCop::AST::ConstNode #namespace is expected to eq "::Foo::Bar" #relative? with a non-namespaced constant is expected to be relative #short_name is expected to eq :BAZ #each_path yields all parts of the namespace #module_name? is expected not to be module name with a constant with a lowercase letter is expected to be module name #absolute? is expected to be absolute with a non-namespaced constant is expected not to be absolute with a constant not starting with :: is expected not to be absolute RuboCop::AST::CaseMatchNode when using Ruby 2.7 or newer #branches when there is no else keyword returns only then when bodies when there is an else with else body returns all the bodies with empty else returns all the bodies #in_pattern_branches is expected to eq 3 is expected to all be in pattern type #each_in_pattern when not passed a block is expected to be a kind of Enumerator when passed a block yields all the conditions #else_branch #else? without an else statement is expected to be nil with an empty else statement is expected to be empty else type with an else statement is expected to be sym type #else? without an else statement is expected not to be else with an else statement is expected to be else #keyword is expected to eq "case" .new is expected to be a kind of RuboCop::AST::CaseMatchNode RuboCop::AST::OrNode .new with a logical or node is expected to be a kind of RuboCop::AST::OrNode with a semantic or node is expected to be a kind of RuboCop::AST::OrNode #lhs with a semantic or node is expected to be sym type with a logical or node is expected to be sym type #rhs with a logical or node is expected to be int type with a semantic or node is expected to be int type #inverse_operator with a semantic or node is expected to eq "and" with a logical or node is expected to eq "&&" #operator with a semantic or node is expected to eq "or" with a logical or node is expected to eq "||" #logical_operator? with a semantic or node is expected not to be logical operator with a logical or node is expected to be logical operator #semantic_operator? with a semantic or node is expected to be semantic operator with a logical or node is expected not to be semantic operator #alternate_operator with a logical or node is expected to eq "or" with a semantic or node is expected to eq "||" RuboCop::AST::Node #pure? for an array literal which contains a method call returns false with only literal children returns true for a gvar assignment returns false for an ivar assignment returns false for a regexp with options returns true with no interpolation returns true with interpolated segments returns false for a nested if where the innermost descendants are local vars and literals returns true where one branch contains an assignment statement returns false where one branch contains a method call returns false for an integer literal returns true for a cvar assignment returns false for a class definition returns false for a method call returns false for a hash literal which contains a method call returns false with only literal children returns true for an lvar assignment returns false for a module definition returns false #argument_type? block arguments returns true for all argument types method arguments returns true for all argument types #value_used? within a module definition node is always true within a while node is true only for the condition within a singleton class node is always true at the end of a block is always true within an array literal at the top level is always false assigned to an ivar is always true within a class definition node is always true within an if...else..end node nested in a method call is always true at the top level is true only for the condition at the top level is false within a method call node is always true #class_constructor? module definition with a block matches class definition with a block matches class definition does not match class definition on outer scope matches #conditional? when `case_match` node is true when `until` node is true when post condition loop node is false when `case` node is true when `while` node is true when `if` node is true #class_definition? without inheritance matches with self singleton class matches constant defined as Struct without block does not match with ::ClassName matches with Class.new matches when using numbered parameter matches with Struct matches when using numbered parameter matches namespaced class matches with object singleton class matches with inheritance matches #parent_module_name when node on singleton class is expected to eq "Foo::#" when node nested in a class << exp is expected to be nil when node on module is expected to eq "Foo" when node on top level is expected to eq "Object" when node nested in an unknown block is expected to be nil when node on class in singleton class is expected to eq "Foo::#::Bar" #module_definition? using module keyword matches prepend Module.new matches with ::ModuleName matches with Module.new matches when using numbered parameter matches namespaced modules matches included module definition matches nested modules matches #recursive_basic_literal? behaves like literal returns true for `1` behaves like non literal returns false for `{ :sym => some_method_call }` behaves like literal returns true for `(false && true)` behaves like non literal returns false for `(x or false)` behaves like non literal returns false for `(x == false)` behaves like literal returns true for `!true` behaves like non literal returns false for `some_method_call` behaves like literal returns true for `"#{2}"` behaves like literal returns true for `(false or true)` behaves like non literal returns false for `(x && false)` behaves like literal returns true for `'str'` behaves like literal returns true for `%r{abx}ixo` behaves like non literal returns false for `/.#{some_method_call}/` behaves like literal returns true for `/./` behaves like non literal returns false for `some_method_call(x, y)` behaves like literal returns true for `(false <=> true)` behaves like literal returns true for `nil` behaves like non literal returns false for `{ some_method_call => :sym }` behaves like literal returns true for `{ :a => 1, :b => 2 }` behaves like non literal returns false for `%r{abx#{foo}}ixo` behaves like literal returns true for `(1)` behaves like literal returns true for `1.0` behaves like literal returns true for `[1, 2, 3]` behaves like literal returns true for `false` behaves like non literal returns false for `[some_method_call]` behaves like literal returns true for `{ a: 1, b: 2 }` sibling_access returns trivial values for a root node for a node with siblings returns the expected values for a single child returns the expected values #struct_constructor? struct definition without block does not match ::Struct matches struct definition with a block matches #numeric_type? when string literal is true when rational literal is true when float literal is true when complex literal whose imaginary part is a rational is true when complex literal is true when integer literal is true RuboCop::AST::AndAsgnNode #expression is expected to eq s(:send, nil, :value) #name is expected to eq :var .new is expected to be a kind of RuboCop::AST::AndAsgnNode #operator is expected to eq :"&&" #assignment_node is expected to be a kind of RuboCop::AST::AsgnNode RuboCop::AST::RegexpNode #extended? with only x option is expected to be extended with no options is expected not to be extended with other options is expected not to be extended with x and other options is expected to be extended #fixed_encoding? with u and other options is expected to be fixed encoding with only u option is expected to be fixed encoding with other options is expected not to be fixed encoding with no options is expected not to be fixed encoding #slash_literal? with %r/-delimiters is expected not to be slash literal with multi-line %r{-delimiters is expected not to be slash literal with %r<-delimiters is expected not to be slash literal with /-delimiters is expected to be slash literal with %r{-delimiters is expected not to be slash literal #delimiters with %r<-delimiters is expected to eq ["<", ">"] with %r/-delimiters is expected to eq ["/", "/"] with /-delimiters is expected to eq ["/", "/"] with multi-line %r{-delimiters is expected to eq ["{", "}"] with %r{-delimiters is expected to eq ["{", "}"] .new is expected to be a kind of RuboCop::AST::RegexpNode #single_interpolation? with only o option is expected to be single interpolation with no options is expected not to be single interpolation with other options is expected not to be single interpolation with o and other options is expected to be single interpolation #interpolation? with no interpolation returns false is expected not to be interpolation with regexp quote is expected to be interpolation with direct variable interpoation is expected to be interpolation #content with a multi-line regexp with option is expected to eq "\n.+\n" with a multi-line regexp without option is expected to eq "\n.+\n" with a regexp with option is expected to eq ".+" with a regexp without option is expected to eq ".+" with an empty regexp with option is expected to eq "" with an empty regexp is expected to eq "" #multiline_mode? with other options is expected not to be multiline mode with only m option is expected to be multiline mode with no options is expected not to be multiline mode with m and other options is expected to be multiline mode #delimiter? with %r<-delimiters is expected not to be delimiter "%" is expected not to be delimiter "%r<" is expected to be delimiter ">" is expected not to be delimiter "r" is expected not to be delimiter "}" is expected not to be delimiter "%r" is expected not to be delimiter "%r{" is expected not to be delimiter "{" is expected not to be delimiter "/" is expected to be delimiter "<" is expected not to be delimiter "%r/" with %r/-delimiters is expected not to be delimiter "r" is expected not to be delimiter "%" is expected not to be delimiter "}" is expected not to be delimiter "%r" is expected to be delimiter "/" is expected not to be delimiter "{" is expected not to be delimiter "%r/" with multi-line %r{-delimiters is expected not to be delimiter "r" is expected not to be delimiter "%r" is expected to be delimiter "{" is expected not to be delimiter "%r/" is expected to be delimiter "}" is expected not to be delimiter "/" is expected not to be delimiter "%r{" is expected not to be delimiter "%" with %r{-delimiters is expected to be delimiter "}" is expected not to be delimiter "%" is expected to be delimiter "{" is expected not to be delimiter "%r" is expected not to be delimiter "r" is expected not to be delimiter "%r{" is expected not to be delimiter "/" is expected not to be delimiter "%r/" with /-delimiters is expected to be delimiter "/" is expected not to be delimiter "{" #regopt with an empty regexp is expected to be regopt type is expected to be empty with an empty regexp with option is expected to eq [:i, :x] is expected to be regopt type with a multi-line regexp without option is expected to be empty is expected to be regopt type with a regexp without option is expected to be regopt type is expected to be empty with a regexp with option is expected to be regopt type is expected to eq [:i, :m, :x] with a multi-line regexp with option is expected to eq [:i, :m, :x] is expected to be regopt type #to_regexp with a regexp with option is expected to eq /.+/mix with a regexp with an "o" option is expected to eq "/abc/i" with an empty regexp is expected to eq // with a regexp with an "n" option is expected to eq "/abc/n" with a regexp with an "u" option is expected to eq "/abc/" with a regexp without option is expected to eq /.+/ with an empty regexp with option is expected to eq //ix with a multi-line regexp without option is expected to eq / .+ / with a multi-line regexp with option is expected to eq / .+ /ix #options with an empty regexp is expected to eq 0 with a regexp with "o" option is expected to eq 0 with a regexp with single option is expected to eq 1 with a regexp without option is expected to eq 0 with a regexp with multiple options is expected to eq 3 #no_encoding? with other options is expected not to be no encoding with no options is expected not to be no encoding with n and other options is expected to be no encoding with only n option is expected to be no encoding #ignore_case? with other options is expected not to be ignore case with only i option is expected to be ignore case with i and other options is expected to be ignore case with no options is expected not to be ignore case #percent_r_literal? with multi-line %r{-delimiters is expected to be percent r literal with %r/-delimiters is expected to be percent r literal with /-delimiters is expected not to be percent r literal with %r<-delimiters is expected to be percent r literal with %r{-delimiters is expected to be percent r literal RuboCop::AST::SymbolNode #value is expected to eq :foo .new with a symbol node is expected to be a kind of RuboCop::AST::SymbolNode RuboCop::AST::NodePattern::Sets is expected to eq "::RuboCop::AST::NodePattern::Sets::SET_1_2_3_ETC" creates a constant with the right value is expected to eq "::RuboCop::AST::NodePattern::Sets::SET_1_2_3_ETC" is expected not to eq "::RuboCop::AST::NodePattern::Sets::SET_1_2_3_ETC_2" RuboCop::AST::EnsureNode .new is expected to be a kind of RuboCop::AST::EnsureNode #body is expected to be sym type RuboCop::AST::BlockNode #arguments? with a single argument is expected to be arguments with a single splat argument is expected to be arguments with destructuring arguments is expected to be arguments with multiple mixed arguments is expected to be arguments >= Ruby 2.7 using numbered parameters is expected not to be arguments with no arguments is expected not to be arguments #arguments >= Ruby 2.7 using numbered parameters is expected to be empty with no arguments is expected to be empty with a single splat argument is expected to eq 1 with a single literal argument is expected to eq 1 with multiple mixed arguments is expected to eq 2 with destructured arguments is expected to eq 2 #delimiters when enclosed in braces is expected to eq ["{", "}"] when enclosed in do-end keywords is expected to eq ["do", "end"] .new is expected to be a kind of RuboCop::AST::BlockNode #braces? when enclosed in braces is expected to be braces when enclosed in do-end keywords is expected not to be braces #multiline? when block is on several lines is expected to be multiline when block is on a single line is expected not to be multiline #receiver with safe navigation operator call is expected to eq "foo" with dot operator call is expected to eq "foo" #void_context? when block method is each is expected to be void context when block method is not each is expected not to be void context when block method is tap is expected to be void context #single_line? when block is on a single line is expected to be single line when block is on several lines is expected not to be single line #lambda? when block belongs to a non-lambda method is expected not to be lambda when block belongs to a method lambda is expected to be lambda when block belongs to a stabby lambda is expected to be lambda #keywords? when enclosed in braces is expected not to be keywords when enclosed in do-end keywords is expected to be keywords #closing_delimiter when enclosed in braces is expected to eq "}" when enclosed in do-end keywords is expected to eq "end" #opening_delimiter when enclosed in do-end keywords is expected to eq "do" when enclosed in braces is expected to eq "{" #argument_list >= Ruby 2.7 using numbered parameters with skipped params is expected to eq [:_1, :_2, :_3, :_4, :_5, :_6, :_7] with sequential params is expected to eq [:_1, :_2] with no arguments is expected to be empty all argument types is expected to eq [:a, :b, :c, :d, :e, :f, :g, :h, :i] RuboCop::AST::NodePattern::Parser sequences generates specialized nodes expands ... in sequence head deep inside unions parses function calls parses capture vs repetition with correct priority parses simple sequences properly parses unions of literals as a set Changelog merges correctly parses correctly Changelog::Entry generates correct content Set#=== tests for inclusion RuboCop::AST::ArgsNode #empty_and_without_delimiters? with empty arguments with a lambda literal is expected to equal true with a method definition is expected to equal true with a block is expected to equal true with arguments with a lambda literal is expected to equal false with a method definition is expected to equal false with delimiters with a lambda literal is expected to equal false with a method definition is expected to equal false with a block is expected to equal false #argument_list is expected to eq [s(:arg, :a), s(:optarg, :b, s(:int, 42)), s(:arg, :c), s(:restarg, :d), s(:kwarg, :e), s(:kwoptarg, :f, s(:int, 42)), s(:kwrestarg, :g), s(:blockarg, :h), s(:shadowarg, :i)] when using Ruby 2.7 or newer with argument forwarding is expected to eq [s(:forward_arg)] .new with a block is expected to be a kind of RuboCop::AST::ArgsNode with a lambda literal is expected to be a kind of RuboCop::AST::ArgsNode with a method definition is expected to be a kind of RuboCop::AST::ArgsNode RuboCop::AST::ForwardArgsNode when using Ruby 2.7 or newer #to_a is expected to contain exactly (be forward arg type) RuboCop::AST::WhenNode .new is expected to be a kind of RuboCop::AST::WhenNode #body without a then keyword is expected to be array type with a then keyword is expected to be sym type #then? with a then keyword is expected to be then without a then keyword is expected not to be then #each_condition when not passed a block is expected to be a kind of Enumerator when passed a block yields all the conditions #branch_index is expected to eq 0 is expected to eq 2 is expected to eq 1 #conditions with a multiple conditions is expected to eq 3 is expected to all be literal with a single condition is expected to eq 1 is expected to all be literal RuboCop::AST::IntNode #sign? explicit negative int is expected to be sign explicit positive int is expected to be sign #value is expected to eq 10 .new is expected to be a kind of RuboCop::AST::IntNode RuboCop::AST::SuperNode #arguments? with multiple literal arguments is expected to be arguments with multiple mixed arguments is expected to be arguments with a single literal argument is expected to be arguments with a single splat argument is expected to be arguments with no arguments is expected not to be arguments #bang_method? is expected not to be bang method #const_receiver? is expected not to be const receiver #assignment_method? is expected not to be assignment method #predicate_method? is expected not to be predicate method #command? when argument is a symbol is expected to be command :super when argument is a string is expected to be command "super" #block_node with a block literal is expected to be block type with no block is expected to be nil with a block argument is expected to be nil #receiver is expected to be nil #splat_argument? with mixed arguments is expected to be splat argument with regular arguments is expected not to be splat argument with a splat argument is expected to be splat argument with no arguments is expected not to be splat argument #setter_method? is expected not to be setter method #block_literal? with no block is expected not to be block literal with a block argument is expected not to be block literal with a block literal is expected to be block literal #dot? is expected not to be dot #camel_case_method? is expected not to be camel case method #macro? is expected not to be macro #implicit_call? is expected not to be implicit call #method? when message matches when argument is a string is expected to be method "super" when argument is a symbol is expected to be method :super when message does not match when argument is a string is expected not to be method "foo" when argument is a symbol is expected not to be method :foo #first_argument with a single literal argument is expected to be sym type with multiple mixed arguments is expected to be sym type with a single splat argument is expected to be splat type with no arguments is expected to be nil with multiple literal arguments is expected to be sym type #operator_method? is expected not to be operator method #method_name is expected to eq :super #last_argument with multiple mixed arguments is expected to be splat type with no arguments is expected to be nil with a single literal argument is expected to be sym type with multiple literal arguments is expected to be sym type with a single splat argument is expected to be splat type #parenthesized? with no arguments when using parentheses is expected to be parenthesized when not using parentheses is expected not to be parenthesized with arguments when not using parentheses is expected not to be parenthesized when using parentheses is expected to be parenthesized #self_receiver? is expected not to be self receiver #double_colon? is expected not to be double colon .new with a zsuper node is expected to be a kind of RuboCop::AST::SuperNode with a super node is expected to be a kind of RuboCop::AST::SuperNode #block_argument? with mixed arguments is expected to be block argument with no arguments is expected not to be block argument with regular arguments is expected not to be block argument with a block argument is expected to be block argument #arguments with no arguments is expected to be empty with a single literal argument is expected to eq 1 with multiple mixed arguments is expected to eq 2 with a single splat argument is expected to eq 1 with multiple literal arguments is expected to eq 2 #comparison_method? is expected not to be comparison method RuboCop::AST::RangeNode .new with an infinite range is expected to be range type is expected to be a kind of RuboCop::AST::RangeNode with an exclusive range is expected to be range type is expected to be a kind of RuboCop::AST::RangeNode with a beignless range is expected to be range type is expected to be a kind of RuboCop::AST::RangeNode with an inclusive range is expected to be range type is expected to be a kind of RuboCop::AST::RangeNode RuboCop::AST::OpAsgnNode #assignment_node is expected to be a kind of RuboCop::AST::AsgnNode #operator with &= is expected to eq :& with **= is expected to eq :** with *= is expected to eq :* with |= is expected to eq :| with /= is expected to eq :/ with += is expected to eq :+ with %= is expected to eq :% with -= is expected to eq :- #expression is expected to eq s(:send, nil, :value) .new with an `op_asgn_node` node is expected to be a kind of RuboCop::AST::OpAsgnNode #name is expected to eq :var Finished in 3.23 seconds (files took 1.18 seconds to load) 2392 examples, 0 failures Randomized with seed 34457 ┌──────────────────────────────────────────────────────────────────────────────┐ │ dh_ruby --install finished │ └──────────────────────────────────────────────────────────────────────────────┘ dh_installdocs -O--buildsystem=ruby dh_ruby_fixdocs -O--buildsystem=ruby debian/rules override_dh_installchangelogs make[1]: Entering directory '/build/reproducible-path/ruby-rubocop-ast-1.24.0' dh_installchangelogs CHANGELOG.md make[1]: Leaving directory '/build/reproducible-path/ruby-rubocop-ast-1.24.0' dh_installsystemduser -O--buildsystem=ruby dh_perl -O--buildsystem=ruby dh_link -O--buildsystem=ruby dh_strip_nondeterminism -O--buildsystem=ruby dh_compress -X.rb -O--buildsystem=ruby dh_fixperms -O--buildsystem=ruby dh_missing -O--buildsystem=ruby dh_ruby_fixdepends -O--buildsystem=ruby dh_installdeb -O--buildsystem=ruby dh_gencontrol -O--buildsystem=ruby dpkg-gencontrol: warning: Depends field of package ruby-rubocop-ast: substitution variable ${shlibs:Depends} used, but is not defined dpkg-gencontrol: warning: package ruby-rubocop-ast: substitution variable ${ruby:Versions} used, but is not defined dh_md5sums -O--buildsystem=ruby dh_builddeb -O--buildsystem=ruby dpkg-deb: building package 'ruby-rubocop-ast' in '../ruby-rubocop-ast_1.24.0-2_all.deb'. dpkg-genbuildinfo --build=binary -O../ruby-rubocop-ast_1.24.0-2_arm64.buildinfo dpkg-genchanges --build=binary -O../ruby-rubocop-ast_1.24.0-2_arm64.changes dpkg-genchanges: info: binary-only upload (no source code included) dpkg-source --after-build . dpkg-buildpackage: info: binary-only upload (no source included) dpkg-genchanges: info: not including original source code in upload I: copying local configuration I: user script /srv/workspace/pbuilder/433812/tmp/hooks/B01_cleanup starting I: user script /srv/workspace/pbuilder/433812/tmp/hooks/B01_cleanup finished I: unmounting dev/ptmx filesystem I: unmounting dev/pts filesystem I: unmounting dev/shm filesystem I: unmounting proc filesystem I: unmounting sys filesystem I: cleaning the build env I: removing directory /srv/workspace/pbuilder/433812 and its subdirectories I: Current time: Sun Apr 27 08:56:34 +14 2025 I: pbuilder-time-stamp: 1745693794 + false + set +x Sat Apr 26 18:56:34 UTC 2025 I: Signing ./b2/ruby-rubocop-ast_1.24.0-2_arm64.buildinfo as ruby-rubocop-ast_1.24.0-2_arm64.buildinfo.asc Sat Apr 26 18:56:34 UTC 2025 I: Signed ./b2/ruby-rubocop-ast_1.24.0-2_arm64.buildinfo as ./b2/ruby-rubocop-ast_1.24.0-2_arm64.buildinfo.asc Sat Apr 26 18:56:34 UTC 2025 - build #2 for ruby-rubocop-ast/unstable/arm64 on codethink04-arm64 done. Starting cleanup. All cleanup done. Sat Apr 26 18:56:34 UTC 2025 - reproducible_build.sh stopped running as /tmp/jenkins-script-ZtowLMUS, removing. /srv/reproducible-results/rbuild-debian/r-b-build.XpjqCx9r: total 260 drwxr-xr-x 2 jenkins jenkins 4096 Apr 26 18:55 b1 drwxr-xr-x 2 jenkins jenkins 4096 Apr 26 18:56 b2 -rw------- 1 jenkins jenkins 248548 Apr 26 18:55 rbuildlog.1anVNAM -rw-r--r-- 1 jenkins jenkins 2224 Dec 21 2022 ruby-rubocop-ast_1.24.0-2.dsc /srv/reproducible-results/rbuild-debian/r-b-build.XpjqCx9r/b1: total 340 -rw-r--r-- 1 jenkins jenkins 244846 Apr 26 18:55 build.log -rw-r--r-- 1 jenkins jenkins 3600 Apr 26 18:55 ruby-rubocop-ast_1.24.0-2.debian.tar.xz -rw-r--r-- 1 jenkins jenkins 2224 Apr 26 18:55 ruby-rubocop-ast_1.24.0-2.dsc -rw-r--r-- 1 jenkins jenkins 53520 Apr 26 18:55 ruby-rubocop-ast_1.24.0-2_all.deb -rw-r--r-- 1 jenkins jenkins 7668 Apr 26 18:55 ruby-rubocop-ast_1.24.0-2_arm64.buildinfo -rw-r--r-- 1 jenkins jenkins 8550 Apr 26 18:55 ruby-rubocop-ast_1.24.0-2_arm64.buildinfo.asc -rw-r--r-- 1 jenkins jenkins 1128 Apr 26 18:55 ruby-rubocop-ast_1.24.0-2_arm64.changes -rw-r--r-- 1 jenkins jenkins 1308 Apr 26 18:55 ruby-rubocop-ast_1.24.0-2_source.changes /srv/reproducible-results/rbuild-debian/r-b-build.XpjqCx9r/b2: total 344 -rw-r--r-- 1 jenkins jenkins 246778 Apr 26 18:56 build.log -rw-r--r-- 1 jenkins jenkins 3600 Apr 26 18:56 ruby-rubocop-ast_1.24.0-2.debian.tar.xz -rw-r--r-- 1 jenkins jenkins 2224 Apr 26 18:56 ruby-rubocop-ast_1.24.0-2.dsc -rw-r--r-- 1 jenkins jenkins 53520 Apr 26 18:56 ruby-rubocop-ast_1.24.0-2_all.deb -rw-r--r-- 1 jenkins jenkins 7668 Apr 26 18:56 ruby-rubocop-ast_1.24.0-2_arm64.buildinfo -rw-r--r-- 1 jenkins jenkins 8550 Apr 26 18:56 ruby-rubocop-ast_1.24.0-2_arm64.buildinfo.asc -rw-r--r-- 1 jenkins jenkins 1128 Apr 26 18:56 ruby-rubocop-ast_1.24.0-2_arm64.changes -rw-r--r-- 1 jenkins jenkins 1308 Apr 26 18:56 ruby-rubocop-ast_1.24.0-2_source.changes Sat Apr 26 18:56:35 UTC 2025 I: Deleting $TMPDIR on codethink04-arm64.debian.net. Sat Apr 26 18:56:36 UTC 2025 I: ruby-rubocop-ast_1.24.0-2_arm64.changes: Format: 1.8 Date: Wed, 21 Dec 2022 18:24:30 -0300 Source: ruby-rubocop-ast Binary: ruby-rubocop-ast Architecture: all Version: 1.24.0-2 Distribution: unstable Urgency: medium Maintainer: Debian Ruby Team Changed-By: Lucas Kanashiro Description: ruby-rubocop-ast - RuboCop tools to deal with Ruby code AST Changes: ruby-rubocop-ast (1.24.0-2) unstable; urgency=medium . * Team upload. * Generate parsers during the build target. Checksums-Sha1: d393d6f67524212a3d188f38f6d79d1dbd5fca25 53520 ruby-rubocop-ast_1.24.0-2_all.deb 4e1ca0dc8acb3e66fe1a3eb0efc6ccb408b46259 7668 ruby-rubocop-ast_1.24.0-2_arm64.buildinfo Checksums-Sha256: 59f59511852472a544a966615957e31b936bbfdce4b2ee4e188946fa7ef13220 53520 ruby-rubocop-ast_1.24.0-2_all.deb 2151a5938ee358e21784fda4985f48015b400625b7f3c6e319e1813d4766ab94 7668 ruby-rubocop-ast_1.24.0-2_arm64.buildinfo Files: d65e748d0febd04d82f1cced5e4b7ca0 53520 ruby optional ruby-rubocop-ast_1.24.0-2_all.deb 2563aa523aa12d4d3adf949ae59eea3a 7668 ruby optional ruby-rubocop-ast_1.24.0-2_arm64.buildinfo removed '/var/lib/jenkins/userContent/reproducible/debian/rbuild/unstable/arm64/ruby-rubocop-ast_1.24.0-2.rbuild.log' removed '/var/lib/jenkins/userContent/reproducible/debian/rbuild/unstable/arm64/ruby-rubocop-ast_1.24.0-2.rbuild.log.gz' removed '/var/lib/jenkins/userContent/reproducible/debian/logs/unstable/arm64/ruby-rubocop-ast_1.24.0-2.build1.log.gz' removed '/var/lib/jenkins/userContent/reproducible/debian/logs/unstable/arm64/ruby-rubocop-ast_1.24.0-2.build2.log.gz' removed '/var/lib/jenkins/userContent/reproducible/debian/buildinfo/unstable/arm64/ruby-rubocop-ast_1.24.0-2_arm64.buildinfo' removed '/var/lib/jenkins/userContent/reproducible/debian/logdiffs/unstable/arm64/ruby-rubocop-ast_1.24.0-2.diff.gz' Diff of the two buildlogs: -- --- b1/build.log 2025-04-26 18:55:45.359547473 +0000 +++ b2/build.log 2025-04-26 18:56:35.346479346 +0000 @@ -1,6 +1,6 @@ I: pbuilder: network access will be disabled during build -I: Current time: Fri May 29 13:18:02 -12 2026 -I: pbuilder-time-stamp: 1780103882 +I: Current time: Sun Apr 27 08:55:48 +14 2025 +I: pbuilder-time-stamp: 1745693748 I: Building the build Environment I: extracting base tarball [/var/cache/pbuilder/unstable-reproducible-base.tgz] I: copying local configuration @@ -25,52 +25,84 @@ dpkg-source: info: applying 0002-Fix-compile-task.patch I: Not using root during the build. I: Installing the build-deps -I: user script /srv/workspace/pbuilder/2893848/tmp/hooks/D02_print_environment starting +I: user script /srv/workspace/pbuilder/433812/tmp/hooks/D01_modify_environment starting +debug: Running on codethink04-arm64. +I: Changing host+domainname to test build reproducibility +I: Adding a custom variable just for the fun of it... +I: Changing /bin/sh to bash +'/bin/sh' -> '/bin/bash' +lrwxrwxrwx 1 root root 9 Apr 26 18:55 /bin/sh -> /bin/bash +I: Setting pbuilder2's login shell to /bin/bash +I: Setting pbuilder2's GECOS to second user,second room,second work-phone,second home-phone,second other +I: user script /srv/workspace/pbuilder/433812/tmp/hooks/D01_modify_environment finished +I: user script /srv/workspace/pbuilder/433812/tmp/hooks/D02_print_environment starting I: set - BUILDDIR='/build/reproducible-path' - BUILDUSERGECOS='first user,first room,first work-phone,first home-phone,first other' - BUILDUSERNAME='pbuilder1' - BUILD_ARCH='arm64' - DEBIAN_FRONTEND='noninteractive' + BASH=/bin/sh + BASHOPTS=checkwinsize:cmdhist:complete_fullquote:extquote:force_fignore:globasciiranges:globskipdots:hostcomplete:interactive_comments:patsub_replacement:progcomp:promptvars:sourcepath + BASH_ALIASES=() + BASH_ARGC=() + BASH_ARGV=() + BASH_CMDS=() + BASH_LINENO=([0]="12" [1]="0") + BASH_LOADABLES_PATH=/usr/local/lib/bash:/usr/lib/bash:/opt/local/lib/bash:/usr/pkg/lib/bash:/opt/pkg/lib/bash:. + BASH_SOURCE=([0]="/tmp/hooks/D02_print_environment" [1]="/tmp/hooks/D02_print_environment") + BASH_VERSINFO=([0]="5" [1]="2" [2]="37" [3]="1" [4]="release" [5]="aarch64-unknown-linux-gnu") + BASH_VERSION='5.2.37(1)-release' + BUILDDIR=/build/reproducible-path + BUILDUSERGECOS='second user,second room,second work-phone,second home-phone,second other' + BUILDUSERNAME=pbuilder2 + BUILD_ARCH=arm64 + DEBIAN_FRONTEND=noninteractive DEB_BUILD_OPTIONS='buildinfo=+all reproducible=+all parallel=12 ' - DISTRIBUTION='unstable' - HOME='/root' - HOST_ARCH='arm64' + DIRSTACK=() + DISTRIBUTION=unstable + EUID=0 + FUNCNAME=([0]="Echo" [1]="main") + GROUPS=() + HOME=/root + HOSTNAME=i-capture-the-hostname + HOSTTYPE=aarch64 + HOST_ARCH=arm64 IFS=' ' - INVOCATION_ID='d8c94ffce52c47cb84cc1da279b6dc62' - LANG='C' - LANGUAGE='en_US:en' - LC_ALL='C' - MAIL='/var/mail/root' - OPTIND='1' - PATH='/usr/sbin:/usr/bin:/sbin:/bin:/usr/games' - PBCURRENTCOMMANDLINEOPERATION='build' - PBUILDER_OPERATION='build' - PBUILDER_PKGDATADIR='/usr/share/pbuilder' - PBUILDER_PKGLIBDIR='/usr/lib/pbuilder' - PBUILDER_SYSCONFDIR='/etc' - PPID='2893848' - PS1='# ' - PS2='> ' + INVOCATION_ID=0928debd5c3c471fb97bdedfb6a3449a + LANG=C + LANGUAGE=nl_BE:nl + LC_ALL=C + MACHTYPE=aarch64-unknown-linux-gnu + MAIL=/var/mail/root + OPTERR=1 + OPTIND=1 + OSTYPE=linux-gnu + PATH=/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/i/capture/the/path + PBCURRENTCOMMANDLINEOPERATION=build + PBUILDER_OPERATION=build + PBUILDER_PKGDATADIR=/usr/share/pbuilder + PBUILDER_PKGLIBDIR=/usr/lib/pbuilder + PBUILDER_SYSCONFDIR=/etc + PIPESTATUS=([0]="0") + POSIXLY_CORRECT=y + PPID=433812 PS4='+ ' - PWD='/' - SHELL='/bin/bash' - SHLVL='2' - SUDO_COMMAND='/usr/bin/timeout -k 18.1h 18h /usr/bin/ionice -c 3 /usr/bin/nice /usr/sbin/pbuilder --build --configfile /srv/reproducible-results/rbuild-debian/r-b-build.XpjqCx9r/pbuilderrc_uiMP --distribution unstable --hookdir /etc/pbuilder/first-build-hooks --debbuildopts -b --basetgz /var/cache/pbuilder/unstable-reproducible-base.tgz --buildresult /srv/reproducible-results/rbuild-debian/r-b-build.XpjqCx9r/b1 --logfile b1/build.log ruby-rubocop-ast_1.24.0-2.dsc' - SUDO_GID='109' - SUDO_UID='104' - SUDO_USER='jenkins' - TERM='unknown' - TZ='/usr/share/zoneinfo/Etc/GMT+12' - USER='root' - _='/usr/bin/systemd-run' - http_proxy='http://192.168.101.4:3128' + PWD=/ + SHELL=/bin/bash + SHELLOPTS=braceexpand:errexit:hashall:interactive-comments:posix + SHLVL=3 + SUDO_COMMAND='/usr/bin/timeout -k 24.1h 24h /usr/bin/ionice -c 3 /usr/bin/nice -n 11 /usr/bin/unshare --uts -- /usr/sbin/pbuilder --build --configfile /srv/reproducible-results/rbuild-debian/r-b-build.XpjqCx9r/pbuilderrc_Pgl6 --distribution unstable --hookdir /etc/pbuilder/rebuild-hooks --debbuildopts -b --basetgz /var/cache/pbuilder/unstable-reproducible-base.tgz --buildresult /srv/reproducible-results/rbuild-debian/r-b-build.XpjqCx9r/b2 --logfile b2/build.log ruby-rubocop-ast_1.24.0-2.dsc' + SUDO_GID=109 + SUDO_UID=104 + SUDO_USER=jenkins + TERM=unknown + TZ=/usr/share/zoneinfo/Etc/GMT-14 + UID=0 + USER=root + _='I: set' + http_proxy=http://192.168.101.4:3128 I: uname -a - Linux codethink03-arm64 6.1.0-33-cloud-arm64 #1 SMP Debian 6.1.133-1 (2025-04-10) aarch64 GNU/Linux + Linux i-capture-the-hostname 6.1.0-33-cloud-arm64 #1 SMP Debian 6.1.133-1 (2025-04-10) aarch64 GNU/Linux I: ls -l /bin - lrwxrwxrwx 1 root root 7 Mar 4 2025 /bin -> usr/bin -I: user script /srv/workspace/pbuilder/2893848/tmp/hooks/D02_print_environment finished + lrwxrwxrwx 1 root root 7 Mar 4 11:20 /bin -> usr/bin +I: user script /srv/workspace/pbuilder/433812/tmp/hooks/D02_print_environment finished -> Attempting to satisfy build-dependencies -> Creating pbuilder-satisfydepends-dummy package Package: pbuilder-satisfydepends-dummy @@ -247,7 +279,7 @@ Get: 127 http://deb.debian.org/debian unstable/main arm64 ruby-rspec-mocks all 3.13.0c0e0m0s1-2 [81.3 kB] Get: 128 http://deb.debian.org/debian unstable/main arm64 ruby-rspec all 3.13.0c0e0m0s1-2 [5184 B] Get: 129 http://deb.debian.org/debian unstable/main arm64 ruby-whitequark-parser all 3.3.4.2-2 [507 kB] -Fetched 35.0 MB in 0s (95.9 MB/s) +Fetched 35.0 MB in 0s (154 MB/s) Preconfiguring packages ... Selecting previously unselected package libpython3.13-minimal:arm64. (Reading database ... (Reading database ... 5% (Reading database ... 10% (Reading database ... 15% (Reading database ... 20% (Reading database ... 25% (Reading database ... 30% (Reading database ... 35% (Reading database ... 40% (Reading database ... 45% (Reading database ... 50% (Reading database ... 55% (Reading database ... 60% (Reading database ... 65% (Reading database ... 70% (Reading database ... 75% (Reading database ... 80% (Reading database ... 85% (Reading database ... 90% (Reading database ... 95% (Reading database ... 100% (Reading database ... 19953 files and directories currently installed.) @@ -678,8 +710,8 @@ Setting up tzdata (2025b-2) ... Current default time zone: 'Etc/UTC' -Local time is now: Sat May 30 01:18:22 UTC 2026. -Universal Time is now: Sat May 30 01:18:22 UTC 2026. +Local time is now: Sat Apr 26 18:56:08 UTC 2025. +Universal Time is now: Sat Apr 26 18:56:08 UTC 2025. Run 'dpkg-reconfigure tzdata' if you wish to change it. Setting up ruby-minitest (5.25.4-2) ... @@ -798,7 +830,11 @@ Building tag database... -> Finished parsing the build-deps I: Building the package -I: Running cd /build/reproducible-path/ruby-rubocop-ast-1.24.0/ && env PATH="/usr/sbin:/usr/bin:/sbin:/bin:/usr/games" HOME="/nonexistent/first-build" dpkg-buildpackage -us -uc -b && env PATH="/usr/sbin:/usr/bin:/sbin:/bin:/usr/games" HOME="/nonexistent/first-build" dpkg-genchanges -S > ../ruby-rubocop-ast_1.24.0-2_source.changes +I: user script /srv/workspace/pbuilder/433812/tmp/hooks/A99_set_merged_usr starting +Not re-configuring usrmerge for unstable +I: user script /srv/workspace/pbuilder/433812/tmp/hooks/A99_set_merged_usr finished +hostname: Name or service not known +I: Running cd /build/reproducible-path/ruby-rubocop-ast-1.24.0/ && env PATH="/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/i/capture/the/path" HOME="/nonexistent/second-build" dpkg-buildpackage -us -uc -b && env PATH="/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/i/capture/the/path" HOME="/nonexistent/second-build" dpkg-genchanges -S > ../ruby-rubocop-ast_1.24.0-2_source.changes dpkg-buildpackage: info: source package ruby-rubocop-ast dpkg-buildpackage: info: source version 1.24.0-2 dpkg-buildpackage: info: source distribution unstable @@ -838,7 +874,7 @@ │ ruby-rubocop-ast: Installing files and building extensions for ruby3.3 │ └──────────────────────────────────────────────────────────────────────────────┘ -/usr/bin/ruby3.3 -S gem build --config-file /dev/null --verbose /tmp/d20260529-2904851-frzkt7/gemspec +/usr/bin/ruby3.3 -S gem build --config-file /dev/null --verbose /tmp/d20250427-443914-v9ocuu/gemspec WARNING: open-ended dependency on parser (>= 3.1.1.0) is not recommended if parser is semantically versioned, use: add_runtime_dependency "parser", "~> 3.1", ">= 3.1.1.0" @@ -847,7 +883,7 @@ Name: rubocop-ast Version: 1.24.0 File: rubocop-ast-1.24.0.gem -/usr/bin/ruby3.3 -S gem install --config-file /dev/null --verbose --local --verbose --no-document --ignore-dependencies --install-dir debian/ruby-rubocop-ast/usr/share/rubygems-integration/all /tmp/d20260529-2904851-frzkt7/rubocop-ast-1.24.0.gem +/usr/bin/ruby3.3 -S gem install --config-file /dev/null --verbose --local --verbose --no-document --ignore-dependencies --install-dir debian/ruby-rubocop-ast/usr/share/rubygems-integration/all /tmp/d20250427-443914-v9ocuu/rubocop-ast-1.24.0.gem /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop-ast.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast.rb /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast/usr/share/rubygems-integration/all/gems/rubocop-ast-1.24.0/lib/rubocop/ast/builder.rb @@ -973,123 +1009,419 @@ warning: parser/current is loading parser/ruby33, which recognizes 3.3.4-compliant syntax, but you are running 3.3.8. Please see https://github.com/whitequark/parser#compatibility-with-ruby-mri. -Randomized with seed 46231 +Randomized with seed 34457 + +RuboCop::AST::Ext::Range + #line_span + accepts an `exclude_end` keyword argument + returns the range of lines a range occupies + +RuboCop::AST::DstrNode + #value + with interpolation + is expected to eq "foo \#{bar} baz" + with a multiline string + is expected to eq "this is a multiline string" + with implicit concatenation + is expected to eq "foo bar baz" + +RuboCop::AST::BreakNode + behaves like wrapped arguments node + #arguments + with a single argument and braces + is expected to eq 1 + with a single splat argument + is expected to eq 1 + with multiple literal arguments + is expected to eq 2 + with a single argument + is expected to eq 1 + with no arguments + is expected to be empty + with no arguments and braces + is expected to be empty + .new + without arguments + is expected to be a kind of RuboCop::AST::BreakNode + with arguments + is expected to be a kind of RuboCop::AST::BreakNode + +RuboCop::AST::Token + #column + returns index of first char in token range on that line + .from_parser_token + sets parser token's range to rubocop token's pos + sets parser token's type to rubocop token's type + returns a #to_s useful for debugging + sets parser token's text to rubocop token's text + #line + returns line of token + #to_s + returns string of token data + #end_pos + returns index of last char in token range of entire source + #space_after + returns truthy MatchData when there is a space after token + returns nil when there is not a space after token + #begin_pos + returns index of first char in token range of entire source + #space_before + returns nil when it is on the first line + returns truthy MatchData when there is a space before token + returns nil when there is not a space before token + type predicates + #left_array_bracket? + returns true for left_array_bracket tokens + returns false for non left_array_bracket tokens + with braces & parens + #left_brace? + returns false for non left hash brace tokens + returns true for left hash brace tokens + #right_curly_brace? + returns true for all right brace tokens + returns false for non right brace tokens + #left_parens? + returns true for left parens tokens + returns false for non left parens tokens + #right_parens? + returns true for right parens tokens + returns false for non right parens tokens + #left_curly_brace? + returns true for left block brace tokens + returns false for non left block brace tokens + #left_ref_bracket? + returns true for left_ref_bracket tokens + returns false for non left_ref_bracket tokens + #regexp_dots? + returns false for non comma tokens + returns true for regexp tokens + #comment? + returns true for comment tokens + returns false for non comment tokens + #semicolon? + returns true for semicolon tokens + returns false for non semicolon tokens + #new_line? + returns false for non new line tokens + returns true for new line tokens + #left_brace? + returns true for right_bracket tokens + returns false for non right_bracket tokens + #left_bracket? + returns true for all left_bracket tokens + returns false for non left_bracket tokens + #equals_sign? + returns true for equals sign tokens + returns false for non equals sign tokens + #rescue_modifier? + returns false for non rescue modifier tokens + returns true for rescue modifier tokens + #end? + returns false for non end tokens + returns true for end tokens + #right_bracket? + returns true for all right_bracket tokens + returns false for non right_bracket tokens + #dot? + returns false for non dot tokens + returns true for dot tokens + #comma? + returns false for non comma tokens + returns true for comma tokens + +RuboCop::AST::CasgnNode + .new + with a `casgn` node + is expected to be a kind of RuboCop::AST::CasgnNode + #expression + is expected to eq s(:send, nil, :value) + #name + is expected to eq :VAR + #namespace + when there is no parent + is expected to be nil + when the parent is a `const` + is expected to eq s(:const, nil, :FOO) + when the parent is a `cbase` + is expected to eq s(:cbase) + +RuboCop::AST::AliasNode + #old_identifier + is expected to be sym type + is expected to eq :bar + .new + is expected to be a kind of RuboCop::AST::AliasNode + #new_identifier + is expected to be sym type + is expected to eq :foo + +RuboCop::AST::RuboCopCompatibility + when ran from a compatible version of Rubocop + issues a warning + when ran from an incompatible version of Rubocop + issues a warning + +RuboCop::AST::AndNode + #lhs + with a logical and node + is expected to be sym type + with a semantic and node + is expected to be sym type + .new + with a logical and node + is expected to be a kind of RuboCop::AST::AndNode + with a semantic and node + is expected to be a kind of RuboCop::AST::AndNode + #logical_operator? + with a semantic and node + is expected not to be logical operator + with a logical and node + is expected to be logical operator + #semantic_operator? + with a logical and node + is expected not to be semantic operator + with a semantic and node + is expected to be semantic operator + #inverse_operator + with a semantic and node + is expected to eq "or" + with a logical and node + is expected to eq "||" + #operator + with a logical and node + is expected to eq "&&" + with a semantic and node + is expected to eq "and" + #rhs + with a semantic and node + is expected to be int type + with a logical and node + is expected to be int type + #alternate_operator + with a logical and node + is expected to eq "and" + with a semantic and node + is expected to eq "&&" + +RuboCop::AST::AsgnNode + #name + with a `cvasgn` node + is expected to eq :@@var + with a `ivasgn` node + is expected to eq :@var + with a `gvasgn` node + is expected to eq :$var + with a `lvasgn` node + is expected to eq :var + #expression + with a `cvasgn` node + is expected to eq s(:send, nil, :value) + with a `gvasgn` node + is expected to eq s(:send, nil, :value) + with a `lvasgn` node + is expected to eq s(:send, nil, :value) + with a `ivasgn` node + is expected to eq s(:send, nil, :value) + .new + with a `ivasgn` node + is expected to be a kind of RuboCop::AST::AsgnNode + with a `lvasgn` node + is expected to be a kind of RuboCop::AST::AsgnNode + with a `cvasgn` node + is expected to be a kind of RuboCop::AST::AsgnNode + with a `gvasgn` node + is expected to be a kind of RuboCop::AST::AsgnNode + +RuboCop::AST::StrNode + .new + with a string with interpolation + is expected to be a kind of RuboCop::AST::StrNode + with a heredoc + is expected to be a kind of RuboCop::AST::StrNode + with a normal string + is expected to be a kind of RuboCop::AST::StrNode + #character_literal? + with a character literal + is expected to be character literal + with a normal string literal + is expected not to be character literal + with a heredoc + is expected not to be character literal + #heredoc? + with a normal string + is expected not to be heredoc + with a heredoc + is expected to be heredoc + with a string with interpolation + is expected not to be heredoc + +RuboCop::AST::RescueNode + #body + is expected to be send type + #resbody_branches + is expected to all be resbody type + is expected to eq 2 + #else_branch + with an else statement + is expected to be send type + without an else statement + is expected to be nil + #else? + without an else statement + is expected not to be else + with an else statement + is expected to be else + #branches + when there is no else keyword + returns only then rescue bodies + when there is an else + returns all the bodies + with an empty else + returns all the bodies + .new + is expected to be a kind of RuboCop::AST::RescueNode + +RuboCop::AST::OrAsgnNode + .new + is expected to be a kind of RuboCop::AST::OrAsgnNode + #assignment_node + is expected to be a kind of RuboCop::AST::AsgnNode + #operator + is expected to eq :"||" + #name + is expected to eq :var + #expression + is expected to eq s(:send, nil, :value) + +RuboCop::AST::WhileNode + #keyword + is expected to eq "while" + .new + with a statement while + is expected to be a kind of RuboCop::AST::WhileNode + with a modifier while + is expected to be a kind of RuboCop::AST::WhileNode + #post_condition_loop? + with a statement while + is expected not to be post condition loop + with a modifier while + is expected to be post condition loop + #inverse_keyword + is expected to eq "until" + #loop_keyword? + with a statement while + is expected to be loop keyword + with a modifier while + is expected to be loop keyword + #do? + without a do keyword + is expected not to be do + with a do keyword + is expected to be do RuboCop::AST::IfNode + #else_branch + with an unless statement + is expected to be int type + with a ternary operator + is expected to be int type + with an if statement + is expected to be int type + #modifier_form? + with a modifier unless statement + is expected to be modifier form + with a modifier if statement + is expected to be modifier form + with a non-modifier if statement + is expected not to be modifier form + with a ternary operator + is expected not to be modifier form + with a non-modifier unless statement + is expected not to be modifier form + #keyword + with an unless statement + is expected to eq "unless" + with a ternary operator + is expected to eq "" + with an if statement + is expected to eq "if" + #if? + with a ternary operator + is expected not to be if + with an unless statement + is expected not to be if + with an if statement + is expected to be if #branches with an elsif statement is expected to all be literal is expected to eq 3 - with an if statement - is expected to eq 1 - is expected to all be literal with an unless statement is expected to all be literal is expected to eq 1 - with a ternary operator - is expected to all be literal - is expected to eq 2 with an else statement - is expected to all be literal is expected to eq 2 - #each_branch - when passed a block - yields all the branches - when not passed a block - is expected to be a kind of Enumerator - #if? + is expected to all be literal with a ternary operator - is expected not to be if - with an unless statement - is expected not to be if + is expected to all be literal + is expected to eq 2 with an if statement - is expected to be if + is expected to eq 1 + is expected to all be literal #unless? - with a ternary operator + with an if statement is expected not to be unless with an unless statement is expected to be unless - with an if statement + with a ternary operator is expected not to be unless #if_branch - with an if statement - is expected to be sym type with a ternary operator is expected to be sym type + with an if statement + is expected to be sym type with an unless statement is expected to be sym type + #each_branch + when passed a block + yields all the branches + when not passed a block + is expected to be a kind of Enumerator #inverse_keyword? - with an if statement - is expected to eq "unless" with an unless statement is expected to eq "if" + with an if statement + is expected to eq "unless" with a ternary operator is expected to eq "" - #ternary? - with a ternary operator - is expected to be ternary - with an unless statement - is expected not to be ternary - with an if statement - is expected not to be ternary #nested_conditional? - with nested conditionals in elsif clause - is expected to be nested conditional - with no nested conditionals - is expected not to be nested conditional with nested conditionals in if clause is expected to be nested conditional with nested conditionals in else clause is expected to be nested conditional + with nested conditionals in elsif clause + is expected to be nested conditional + with no nested conditionals + is expected not to be nested conditional with nested ternary operators - when nested in the falsey branch - is expected to be nested conditional when nested in the truthy branch is expected to be nested conditional - #elsif_conditional? - with nested conditionals in else clause - is expected not to be elsif conditional - with multiple elsif conditionals - is expected to be elsif conditional - with nested ternary operators - when nested in the truthy branch - is expected not to be elsif conditional when nested in the falsey branch - is expected not to be elsif conditional - with nested conditionals in if clause - is expected not to be elsif conditional - with one elsif conditional - is expected to be elsif conditional - #else? - without an else statement - is expected not to be elsif + is expected to be nested conditional + #elsif? with an elsif statement - is expected to be else - #modifier_form? - with a modifier if statement - is expected to be modifier form - with a non-modifier if statement - is expected not to be modifier form - with a modifier unless statement - is expected to be modifier form - with a non-modifier unless statement - is expected not to be modifier form - with a ternary operator - is expected not to be modifier form - #keyword - with an unless statement - is expected to eq "unless" - with a ternary operator - is expected to eq "" - with an if statement - is expected to eq "if" - #else_branch + is expected to be elsif + without an elsif statement + is expected not to be elsif + with an if statement comtaining an elsif + is expected not to be elsif + #ternary? with an unless statement - is expected to be int type + is expected not to be ternary with an if statement - is expected to be int type + is expected not to be ternary with a ternary operator - is expected to be int type + is expected to be ternary .new with a modifier statement is expected to be a kind of RuboCop::AST::IfNode @@ -1097,4221 +1429,2206 @@ is expected to be a kind of RuboCop::AST::IfNode with a ternary operator is expected to be a kind of RuboCop::AST::IfNode - #elsif? - without an elsif statement - is expected not to be elsif - with an if statement comtaining an elsif + #else? + without an else statement is expected not to be elsif with an elsif statement - is expected to be elsif - -RuboCop::AST::AndAsgnNode - #operator - is expected to eq :"&&" - .new - is expected to be a kind of RuboCop::AST::AndAsgnNode - #name - is expected to eq :var - #expression - is expected to eq s(:send, nil, :value) - #assignment_node - is expected to be a kind of RuboCop::AST::AsgnNode - -RuboCop::AST::HashNode - #empty? - with an empty hash - is expected to be empty - with a hash containing pairs - is expected not to be empty - with a hash containing a keyword splat - is expected not to be empty - #each_value - when passed a block - yields all the pairs - when not passed a block - is expected to be a kind of Enumerator - #mixed_delimiters? - when all pairs are using a hash rocket delimiter - is expected not to be mixed delimiters - when pairs are using different delimiters - is expected to be mixed delimiters - when all pairs are using a colon delimiter - is expected not to be mixed delimiters - #values - with a hash with literal values - is expected to eq 3 - is expected to all be literal - with a hash with string keys - is expected to eq 2 - is expected to all be send type - with an empty hash - is expected to be empty - #pairs_on_same_line? - with all pairs on the same line - is expected to be pairs on same line - with no pairs on the same line - is expected not to be pairs on same line - with some pairs on the same line - is expected to be pairs on same line - #keys - with a hash with string keys - is expected to all be str type - is expected to eq 2 - with an empty hash - is expected to be empty - with a hash with symbol keys - is expected to eq 3 - is expected to all be sym type - #each_key - when passed a block - yields all the pairs - when not passed a block - is expected to be a kind of Enumerator - #braces? - as an argument with braces - is expected to be braces - as an argument with no braces - is expected not to be braces - with braces - is expected to be braces - .new - is expected to be a kind of RuboCop::AST::HashNode - #pairs - with an empty hash - is expected to be empty - with a hash of variables - is expected to eq 2 - is expected to all be pair type - with a hash of literals - is expected to eq 3 - is expected to all be pair type - #each_pair - when passed a block - yields all the pairs - when not passed a block - is expected to be a kind of Enumerator - -RuboCop::AST::AndNode - #inverse_operator - with a semantic and node - is expected to eq "or" - with a logical and node - is expected to eq "||" - .new - with a logical and node - is expected to be a kind of RuboCop::AST::AndNode - with a semantic and node - is expected to be a kind of RuboCop::AST::AndNode - #lhs - with a semantic and node - is expected to be sym type - with a logical and node - is expected to be sym type - #operator - with a logical and node - is expected to eq "&&" - with a semantic and node - is expected to eq "and" - #alternate_operator - with a logical and node - is expected to eq "and" - with a semantic and node - is expected to eq "&&" - #rhs - with a logical and node - is expected to be int type - with a semantic and node - is expected to be int type - #semantic_operator? - with a semantic and node - is expected to be semantic operator - with a logical and node - is expected not to be semantic operator - #logical_operator? - with a semantic and node - is expected not to be logical operator - with a logical and node - is expected to be logical operator - -RuboCop::AST::EnsureNode - .new - is expected to be a kind of RuboCop::AST::EnsureNode - #body - is expected to be sym type + is expected to be else + #elsif_conditional? + with one elsif conditional + is expected to be elsif conditional + with multiple elsif conditionals + is expected to be elsif conditional + with nested conditionals in else clause + is expected not to be elsif conditional + with nested conditionals in if clause + is expected not to be elsif conditional + with nested ternary operators + when nested in the truthy branch + is expected not to be elsif conditional + when nested in the falsey branch + is expected not to be elsif conditional RuboCop::AST::YieldNode - #method_name - is expected to eq :yield - #block_argument? - is expected not to be block argument - #command? - when argument is a symbol - is expected to be command :yield - when argument is a string - is expected to be command "yield" - #block_literal? - is expected not to be block literal - #splat_argument? - with a splat argument - is expected to be splat argument - with mixed arguments - is expected to be splat argument - with regular arguments - is expected not to be splat argument - with no arguments - is expected not to be splat argument - #bang_method? - is expected not to be bang method - #first_argument - with a single splat argument - is expected to be splat type - with a single literal argument - is expected to be sym type - with multiple mixed arguments - is expected to be sym type - with multiple literal arguments - is expected to be sym type - with no arguments - is expected to be nil - #camel_case_method? - is expected not to be camel case method - #dot? - is expected not to be dot #receiver is expected to be nil - #last_argument - with multiple literal arguments - is expected to be sym type - with a single splat argument - is expected to be splat type - with a single literal argument - is expected to be sym type - with no arguments - is expected to be nil - with multiple mixed arguments - is expected to be splat type - #self_receiver? - is expected not to be self receiver #double_colon? is expected not to be double colon - #operator_method? - is expected not to be operator method - #setter_method? - is expected not to be setter method - #const_receiver? - is expected not to be const receiver - #assignment_method? - is expected not to be assignment method - #arguments - with no arguments - is expected to be empty - with multiple mixed arguments - is expected to eq 2 - with a single literal argument - is expected to eq 1 - with a single splat argument - is expected to eq 1 - with multiple literal arguments - is expected to eq 2 #method? - when message matches - when argument is a string - is expected to be method "yield" - when argument is a symbol - is expected to be method :yield when message does not match when argument is a symbol is expected not to be method :foo when argument is a string is expected not to be method "foo" + when message matches + when argument is a symbol + is expected to be method :yield + when argument is a string + is expected to be method "yield" + #command? + when argument is a string + is expected to be command "yield" + when argument is a symbol + is expected to be command :yield #arguments? - with no arguments - is expected not to be arguments - with multiple literal arguments - is expected to be arguments with a single literal argument is expected to be arguments with multiple mixed arguments is expected to be arguments with a single splat argument is expected to be arguments - #macro? - is expected not to be macro + with multiple literal arguments + is expected to be arguments + with no arguments + is expected not to be arguments #block_node is expected to be nil - #parenthesized? - with arguments - when using parentheses - is expected to be parenthesized - when not using parentheses - is expected not to be parenthesized + #assignment_method? + is expected not to be assignment method + #camel_case_method? + is expected not to be camel case method + #splat_argument? + with a splat argument + is expected to be splat argument with no arguments - when not using parentheses - is expected not to be parenthesized - when using parentheses - is expected to be parenthesized - #comparison_method? - is expected not to be comparison method + is expected not to be splat argument + with regular arguments + is expected not to be splat argument + with mixed arguments + is expected to be splat argument #predicate_method? is expected not to be predicate method .new is expected to be a kind of RuboCop::AST::YieldNode - #implicit_call? - is expected not to be implicit call - -RuboCop::AST::ArrayNode - .new - is expected to be a kind of RuboCop::AST::ArrayNode - #values - with an array of variables - is expected to all be send type - is expected to eq 2 - with an array of literals - is expected to eq 3 - is expected to all be literal - with an empty array - is expected to be empty - #percent_literal? - with square brackets - is expected not to be percent literal :symbol - is expected not to be percent literal :string - is expected not to be percent literal - with a string percent literal - is expected to be percent literal :string - is expected to be percent literal - is expected not to be percent literal :symbol - with a symbol percent literal - is expected not to be percent literal :string - is expected to be percent literal :symbol - is expected to be percent literal - #bracketed? - unbracketed - is expected to be nil - with square brackets - is expected to be bracketed - with a percent literal - is expected to be bracketed - #square_brackets? - with a percent literal - is expected not to be square brackets - with square brackets - is expected to be square brackets - #each_value - without block - is expected to be a kind of Enumerator - with block - is expected to eq ["(int 1)", "(int 2)", "(int 3)"] - is expected to be a kind of RuboCop::AST::ArrayNode - -RuboCop::AST::ReturnNode - behaves like wrapped arguments node - .new - with arguments - is expected to be a kind of RuboCop::AST::ReturnNode - without arguments - is expected to be a kind of RuboCop::AST::ReturnNode - #arguments - with a single splat argument - is expected to eq 1 - with a single argument - is expected to eq 1 - with no arguments - is expected to be empty - with no arguments and braces - is expected to be empty - with multiple literal arguments - is expected to eq 2 - with a single argument and braces - is expected to eq 1 - -RuboCop::AST::RescueNode - #branches - when there is no else keyword - returns only then rescue bodies - when there is an else - returns all the bodies - with an empty else - returns all the bodies - #else_branch - with an else statement - is expected to be send type - without an else statement + #macro? + is expected not to be macro + #last_argument + with no arguments is expected to be nil - #else? - without an else statement - is expected not to be else - with an else statement - is expected to be else - #resbody_branches - is expected to eq 2 - is expected to all be resbody type - .new - is expected to be a kind of RuboCop::AST::RescueNode - #body - is expected to be send type - -RuboCop::AST::RangeNode - .new - with a beignless range - is expected to be range type - is expected to be a kind of RuboCop::AST::RangeNode - with an exclusive range - is expected to be range type - is expected to be a kind of RuboCop::AST::RangeNode - with an infinite range - is expected to be range type - is expected to be a kind of RuboCop::AST::RangeNode - with an inclusive range - is expected to be a kind of RuboCop::AST::RangeNode - is expected to be range type - -RuboCop::AST::SuperNode - #implicit_call? - is expected not to be implicit call - #block_literal? - with a block argument - is expected not to be block literal - with a block literal - is expected to be block literal - with no block - is expected not to be block literal - #receiver - is expected to be nil - #setter_method? - is expected not to be setter method - #predicate_method? - is expected not to be predicate method - #assignment_method? - is expected not to be assignment method - #comparison_method? - is expected not to be comparison method - #command? - when argument is a symbol - is expected to be command :super - when argument is a string - is expected to be command "super" - #self_receiver? - is expected not to be self receiver - #camel_case_method? - is expected not to be camel case method - #bang_method? - is expected not to be bang method - #first_argument - with a single splat argument - is expected to be splat type with multiple mixed arguments + is expected to be splat type + with multiple literal arguments is expected to be sym type with a single literal argument is expected to be sym type - with multiple literal arguments - is expected to be sym type - with no arguments - is expected to be nil - #macro? - is expected not to be macro - #method? - when message does not match - when argument is a symbol - is expected not to be method :foo - when argument is a string - is expected not to be method "foo" - when message matches - when argument is a string - is expected to be method "super" - when argument is a symbol - is expected to be method :super - #arguments? with a single splat argument - is expected to be arguments - with no arguments - is expected not to be arguments - with multiple mixed arguments - is expected to be arguments - with multiple literal arguments - is expected to be arguments + is expected to be splat type + #first_argument with a single literal argument - is expected to be arguments - #parenthesized? - with arguments - when not using parentheses - is expected not to be parenthesized - when using parentheses - is expected to be parenthesized - with no arguments - when using parentheses - is expected to be parenthesized - when not using parentheses - is expected not to be parenthesized - #method_name - is expected to eq :super - #dot? - is expected not to be dot - #double_colon? - is expected not to be double colon - #last_argument - with multiple literal arguments is expected to be sym type with no arguments is expected to be nil - with a single literal argument - is expected to be sym type with a single splat argument is expected to be splat type + with multiple literal arguments + is expected to be sym type with multiple mixed arguments - is expected to be splat type - #splat_argument? - with a splat argument - is expected to be splat argument - with no arguments - is expected not to be splat argument - with mixed arguments - is expected to be splat argument - with regular arguments - is expected not to be splat argument - #operator_method? - is expected not to be operator method + is expected to be sym type #const_receiver? is expected not to be const receiver - #block_node - with a block argument - is expected to be nil - with a block literal - is expected to be block type - with no block - is expected to be nil + #comparison_method? + is expected not to be comparison method + #method_name + is expected to eq :yield + #self_receiver? + is expected not to be self receiver + #dot? + is expected not to be dot + #setter_method? + is expected not to be setter method #block_argument? - with regular arguments - is expected not to be block argument - with mixed arguments - is expected to be block argument - with no arguments - is expected not to be block argument - with a block argument - is expected to be block argument + is expected not to be block argument #arguments - with multiple literal arguments + with multiple mixed arguments is expected to eq 2 - with no arguments - is expected to be empty with a single literal argument is expected to eq 1 - with multiple mixed arguments + with no arguments + is expected to be empty + with multiple literal arguments is expected to eq 2 with a single splat argument is expected to eq 1 - .new - with a zsuper node - is expected to be a kind of RuboCop::AST::SuperNode - with a super node - is expected to be a kind of RuboCop::AST::SuperNode - -Changelog - merges correctly - parses correctly - Changelog::Entry - generates correct content - -RuboCop::AST::Ext::Range - #line_span - returns the range of lines a range occupies - accepts an `exclude_end` keyword argument - -RuboCop::AST::RegexpNode - #options - with a regexp with multiple options - is expected to eq 3 - with a regexp with "o" option - is expected to eq 0 - with an empty regexp - is expected to eq 0 - with a regexp without option - is expected to eq 0 - with a regexp with single option - is expected to eq 1 - #single_interpolation? - with o and other options - is expected to be single interpolation - with other options - is expected not to be single interpolation - with no options - is expected not to be single interpolation - with only o option - is expected to be single interpolation - #to_regexp - with a regexp with option - is expected to eq /.+/mix - with a multi-line regexp with option - is expected to eq / -.+ -/ix - with a regexp without option - is expected to eq /.+/ - with an empty regexp with option - is expected to eq //ix - with a regexp with an "u" option - is expected to eq "/abc/" - with a regexp with an "n" option - is expected to eq "/abc/n" - with an empty regexp - is expected to eq // - with a regexp with an "o" option - is expected to eq "/abc/i" - with a multi-line regexp without option - is expected to eq / -.+ -/ - #delimiters - with %r{-delimiters - is expected to eq ["{", "}"] - with %r/-delimiters - is expected to eq ["/", "/"] - with %r<-delimiters - is expected to eq ["<", ">"] - with multi-line %r{-delimiters - is expected to eq ["{", "}"] - with /-delimiters - is expected to eq ["/", "/"] - #no_encoding? - with no options - is expected not to be no encoding - with n and other options - is expected to be no encoding - with only n option - is expected to be no encoding - with other options - is expected not to be no encoding - #content - with a multi-line regexp with option - is expected to eq "\n.+\n" - with a regexp with option - is expected to eq ".+" - with a multi-line regexp without option - is expected to eq "\n.+\n" - with a regexp without option - is expected to eq ".+" - with an empty regexp - is expected to eq "" - with an empty regexp with option - is expected to eq "" - #percent_r_literal? - with %r<-delimiters - is expected to be percent r literal - with /-delimiters - is expected not to be percent r literal - with multi-line %r{-delimiters - is expected to be percent r literal - with %r{-delimiters - is expected to be percent r literal - with %r/-delimiters - is expected to be percent r literal - #regopt - with a regexp with option - is expected to eq [:i, :m, :x] - is expected to be regopt type - with a multi-line regexp without option - is expected to be empty - is expected to be regopt type - with a multi-line regexp with option - is expected to be regopt type - is expected to eq [:i, :m, :x] - with a regexp without option - is expected to be regopt type - is expected to be empty - with an empty regexp with option - is expected to be regopt type - is expected to eq [:i, :x] - with an empty regexp - is expected to be regopt type - is expected to be empty - #fixed_encoding? - with other options - is expected not to be fixed encoding - with u and other options - is expected to be fixed encoding - with only u option - is expected to be fixed encoding - with no options - is expected not to be fixed encoding - #multiline_mode? - with m and other options - is expected to be multiline mode - with only m option - is expected to be multiline mode - with other options - is expected not to be multiline mode - with no options - is expected not to be multiline mode - #interpolation? - with regexp quote - is expected to be interpolation - with no interpolation returns false - is expected not to be interpolation - with direct variable interpoation - is expected to be interpolation - #delimiter? - with multi-line %r{-delimiters - is expected not to be delimiter "/" - is expected not to be delimiter "%" - is expected not to be delimiter "%r/" - is expected not to be delimiter "%r" - is expected not to be delimiter "r" - is expected not to be delimiter "%r{" - is expected to be delimiter "}" - is expected to be delimiter "{" - with /-delimiters - is expected not to be delimiter "{" - is expected to be delimiter "/" - with %r/-delimiters - is expected not to be delimiter "%" - is expected not to be delimiter "%r" - is expected not to be delimiter "{" - is expected not to be delimiter "r" - is expected not to be delimiter "}" - is expected to be delimiter "/" - is expected not to be delimiter "%r/" - with %r{-delimiters - is expected not to be delimiter "%r" - is expected not to be delimiter "/" - is expected not to be delimiter "%" - is expected to be delimiter "}" - is expected to be delimiter "{" - is expected not to be delimiter "%r{" - is expected not to be delimiter "%r/" - is expected not to be delimiter "r" - with %r<-delimiters - is expected not to be delimiter "%r{" - is expected to be delimiter "<" - is expected to be delimiter ">" - is expected not to be delimiter "{" - is expected not to be delimiter "r" - is expected not to be delimiter "%" - is expected not to be delimiter "}" - is expected not to be delimiter "%r" - is expected not to be delimiter "/" - is expected not to be delimiter "%r/" - is expected not to be delimiter "%r<" - .new - is expected to be a kind of RuboCop::AST::RegexpNode - #ignore_case? - with only i option - is expected to be ignore case - with i and other options - is expected to be ignore case - with no options - is expected not to be ignore case - with other options - is expected not to be ignore case - #slash_literal? - with /-delimiters - is expected to be slash literal - with %r<-delimiters - is expected not to be slash literal - with multi-line %r{-delimiters - is expected not to be slash literal - with %r/-delimiters - is expected not to be slash literal - with %r{-delimiters - is expected not to be slash literal - #extended? - with x and other options - is expected to be extended - with no options - is expected not to be extended - with only x option - is expected to be extended - with other options - is expected not to be extended + #block_literal? + is expected not to be block literal + #bang_method? + is expected not to be bang method + #operator_method? + is expected not to be operator method + #parenthesized? + with no arguments + when using parentheses + is expected to be parenthesized + when not using parentheses + is expected not to be parenthesized + with arguments + when not using parentheses + is expected not to be parenthesized + when using parentheses + is expected to be parenthesized + #implicit_call? + is expected not to be implicit call RuboCop::AST::Traversal knows all current node types - for example !/wat/ - traverses all nodes - for example def String=; end - traverses all nodes - for example if foo; bar; elsif baz; 1; else 2; end - traverses all nodes - for example module Bar::Foo; end - traverses all nodes - for example [*foo] + for example < { _1 + _9} + for example a b{c d}, 1.0i do end traverses all nodes - for example f{ |*s| } + for example foo < 1 traverses all nodes - for example %{a\ -b} + for example a, *b = bar traverses all nodes - for example p <<~E -E + for example %x{#@@1} traverses all nodes - for example a b(c(d)), :e do end + for example foo ** 1 traverses all nodes - for example case foo; in x, y, then nil; end + for example m = -> *args do end traverses all nodes - for example foo === 1 + for example 1.33 traverses all nodes - for example foo ** 1 + for example @var = 10 traverses all nodes - for example a b{c(d)}, /x/m do end + for example *b = bar traverses all nodes - for example defined? foo + for example foo[1, 2] traverses all nodes - for example a, *b, c = bar + for example meth 1 do end.fun bar traverses all nodes - for example foo = meth rescue bar + for example f{ |o=1, &b| } traverses all nodes - for example bar unless foo + for example ((b, )) = foo traverses all nodes - for example a b(c(d)), 1.0r do end + for example foo * 1 traverses all nodes - for example def foo; end + for example !/wat/ traverses all nodes - for example %s{a\ -b} + for example !foo traverses all nodes - for example def f ((a, *)); end + for example [*foo] traverses all nodes - for example def f *, **; end + for example case foo; in [x, y, *] then true; end traverses all nodes - for example %W[#@1] + for example meth 1 do end::fun(bar) traverses all nodes - for example :"#@1" + for example case foo; in A[] then true; end traverses all nodes - for example fun do end + for example %w[ #@@1 ] traverses all nodes - for example foo.(1) + for example %r{a\ +b} traverses all nodes - for example f{ |a, c| } + for example f (g rescue nil) traverses all nodes - for example case foo; in (1) then true; end + for example Foo = 10 traverses all nodes - for example %{#@@1} + for example meth do; foo; rescue; bar; end traverses all nodes - for example foo[m bar] + for example !(foo..bar) traverses all nodes - for example super + for example case foo; in [x, *, y] then true; end traverses all nodes - for example def self.foo; end + for example "a\ +b" traverses all nodes - for example @var = 10 + for example fun! traverses all nodes - for example case foo; - in {a: - } - true - ; end + for example case foo; in "a": then true; end traverses all nodes - for example foo::fun bar + for example true ? 1.tap do |n| p n end : 0 traverses all nodes - for example foo < 1 + for example foo, bar = 1, 2 traverses all nodes - for example while foo do meth end + for example -foo traverses all nodes - for example f{ |*s, &b| } + for example (foo, bar) = 1, 2 traverses all nodes - for example fun(*bar, &baz) + for example defined? foo traverses all nodes - for example case foo; in "#{ 'a' }": 1 then true; end + for example case foo; in ** then true; end traverses all nodes - for example case foo; in [x, y, *] then true; end + for example [1, *foo] traverses all nodes - for example def f o=1, p, &b; end + for example fun(1) traverses all nodes - for example a b{c d}, 1 do end + for example f{ |;a| } traverses all nodes - for example f{ |a, &b| } + for example foo[m bar] traverses all nodes - for example $foo + for example if foo...bar; end traverses all nodes - for example def x(_4) end + for example break traverses all nodes - for example case foo; in A::B then true; end + for example self::a, foo = foo traverses all nodes - for example foo.C += raise(bar) rescue nil + for example m [], 1 do end traverses all nodes - for example foo = raise bar rescue nil + for example f{ |o=1, *r, p, &b| } traverses all nodes - for example <<-`HERE` + for example <<-'HERE' #@@1 HERE traverses all nodes - for example case foo; in "#{ %Q{a} }": then true; end + for example f { || a:b } traverses all nodes - for example unless foo then bar; else baz; end + for example 42 traverses all nodes - for example foo::a = 1 + for example begin; meth; rescue; baz; else foo; ensure; bar end traverses all nodes - for example yield + for example foo[0, 1] += m foo traverses all nodes - for example a += 1 + for example /source/im traverses all nodes - for example p <<~E - x - y -E + for example def f a, o=1, &b; end traverses all nodes - for example foo && bar + for example def f a, o=1, *r, &b; end traverses all nodes - for example foo (-1.3).abs + for example m { |foo| } traverses all nodes - for example begin meth end while foo + for example let (:a) { m do; end } traverses all nodes - for example :foo + for example %r{#@@1} traverses all nodes - for example :'#@@1' + for example class << foo; nil; end traverses all nodes - for example case foo; when 'bar'; bar; else baz; end + for example 'a\ +b' traverses all nodes - for example meth while foo + for example f{ |*s| } traverses all nodes - for example (foo, bar) = 1, 2 + for example f{ |a, o=1, o1=2, *r, &b| } traverses all nodes - for example "#@1" + for example meth 1 do end.fun bar do end traverses all nodes - for example p <<~E - x - \ y -E + for example proc {|_3|} traverses all nodes - for example def foo raise; raise A::B, ''; end + for example case foo; in "#{ 'a' }": 1 then true; end traverses all nodes - for example m def x(); end; 1.tap do end + for example proc {_1 = nil} traverses all nodes - for example p begin 1.times do 1 end end + for example case foo; in [x,] then nil; end traverses all nodes - for example %i[foo bar] + when a class defines `on_block_pass` + calls it for all block-pass arguments + for example foo::A += m foo traverses all nodes - for example break(foo) + for example case foo; in A then true; end traverses all nodes - for example p <<~"E" - x - #{foo} + for example f{ |a, o=1, *r, p, &b| } + traverses all nodes + for example %s{#@1} + traverses all nodes + for example p <<~E + x + y E traverses all nodes - for example foo[0, 1] &&= 2 + for example <<-`HERE` +a\ +b +HERE traverses all nodes - for example case foo; in [x, y, *z] then true; end + for example ->{ } traverses all nodes - for example def foo - a:b end + for example 1.. traverses all nodes - for example :"#@@1" + for example while foo do meth end traverses all nodes - for example def String.foo; end + for example fun(:foo => 1, &baz) traverses all nodes - for example p -> { :hello }, a: 1 do end + for example p <<~E + x + y +E traverses all nodes - for example def f ((*r, p)); end + for example case foo; in { a: 1, } then true; end traverses all nodes - for example p ->() do a() do end end + for example -> do end traverses all nodes - for example foo = bar = m foo + for example ->(**nil) {} traverses all nodes - for example <<`HERE` -foo -bar -HERE + for example [1, *foo, 2] traverses all nodes - for example f{ |a, *s| } + for example f{ |a, *, &b| } traverses all nodes - for example foo && (a, b = bar) + for example +2.0 ** 10 traverses all nodes - for example case foo; in 1, "a", [], {} then nil; end + for example def _5; end traverses all nodes - for example foo "#{(1+1).to_i}" do; end + for example a, * = bar traverses all nodes - for example { 'foo': 2 } + for example @a |= 1 traverses all nodes - for example case foo; - in {a: - 2} - false - ; end + for example case foo; in x then x; end traverses all nodes - for example %s{#@@1} + for example def String::foo; end traverses all nodes - for example /\xa8/n =~ "" + for example meth while foo traverses all nodes - for example p <<~E - x - y -E + for example alias $a $+ traverses all nodes - for example # coding:utf-8 - "\xD0\xBF\xD1\x80\xD0\xBE\xD0\xB2\xD0\xB5\xD1\x80\xD0\xBA\xD0\xB0" + for example def f a, *r, p, &b; end traverses all nodes - for example foo * 1 + for example a b{c d}, 1.0 do end traverses all nodes - for example a b{c d}, /x/m do end + for example %s{a\ +b} traverses all nodes - for example yield foo + for example $10 traverses all nodes - for example p <<~`E` - x - #{foo} -E + for example def f foo: +; end traverses all nodes - for example a b(c(d)), 1.0 do end + for example foo ? 1 : 2 traverses all nodes - for example if (bar; a, b = foo); end + for example foo::Fun() traverses all nodes - for example foo.fun bar + for example { 'foo': 2 } traverses all nodes - for example meth until foo + for example class A < B +end traverses all nodes - for example foo[1, 2] = 3 + for example a b(c d), :e do end traverses all nodes - for example def f ((*, p)); end + for example def f (((a))); end traverses all nodes - for example case foo; when 'bar' then bar; end + for example foo[:baz => 1,] traverses all nodes - for example foo / 1 + for example def a b: +return +end traverses all nodes - for example p <<~"E" - x - #{" y"} -E + for example foo.a += m foo traverses all nodes - for example def f ((a, *r)); end + for example foo && (a, b = bar) traverses all nodes - for example "#{-> foo {}}" + for example foo[bar,] traverses all nodes - for example fun(*bar) + for example def f(**); end traverses all nodes - for example false ? raise do end : tap do end + for example @@var = 10 traverses all nodes - for example f{ |o=1, &b| } + for example f{ |foo: 1, bar: 2, **baz, &b| } traverses all nodes - for example def m; class << self; class C; end; end; end + for example %q(foobar) traverses all nodes - for example -> * { } + for example A += 1 traverses all nodes - for example f{ |;a| } + for example for a, b in foo; p a, b; end traverses all nodes - for example unless foo; bar; else baz; end + for example case foo; in { a: 1 } then true; end traverses all nodes - for example break() + for example foo[bar, :baz => 1,] traverses all nodes - for example foo += m foo + for example p begin 1.times do 1 end end traverses all nodes - for example def foo(...); bar(...); end + for example ->(a; foo, bar) { } traverses all nodes - for example `#@@1` + for example foo::m += raise(bar) rescue nil traverses all nodes - for example foo, bar, baz = 1, 2 + for example Bar::Foo traverses all nodes - for example `a\ -b` + for example def f ((a, *r, p)); end traverses all nodes - for example -> do _1 + _9 end + for example -> (a) { } traverses all nodes - for example foo::a += 1 + for example foo = *bar traverses all nodes - for example fun (f bar) + for example "#@a #@@a #$a" traverses all nodes - for example f(a ? "a":1) + for example assert dogs traverses all nodes - for example def self.m; _1; end + for example foo[0] += raise bar rescue nil traverses all nodes - for example fun(f bar) + for example foo::(1) traverses all nodes - for example while def self.foo; tap do end; end; break; end + for example case foo; in "#{ %q{a} }": 1 then true; end traverses all nodes - for example def m; class << self; A = nil; end; end + for example fun (1).to_i traverses all nodes - for example @a |= 1 + for example ->{ } traverses all nodes - for example 1.33 + for example begin ensure end traverses all nodes - for example f{ |&b| } + for example %i[ #@@1 ] traverses all nodes - for example retry + for example p <<~E + x + \ y +E traverses all nodes - for example a b{c(d)}, 1.0i do end + for example f{ |*r, p, &b| } traverses all nodes - for example <<-'HERE' -a\ -b -HERE + for example case foo; in x, then nil; end traverses all nodes - for example break foo + for example fun (1) {} traverses all nodes - for example f{ |*| } + for example foo << 1 traverses all nodes - for example module A; _1; end + for example foo || bar traverses all nodes - for example f{ |a| } + for example { 1 => 2 } traverses all nodes - for example <<-`HERE` + for example <<-"HERE" a\ b HERE traverses all nodes - for example foo, bar = 1, 2 + for example for a in foo; p a; end traverses all nodes - for example def f **baz, &b; end + for example "#{-> foo {}}" traverses all nodes - for example foo & 1 + for example case foo; in 1, "a", [], {} then nil; end traverses all nodes - for example return foo + for example foo | 1 traverses all nodes - for example class << foo; _1; end + for example def f ((*, p)); end traverses all nodes - for example def foo(_a, _a); end + for example foo === 1 traverses all nodes - for example return fun foo do end + for example foo[0, 1] ||= 2 traverses all nodes - for example foo.a = 1 + for example %q{#@@1} traverses all nodes - for example f{ |*r, p, &b| } + for example /\xa8/n =~ "" traverses all nodes - for example f{ |a, *, &b| } + for example m def x(); end; 1.tap do end traverses all nodes - for example case foo; in "#{ 'a' }": then true; end + for example def f o=1, *r, &b; end traverses all nodes - for example case foo; in a:, b: then true; end + for example if (a, b = foo); end traverses all nodes - for example def f ((*r)); end + for example foo.a &&= 1 traverses all nodes - for example fun (1).to_i + for example a b{c(d)}, /x/m do end traverses all nodes - for example def f(**); end + for example traverses all nodes - for example td (1_500).toString(); td.num do; end + for example +42 traverses all nodes for example super() traverses all nodes - for example def f ; end + for example a b(c(d)), 1 do end traverses all nodes - for example a b(c d), 1 do end + for example true traverses all nodes - for example ..100 + for example case foo; in [*, x] then true; end traverses all nodes - for example fun(1) + for example return fun foo do end traverses all nodes - for example foo <= 1 + for example foo[1, 2] = 3 traverses all nodes - for example foo[0, 1] += m foo + for example 1...2 traverses all nodes - for example case foo; in "a": 1 then true; end + for example m { _1 + _9 } traverses all nodes - for example class Foo < Bar; end + for example f{ || } traverses all nodes - for example case foo; in x unless true; nil; end + for example %I() traverses all nodes - for example foo.A += m foo + for example p <<~"E" + x\n y +E traverses all nodes - for example def f(**nil); end + for example def f **baz, &b; end traverses all nodes - for example :'foo' + for example foo, bar = m foo traverses all nodes - for example begin; meth; rescue; foo; else; bar; end + for example while not (true) do end traverses all nodes - for example case foo; in ::A then true; end + for example def String; end traverses all nodes - for example %I() + for example def (foo).foo; end traverses all nodes for example while def self.foo a = tap do end; end; break; end traverses all nodes - for example *, c, d = bar - traverses all nodes - for example %x{#@1} - traverses all nodes - for example [1, *foo, 2] - traverses all nodes - for example def f ((a, *, p)); end - traverses all nodes - for example [ 1, 2 => 3 ] + for example self.A, foo = foo traverses all nodes - for example defined?(foo) + for example next() traverses all nodes - for example a += b += raise :x + for example %i[] traverses all nodes - for example %W"#{1}" + for example if foo then bar; else baz; end traverses all nodes - for example a b(c(d)), 1 do end + for example f{ |o=1, p, &b| } traverses all nodes - for example proc {_1 = nil} + for example %i[ #@1 ] traverses all nodes - for example f{ |a, o=1, &b| } + for example if /wat/; end traverses all nodes - for example case foo; in self then true; end + for example ::A += 1 traverses all nodes - for example true + for example redo traverses all nodes - for example foo[1, 2] + for example fun (f bar) traverses all nodes - for example case foo; in {} then true; end + for example B::A += 1 traverses all nodes - for example if foo; bar; end + for example "foo#{bar}baz" traverses all nodes - for example begin ensure end + for example foo.A += 1 traverses all nodes - for example def foo(...); end + for example foo >= 1 traverses all nodes - for example END { 1 } + for example foo = meth rescue bar traverses all nodes - for example f{ |foo: 1, &b| } + for example *, c, d = bar traverses all nodes - for example { 1 => 2 } + for example foo + 1 traverses all nodes - for example foo.a ||= 1 + for example a b(c(d)), 1.0 do end traverses all nodes - for example case foo; in a: 1, b: 2 then true; end + for example alias :foo bar traverses all nodes - for example Foo = 10 + for example foo[0, 1] += 2 traverses all nodes - for example 42i + for example foo = raise(bar) rescue nil traverses all nodes - for example if foo then bar; end + for example module Bar::Foo; end traverses all nodes - for example case foo; in A(1, 2) then true; end + for example unless foo; bar; else baz; end traverses all nodes - for example < proc do end, b: proc do end} + for example %I[#@@1] traverses all nodes - for example desc "foo" do end + for example case foo; in 1 => a then true; end traverses all nodes - for example f{ |a, *s, &b| } + for example def f *r, &b; end traverses all nodes - for example p <<~E - E + for example :'#@1' traverses all nodes - for example case foo; in [x, *, y] then true; end + for example case foo; in [x, *y, z] then true; end traverses all nodes - for example f{ |a, o=1, *r, p, &b| } + for example def f(foo=1, bar=2); end traverses all nodes - for example def a; @@var |= 10; end + for example case foo; in x unless true; nil; end traverses all nodes - for example until foo; meth end + for example f{ |a,| } traverses all nodes - for example a b(c d), /x/m do end + for example def f ((a, a1)); end traverses all nodes - for example foo[:baz => 1,] + for example a b(c(d)), 1.0r do end traverses all nodes - for example m { |**nil| } + for example def f foo = 1; end traverses all nodes - for example %i[] + for example foo::a += 1 traverses all nodes - for example def f o=1, *r, p, &b; end + for example def f a, &b; end traverses all nodes - for example super foo + for example f(a ? "a":1) traverses all nodes - for example true ? 1.tap do |n| p n end : 0 + for example case foo; in a: 1, b: 2 then true; end traverses all nodes - for example foo, bar = meth rescue [1, 2] + for example def foo raise; raise A::B, ''; end traverses all nodes - for example def f o=1, *r, &b; end + for example %q{a\ +b} traverses all nodes - for example def f a, &b; end + for example foo::a += m foo traverses all nodes - for example a b(c(d)), /x/ do end + for example foo "#{(1+1).to_i}" do; end traverses all nodes - for example begin; meth; rescue Exception; bar; end + for example __ENCODING__ traverses all nodes - for example nil + for example <<`HERE` +foo +bar +HERE traverses all nodes - for example fun (1) + for example [ 1, 2 => 3 ] traverses all nodes - for example foo += meth rescue bar + for example a b{c(d)}, 1.0i do end traverses all nodes - for example m do _1 + _9 end + for example case foo; + in {a: 1 + } + false + ; end traverses all nodes - for example f (g rescue nil) + for example f{ |a, *| } traverses all nodes - for example foo&.bar {} + for example def foo + a:b end traverses all nodes - for example f{ |foo: 1, bar: 2, **baz, &b| } + for example -> do _1 + _9 end traverses all nodes - for example a = b += raise :x + for example while foo; meth end traverses all nodes - for example case foo; in 1 => a then true; end + for example unless foo then bar; else baz; end traverses all nodes - for example 1.. + for example def String.foo; end traverses all nodes - for example def f(foo); end + for example %i{a\ +b} traverses all nodes - for example f{ |o=1, *r, p, &b| } + for example false ? raise {} : tap {} traverses all nodes - for example fun + for example a += b += raise :x traverses all nodes - for example `#@1` + for example %Q{#@1} traverses all nodes - for example case foo; in A[x:] then true; end + for example foo ^ 1 traverses all nodes - for example m ->(a: ->{_1}) {a} + for example f <<-TABLE do +TABLE +end traverses all nodes - for example def f foo = 1; end + for example foo.fun (1) {} traverses all nodes - for example a&.b + for example ->(a) { } traverses all nodes - for example [/()\1/, ?#] + for example def foo(...); end traverses all nodes - for example a b{c d}, 1.0i do end + for example self::A, foo = foo traverses all nodes - for example 42ri + for example %x{a\ +b} traverses all nodes - for example %i[ #@1 ] + for example foo, bar = meth rescue [1, 2] traverses all nodes - for example until foo do meth end + for example td (1_500).toString(); td.num do; end traverses all nodes - for example foo::Fun bar + for example foo::a = 1 traverses all nodes - for example yield(foo) + for example foo traverses all nodes - for example ->(a; foo, bar) { } + for example <<-E + 1 \ + 2 + 3 +E traverses all nodes - for example if foo..bar; end + for example a b(c d), 1 do end traverses all nodes - for example class Foo end + for example foo::fun traverses all nodes - for example a # -# -&.foo + for example case foo; in x, *y, z then nil; end traverses all nodes - for example !foo + for example %W[#@@1] traverses all nodes - for example :'a\ -b' + for example def f *, **; end traverses all nodes - for example `foobar` + for example if (bar; a, b = foo); end traverses all nodes - for example foo + for example case foo; in **a then true; end traverses all nodes - for example m ->(a = ->{_1}) {a} + for example p <<~E + x + + y +E traverses all nodes - for example super(foo) + for example %w[ #@1 ] traverses all nodes - for example def self::foo; end + for example fun(1) { } traverses all nodes - for example case foo; in x, y then nil; end + for example :"a\ +b" traverses all nodes - for example fun(1) { } + for example begin; meth; rescue; foo; end traverses all nodes - for example return + for example meth (-1.3).abs traverses all nodes - for example begin foo!; bar! end + for example m do _1 + _9 end traverses all nodes - for example while def foo; tap do end; end; break; end + for example case foo; in A() then true; end traverses all nodes - for example %{#@1} + for example a # + # +.foo traverses all nodes - for example $10 + for example f{ |a, o=1, &b| } traverses all nodes - for example /#{1}(?bar)/ =~ 'bar' + for example END { 1 } traverses all nodes - for example foo != 1 + for example Bar::Foo = 10 traverses all nodes - for example -2.0 ** 10 + for example class Foo end traverses all nodes - for example %i{a\ -b} + for example foo - 1 traverses all nodes - for example foo::fun + for example case foo; in x, y, then nil; end traverses all nodes - for example __LINE__ + for example foo[0, 1] &&= 2 traverses all nodes - for example p <<~E " y" - x -E + for example while def self.foo; tap do end; end; break; end traverses all nodes - for example alias $a $+ + for example begin; meth; rescue => @ex; bar; end traverses all nodes - for example def foo(...); bar(...); end + for example m a + b do end traverses all nodes - for example %r{#@1} + for example fun () {} traverses all nodes - for example case foo; in 1 | 2 then true; end + for example %w[] traverses all nodes - for example if foo -then bar end + for example case foo; when 'bar'; bar; else baz; end traverses all nodes - for example let (:a) { m do; end } + for example class Foo < Bar; end traverses all nodes - for example foo += raise bar rescue nil + for example until foo; meth end traverses all nodes - for example case foo; in { a: 1, } then true; end + for example def BEGIN; end traverses all nodes - for example f{ |**baz, &b| } + for example begin; meth; rescue => ex; bar; end traverses all nodes - for example %I[#@@1] + for example case foo; in a:, b: then true; end traverses all nodes - for example 'foobar' + for example case foo; in A[1, 2] then true; end traverses all nodes - for example '#@1' + for example def f(foo: 1); end traverses all nodes - for example BEGIN { 1 } + for example case foo; in x if true; nil; end traverses all nodes - for example fun (1 -) + for example def f(**foo); end traverses all nodes - for example case foo; in **nil then true; end + for example a b{c d}, 1.0r do end traverses all nodes - for example bar def foo; self.each do end end + for example p ->() do a() do end end traverses all nodes - for example a # - # -.foo + for example /a\ +b/ traverses all nodes - for example foo += raise(bar) rescue nil + for example a += 1 traverses all nodes - for example fun! + for example super traverses all nodes - for example def _5; end + for example return foo traverses all nodes - for example %x{a\ -b} + for example case foo; in x, y then nil; end traverses all nodes - for example a b(c d), /x/ do end + for example f{ |*| } traverses all nodes - for example foo::a += m foo + for example f{ |; +a +| } traverses all nodes - for example p <<~E - x - y -E + for example case foo; in [*x, y] then true; end traverses all nodes - for example case foo; in ..2 then true; end + for example break(foo) traverses all nodes - for example next foo + for example defined?(foo) traverses all nodes - for example %w[foo bar] + for example %w{a\ +b} traverses all nodes - for example !(foo..bar) + for example -> { _1 + _9} traverses all nodes - for example %r{#@@1} + for example f{ |foo: 1, &b| } traverses all nodes - for example a b{c d}, :e do end + for example case foo; in A[x:] then true; end traverses all nodes - for example p <<~E - x - \ y -E + for example a b(c d), 1.0 do end traverses all nodes - for example foo::C ||= raise(bar) rescue nil + for example %Q{a\ +b} traverses all nodes - when a class defines `on_block_pass` - calls it for all block-pass arguments - for example p <<~"E" - x\n y -E + for example @foo, @@bar = *foo traverses all nodes - for example a b{c(d)}, 1.0 do end + for example f{ |*, &b| } traverses all nodes - for example "#@@1" + for example case foo; in A::B then true; end traverses all nodes - for example { foo: 2, **bar } + for example false ? raise do end : tap do end traverses all nodes - for example while class Foo a = tap do end; end; break; end + for example f{ |a, b,| } traverses all nodes - for example def self._6; end + for example a = b = raise :x traverses all nodes - for example a b(c d), 1.0i do end + for example foo = bar = m foo traverses all nodes - for example next fun foo do end + for example yield(foo) traverses all nodes - for example _2 = 1 + for example case; when foo; 'foo'; end traverses all nodes - for example 1...2 + for example case foo; in 1...2 then true; end traverses all nodes - for example fun (1) {} + for example case foo; in 1..2 then true; end traverses all nodes - for example while not (true) do end + for example foo&.bar {} traverses all nodes - for example %Q{#@1} + for example 'foobar' traverses all nodes - for example a b(c d), 1.0r do end + for example *b, c = bar traverses all nodes - for example m a + b do end + for example f{ |a| } traverses all nodes - for example { 'foo': 2, 'bar': {}} + for example `a\ +b` traverses all nodes - for example case foo; in [*x, y] then true; end + for example p <<~E + x + +y +E traverses all nodes - for example not(foo) + for example case foo; in ..2 then true; end traverses all nodes - for example f{ |a, *| } + for example module ::Foo; end traverses all nodes - for example ::A += 1 + for example a = 1; a b: 1 traverses all nodes - for example { foo: 2 } + for example :'a\ +b' traverses all nodes - for example module Foo; end + for example foo::m += raise bar rescue nil traverses all nodes - for example fun() { } + for example # coding:utf-8 + "\xD0\xBF\xD1\x80\xD0\xBE\xD0\xB2\xD0\xB5\xD1\x80\xD0\xBA\xD0\xB0" traverses all nodes - for example def f(&block); end + for example case foo; when 'bar', 'baz'; bar; end traverses all nodes - for example ->{ } + for example p <<~E + x + y +E traverses all nodes - for example fun(foo, :foo => 1) + for example case 1; in 2; 3; else; end traverses all nodes - for example def foo(...); super(...); end + for example ...100 traverses all nodes - for example %q(foobar) + for example class A; _1; end traverses all nodes - for example def String; end + for example begin; rescue LoadError; else; end traverses all nodes - for example <<-'HERE' -#@1 -HERE + for example m ->(a: ->{_1}) {a} traverses all nodes - for example foo and bar + for example super foo traverses all nodes - for example /foo#{bar}baz/ + for example nil traverses all nodes - for example false + for example begin end traverses all nodes - for example o = { -a: -1 -} + for example foo (-1.3).abs traverses all nodes - for example def f(*foo); end + for example {a: if true then 42 end} traverses all nodes - for example %i[ #@@1 ] + for example case foo; in 1.. then true; end traverses all nodes - for example foo.C += raise bar rescue nil + for example next fun foo do end traverses all nodes - for example %Q{a\ -b} + for example case foo; in 1... then true; end traverses all nodes - for example { 1 => 2, :foo => "bar" } + for example @foo traverses all nodes - for example foo[0] += raise(bar) rescue nil + for example def x; self::A ||= 1; end traverses all nodes - for example foo % 1 + for example m "#{[]}" traverses all nodes - for example class Foo; end + for example foo += raise(bar) rescue nil traverses all nodes - for example foo.m += raise(bar) rescue nil + for example foo.a = 1 traverses all nodes - for example begin; meth; rescue; baz; ensure; bar; end + for example meth until foo traverses all nodes - for example 1... + for example if foo; bar; elsif baz; 1; else 2; end traverses all nodes - for example case foo; in ...2 then true; end + for example a &&= 1 traverses all nodes - for example foo == 1 + for example <<~E + 1 \ + 2 + 3 +E traverses all nodes - for example meth 1 do end::fun bar + for example fun(*bar) traverses all nodes - for example case foo; in A() then true; end + for example case foo; in a: 1, _a:, ** then true; end traverses all nodes - for example B::A += 1 + for example %W{a\ +b} traverses all nodes - for example * = bar + for example %I[foo #{bar}] traverses all nodes - for example %x{#@@1} + for example def until; end traverses all nodes - for example case foo; in ^foo then nil; end + for example a b(c d), /x/m do end traverses all nodes - for example foo[bar,] + for example foo::C ||= raise bar rescue nil traverses all nodes - for example lambda{|;a|a} + for example case foo; in "#{ 'a' }": then true; end traverses all nodes - for example m { |foo| } + for example def self.foo; end traverses all nodes - for example <<-"HERE" -a\ -b -HERE + for example %I[#@1] traverses all nodes - for example case foo; in a: 1 then true; end + for example f{ |o=1, *r, &b| } traverses all nodes - for example for a in foo do p a; end + for example '#@@1' traverses all nodes - for example __FILE__ + for example def f ((a, *r)); end traverses all nodes - for example if (a, b = foo); end + for example f{ |foo:| } traverses all nodes - for example def f foo: -; end + for example %Q{#@@1} traverses all nodes - for example <<-`HERE` -#@1 -HERE + for example foo / 1 traverses all nodes - for example case foo; in "#{ %Q{a} }": 1 then true; end + for example not foo traverses all nodes - for example foo >= 1 + for example begin; meth; ensure; bar; end traverses all nodes - for example %W[foo #{bar}] + for example if foo then bar; end traverses all nodes - for example super foo, bar do end + for example "#@@1" traverses all nodes - for example /a\ -b/ + for example %{#@1} traverses all nodes - for example f{ || } + for example module A; _1; end traverses all nodes for example case foo; - in {a: 1 - } + in {a: + 2} false ; end traverses all nodes - for example def f o=1, &b; end - traverses all nodes - for example %W[#@@1] - traverses all nodes - for example a b{c d}, 1.0 do end + for example :"#@1" traverses all nodes for example f x: -> do meth do end end traverses all nodes - for example !(a, b = foo) + for example foo && bar traverses all nodes - for example foo[1, 2] + for example case foo; in "#{ %Q{a} }": then true; end traverses all nodes - for example def f (foo: 1, bar: 2, **baz, &b); end + for example foo.(1) traverses all nodes - for example if foo then bar; else baz; end + for example foo.a += 1 traverses all nodes - for example self::a, foo = foo + for example ..100 traverses all nodes - for example case 1; in 2; 3; else; 4; end + for example break foo traverses all nodes - for example case foo; in "#{ %q{a} }": then true; end + for example return(foo) traverses all nodes - for example !m foo + for example foo[1, 2] = 3 traverses all nodes - for example %W{a\ + for example case foo; in *x then nil; end + traverses all nodes + for example %{a\ b} traverses all nodes - for example meth 1 do end.fun bar + for example if (bar); foo; end traverses all nodes - for example unless foo; bar; end + for example case 1; in 2; 3; else; 4; end traverses all nodes - for example {a: if true then 42 end} + for example foo || (a, b = bar) traverses all nodes - for example case foo; when 1, *baz; bar; when *foo; end + for example foo =~ 1 traverses all nodes - for example def f (((a))); end + for example { 1 => 2, :foo => "bar" } traverses all nodes - for example alias :foo bar + for example foo != 1 traverses all nodes - for example meth (-1.3).abs + for example %r{#@1} traverses all nodes - for example @foo + for example !(a, b = foo) traverses all nodes - for example +2.0 ** 10 + for example !m foo traverses all nodes - for example a b{c d}, "x" do end + for example case foo; in {} then true; end traverses all nodes - for example foo.A = 1 + for example case foo; in a: 1 then true; end traverses all nodes - for example p :foo, {** proc do end, b: proc do end} + for example <<-`HERE` +#@1 +HERE traverses all nodes - for example next(foo) + for example fun(f bar) traverses all nodes - for example Bar::Foo = 10 + for example while def foo; tap do end; end; break; end traverses all nodes - for example break + for example case foo; in "#{ %q{a} }": then true; end traverses all nodes - for example ::Foo = 10 + for example def f a, o=1, p, &b; end traverses all nodes - for example @foo, @@bar = *foo + for example def m; class << self; class C; end; end; end traverses all nodes - for example @@var |= 10 + for example foo = bar, 1 traverses all nodes - for example if foo...bar; end + for example foo == 1 traverses all nodes - for example %Q{#@@1} + for example case foo; in ...2 then true; end traverses all nodes - for example foo | 1 + for example def foo(...); bar(...); end traverses all nodes - for example <<-"HERE" -#@@1 -HERE + for example def String=; end traverses all nodes - for example while class << self; a = tap do end; end; break; end + for example "foo#@a" "bar" traverses all nodes - for example A += 1 + for example fun(foo, *bar) traverses all nodes - for example case foo; in ->{ 42 } then true; end + for example if foo; bar; end traverses all nodes - for example case foo; in 1...2 then true; end + for example foo += m foo traverses all nodes - for example false ? raise {} : tap {} + for example a ||= 1 traverses all nodes - for example not m foo + for example !(foo...bar) traverses all nodes - for example ::Foo + for example self.a, self[1, 2] = foo traverses all nodes - for example a &&= 1 + for example m "#{}#{()}" traverses all nodes - for example # Extracted from `parser` gem. -# Add the following code at the beginning of `def assert_parses`: -# -# File.open('./out.rb', 'a+') do |f| -# f << code << "\n\n#----\n" if versions.include? '2.7' -# end - -alias $a $b + when given an unexpected AST + with too few children + raises debugging error + with too many children + raises debugging error + for example %W[#@1] traverses all nodes - for example m "#{}#{()}" + for example `foo#{bar}baz` traverses all nodes - for example foo.fun (1) {} + for example a&.b = 1 traverses all nodes - for example begin meth end until foo + for example case foo; in "#{ %Q{a} }": 1 then true; end traverses all nodes - for example "#{1}" + for example def self.m; _1; end traverses all nodes - for example defined? @foo + for example p <<~"E" + x + #{" y"} +E traverses all nodes - for example begin; rescue LoadError; else; end + for example def f foo: -1 +; end traverses all nodes - for example ((b, )) = foo + for example :'#@@1' traverses all nodes - for example f{ |a| } + for example yield() traverses all nodes - for example def m; class << self; module M; end; end; end + for example ::Foo = 10 traverses all nodes - for example foo << 1 + for example t=1;(foo)?t:T traverses all nodes - for example begin; meth; rescue => ex; bar; end + for example foo, bar, baz = 1, 2 traverses all nodes - for example case foo; in x then x; end + for example -> do rescue; end traverses all nodes - for example case foo; in 1.. then true; end + for example break() traverses all nodes - for example def f ((a, a1)); end + for example foo.A += m foo traverses all nodes - for example f <<-TABLE do -TABLE -end + for example [/()\1/, ?#] traverses all nodes - for example foo + 1 + for example %{#@@1} traverses all nodes - for example fun(foo, *bar, &baz) + for example m { |**nil| } traverses all nodes - for example meth 1 do end::fun(bar) + for example a b{c d}, :e do end traverses all nodes - for example /(?bar)/ =~ 'bar'; match + for example unless foo; bar; end traverses all nodes - for example foo >> 1 + for example { foo: 2, **bar } traverses all nodes - for example ->(scope) {}; scope + for example fun (1 +) traverses all nodes - for example /#)/x + for example a b(c(d)), /x/m do end traverses all nodes - for example foo::fun (1) {} + for example begin; meth; rescue Exception, foo; bar; end traverses all nodes - for example def f(foo:); end + for example -> (arg={}) {} traverses all nodes - for example m { |(foo, bar)| } + for example '#@1' traverses all nodes - for example a b{c(d)}, :e do end + for example f{ |a, &b| } traverses all nodes - for example a b{c d}, /x/ do end + for example begin; meth; rescue; baz; ensure; bar; end traverses all nodes - for example foo or bar + for example meth 1 do end.fun(bar) traverses all nodes - for example case foo; in A[1, 2] then true; end + for example begin; meth; rescue foo => ex; bar; end traverses all nodes - for example p <<~E - x - y -E + for example <<-`HERE` +#@@1 +HERE traverses all nodes - for example 42r + for example def a; @@var |= 10; end traverses all nodes - for example foo, bar = m foo + for example def foo(_a, _a); end traverses all nodes - for example fun { } + for example def END; end traverses all nodes - for example def f(foo: 1); end + for example f{ } traverses all nodes - for example ...100 + for example def f ((*r)); end traverses all nodes - for example a b(c d), 1.0 do end + for example m [] do end traverses all nodes - for example p :foo, {:a => proc do end, b: proc do end} + for example def f ((*r, p)); end traverses all nodes - for example next + for example a b{c d}, /x/ do end traverses all nodes - for example self.a, self[1, 2] = foo + for example p :foo, {"a": proc do end, b: proc do end} traverses all nodes - for example def f(foo, bar); end + for example super(foo) traverses all nodes - for example fun(&bar) + for example foo::Fun bar traverses all nodes - for example module ::Foo; end + for example p -> { :hello }, a: 1 do end traverses all nodes - for example %q{a\ -b} + for example <<-'HERE' +a\ +b +HERE traverses all nodes - for example def foo() a:b end + for example f{ |**baz, &b| } traverses all nodes - for example !(foo...bar) + for example meth[] {} traverses all nodes - for example def f a, o=1, p, &b; end + for example ::A, foo = foo traverses all nodes - for example case; when foo; 'foo'; end + for example def f a, *r, &b; end traverses all nodes - for example :"foo#{bar}baz" + for example a = b += raise :x traverses all nodes - for example foo = bar, 1 + for example { 'foo': 2, 'bar': {}} traverses all nodes - for example foo !~ 1 + for example * = bar traverses all nodes - for example case foo; in *x, y, z then nil; end + for example foo <=> 1 traverses all nodes - for example case foo; in A then true; end + for example def f ((*)); end traverses all nodes - for example while class Foo; tap do end; end; break; end + for example def f o=1, *r, p, &b; end traverses all nodes - for example case foo; in [x,] then nil; end + for example %W() traverses all nodes - for example foo <=> 1 + for example def f a, o=1, *r, p, &b; end traverses all nodes - for example foo || (a, b = bar) + for example def f (foo: 1, &b); end traverses all nodes - for example foo > 1 + for example yield foo traverses all nodes - for example %w[] + for example a b{c(d)}, 1.0r do end traverses all nodes - for example self::A, foo = foo + for example a&.b &&= 1 traverses all nodes - for example m1 :k => m2 do; m3() do end; end + for example class Foo; end traverses all nodes - for example a = b = raise :x + for example bar if foo traverses all nodes - for example undef foo, :bar, :"foo#{1}" + for example case foo; in ::A then true; end traverses all nodes - for example Foo + for example defined? @foo traverses all nodes - for example a b{c(d)}, 1.0r do end + for example 42.1r traverses all nodes - for example redo + for example foo::fun bar traverses all nodes - for example case foo; in "#{ %q{a} }": 1 then true; end + for example while class << self; a = tap do end; end; break; end traverses all nodes - for example case foo; in "a": then true; end + for example %i[foo bar] traverses all nodes - for example f { || a:b } + for example 42ri traverses all nodes - for example _1 + for example 1... traverses all nodes - for example foo =~ 1 + for example <<~FOO + baz\ + qux +FOO traverses all nodes - for example 42.1r + for example a += b = raise :x traverses all nodes - for example ->{ } + for example class Foo < a:b; end traverses all nodes - for example while def foo a = tap do end; end; break; end + for example while class << self; tap do end; end; break; end + traverses all nodes + for example a&.b + traverses all nodes + for example begin; meth; rescue Exception; bar; end + traverses all nodes + for example :'foo' traverses all nodes for example tap (proc do end) traverses all nodes - for example -2 ** 10 + for example foo.fun bar traverses all nodes - for example a ||= 1 + for example p <<~"E" + x + #{foo} +E traverses all nodes - for example fun(:foo => 1) + for example def f o=1, p, &b; end traverses all nodes - for example let () { m(a) do; end } + for example case foo; in self then true; end traverses all nodes - for example if foo; bar; else baz; end + for example fun(foo, :foo => 1) traverses all nodes - for example 42 + for example while def foo a = tap do end; end; break; end traverses all nodes - for example @@var = 10 + for example __ENCODING__ traverses all nodes - for example case foo; in *x then nil; end + for example _2 = 1 traverses all nodes - for example return(foo) + for example <<-"HERE" +#@1 +HERE traverses all nodes - for example foo ? 1 : 2 + for example lambda{|;a|a} traverses all nodes - for example t=1;(foo)?t:T + for example <<-'HERE' +#@1 +HERE traverses all nodes - for example foo.fun + for example %q{#@1} traverses all nodes - for example $+ + for example %W"#{1}" traverses all nodes - for example foo ^ 1 + for example fun do end traverses all nodes - for example %W[foo #{bar}foo#@baz] + for example a, b = *foo, bar traverses all nodes - for example foo::m += raise(bar) rescue nil + for example def x; ::A ||= 1; end traverses all nodes - for example f{ |o=1, *r, &b| } + for example :foo traverses all nodes - for example assert do: true + for example %W[foo #{bar}] traverses all nodes - for example case foo; in **a then true; end + for example return() traverses all nodes - for example if (bar); foo; end + for example def f ; end traverses all nodes - for example '#@@1' + for example meth 1 do end.fun {} traverses all nodes - for example [1, 2] + for example case foo; + in {Foo: 42 + } + false + ; end traverses all nodes - for example case foo; in A(x:) then true; end + for example while class Foo; tap do end; end; break; end traverses all nodes - for example "foo#@a" "bar" + for example case foo; in * then nil; end traverses all nodes - for example yield() + for example foo::A = 1 traverses all nodes - for example foo = baz, *bar + for example p :foo, {proc do end => proc do end, b: proc do end} traverses all nodes - for example -foo + for example case foo; in ->{ 42 } then true; end traverses all nodes for example p <<~E - x + x + y E traverses all nodes - for example m { _1 + _9 } - traverses all nodes - for example fun () {} + for example def f(foo:); end traverses all nodes - for example def f foo: -1 -; end + for example a b{c(d)}, /x/ do end traverses all nodes - for example case foo; when 'bar'; bar; end + for example case foo; + in a: {b:}, c: + p c + ; end traverses all nodes - for example <<-'HERE' -#@@1 -HERE + for example foo += meth rescue bar traverses all nodes - for example p :foo, {"a": proc do end, b: proc do end} + for example begin meth end until foo traverses all nodes - for example def f &b; end + for example retry traverses all nodes - for example a = 1; a b: 1 + for example module Foo; end traverses all nodes - for example foo::m += raise bar rescue nil + for example for a in foo do p a; end traverses all nodes - for example while foo; meth end + for example foo.A = 1 traverses all nodes - for example fun(:foo => 1, &baz) + for example fun(:foo => 1) traverses all nodes - for example unless foo then bar; end + for example yield traverses all nodes - for example /source/im + for example `#@1` traverses all nodes - for example begin; meth; rescue foo => ex; bar; end + for example [ 1 => 2 ] traverses all nodes - for example case foo; in [x, *y, z] then true; end + for example a b{c(d)}, 1 do end traverses all nodes - for example /#@@1/ + for example a b{c d}, 1 do end traverses all nodes for example 42.1i traverses all nodes - for example f{ |a, o=1, o1=2, *r, &b| } + for example foo = baz, *bar traverses all nodes - for example %I{a\ -b} + for example f{ |a, *s| } traverses all nodes - for example + for example m1 :k => m2 do; m3() do end; end traverses all nodes - for example fun(foo, :foo => 1, &baz) + for example case [__FILE__, __LINE__ + 1, __ENCODING__] + in [__FILE__, __LINE__, __ENCODING__] + end traverses all nodes - for example case; when foo; 'foo'; else 'bar'; end + for example break fun foo do end traverses all nodes - for example :"a\ -b" + for example $+ traverses all nodes - for example `foo#{bar}baz` + for example fun(foo, *bar, &baz) traverses all nodes - for example <<~E - 1 \ - 2 - 3 -E + for example def f o=1, &b; end traverses all nodes - for example a ? b & '': nil + for example f{ |a, c| } traverses all nodes - for example proc {|_3|} + for example p <<~E " y" + x +E traverses all nodes - for example ::A, foo = foo + for example ~foo traverses all nodes - for example def BEGIN; end + for example def self._6; end traverses all nodes - for example def f a, o=1, &b; end + for example %W[foo #{bar}foo#@baz] traverses all nodes - for example def foo(_, _); end + for example o = { +a: +1 +} traverses all nodes - for example begin; meth; ensure; bar; end + for example meth 1 do end.fun(bar) {} traverses all nodes - for example def (foo).foo; end + for example a # + # +&.foo traverses all nodes - for example foo::C ||= raise bar rescue nil + for example case foo; in *x, y, z then nil; end traverses all nodes - for example a b(c(d)), 1.0i do end + for example Foo traverses all nodes - for example foo[bar, :baz => 1,] + for example `#@@1` traverses all nodes - for example -> (arg={}) {} + for example self traverses all nodes - for example for a in foo; p a; end + for example ::Foo traverses all nodes - when a class defines on_arg - calls it for all arguments - for example case foo; in A[] then true; end + for example m { |(foo, bar)| } traverses all nodes - for example a @b do |c|;end + for example def foo(_, _); end traverses all nodes - for example fun(foo, *bar) + for example a, *, c = bar traverses all nodes - for example def END; end + for example def x(_4) end traverses all nodes - for example -> do rescue; end + for example def f(*foo); end traverses all nodes - for example a += b = raise :x + for example ->(scope) {}; scope traverses all nodes - for example def f a, *r, p, &b; end + for example case foo; in ^foo then nil; end traverses all nodes - for example bar if foo + for example bar unless foo traverses all nodes - for example 'a\ -b' + for example a b(c d), /x/ do end traverses all nodes - for example Bar::Foo + for example foo % 1 traverses all nodes - for example p <<~E - x - -y -E + for example case foo; + in {a: + } + true + ; end traverses all nodes - for example foo = *bar + for example def foo() a:b end traverses all nodes - for example def String::foo; end + for example proc {_1 = nil} traverses all nodes - for example a, *b = bar + for example a b{c d}, "x" do end traverses all nodes - for example def f(*); end + for example () traverses all nodes - for example __ENCODING__ + for example :"#@@1" traverses all nodes - for example f{ |foo:| } + for example -> a: 1 { } traverses all nodes - for example case foo; in ** then true; end + for example def m; class << self; A = nil; end; end traverses all nodes - for example foo[1, 2] = 3 + for example @@foo traverses all nodes - for example assert dogs + for example def f(**nil); end traverses all nodes for example a, (b, c) = foo traverses all nodes - for example foo.a &&= 1 + for example ?a traverses all nodes - for example f{ |o=1, p, &b| } + for example /foo#{bar}baz/ traverses all nodes - for example f{ |a| } + for example until foo do meth end traverses all nodes - for example foo.m += raise bar rescue nil + for example p p{p(p);p p}, tap do end traverses all nodes - for example %w[ #@@1 ] + for example a b{c(d)}, 1.0 do end traverses all nodes - for example %s{#@1} + for example fun(&bar) traverses all nodes - for example def f a, o=1, *r, &b; end + for example foo.C += raise(bar) rescue nil traverses all nodes - for example m [], 1 do end + for example undef foo, :bar, :"foo#{1}" traverses all nodes - for example case foo; in [x] then nil; end + for example if foo..bar; end traverses all nodes - for example f{ |a,| } + for example foo & 1 traverses all nodes - for example def f a, o=1, *r, p, &b; end + for example [1, 2] traverses all nodes - for example %W() + for example def self::foo; end traverses all nodes - for example case foo; in x, *y, z then nil; end + for example def f(*); end traverses all nodes - for example foo = m foo + for example let () { m(a) do; end } traverses all nodes - for example m = -> *args do end + for example p <<~E + x +E traverses all nodes - for example <<'HERE' -foo -bar -HERE + for example /#)/x traverses all nodes - for example %r{a\ -b} + for example def f &b; end traverses all nodes - for example a b(c d), "x" do end + for example foo.C += raise bar rescue nil traverses all nodes - for example begin end + for example a, *b, c = bar traverses all nodes - for example foo || bar + for example super do end traverses all nodes - for example class A < B -end + for example a b{c(d)}, "x" do end traverses all nodes - when given an unexpected AST - with too many children - raises debugging error - with too few children - raises debugging error - for example return() + for example a @b do |c|;end traverses all nodes - for example case foo; in a: 1, _a:, ** then true; end + for example f{ |a| } traverses all nodes - for example %I[foo #{bar}] + for example a b(c d), "x" do end traverses all nodes - for example begin; meth; rescue; baz; else foo; ensure; bar end + for example <<-"HERE" +#@@1 +HERE traverses all nodes - for example class A; _1; end + for example case foo; in [x, y,] then true; end traverses all nodes - for example break fun foo do end + for example foo = raise bar rescue nil traverses all nodes - for example begin; meth; rescue Exception, foo; bar; end + for example case foo; in A(1, 2) then true; end traverses all nodes - for example a&.b &&= 1 + for example %s{#@@1} traverses all nodes - for example *b = bar + for example %w[foo bar] traverses all nodes - for example "foo#{bar}baz" + for example assert do: true traverses all nodes - for example meth 1 do end.fun bar do end + for example foo[1, 2] + traverses all nodes + for example %I{a\ +b} + traverses all nodes + for example foo !~ 1 + traverses all nodes + for example -1.33 traverses all nodes for example /#@1/ traverses all nodes - for example case foo; in 1..2 then true; end + for example case foo; in 1 | 2 then true; end traverses all nodes - for example def f(foo=1, bar=2); end + for example f{ |*s, &b| } traverses all nodes - for example begin; meth; rescue; foo; end + for example f{ |a, *r, p, &b| } traverses all nodes - for example def a b: -return -end + for example desc "foo" do end traverses all nodes - for example -1.33 + for example def foo(...); bar(...); end traverses all nodes - for example %w[ #@1 ] + for example case; when foo; 'foo'; else 'bar'; end traverses all nodes - for example def until; end + for example def f (foo: 1, bar: 2, **baz, &b); end traverses all nodes - for example f{ } + for example not(foo) traverses all nodes - for example 1..2 + for example def foo(...); super(...); end traverses all nodes - for example -42 + for example __LINE__ traverses all nodes - for example case 1; in 2; 3; else; end + for example p <<~E + x + y +E traverses all nodes - for example next() + for example 42i traverses all nodes - for example foo - 1 + for example fun() { } traverses all nodes - for example case foo; in [*, x] then true; end + for example /#{1}(?bar)/ =~ 'bar' traverses all nodes - for example for a, b in foo; p a, b; end + for example fun (1) traverses all nodes - for example :'#@1' + for example case foo; in [x, y, *z] then true; end traverses all nodes - for example def f *r, &b; end + for example begin meth end while foo traverses all nodes - for example ->(**nil) {} + for example -> * { } traverses all nodes - for example case foo; in 1... then true; end + for example def m; class << self; module M; end; end; end traverses all nodes - for example class << foo; nil; end + for example bar def foo; self.each do end end traverses all nodes - for example <<-E - 1 \ - 2 - 3 -E + for example def f(&block); end traverses all nodes - for example a # - # -&.foo + for example -2.0 ** 10 traverses all nodes - for example def f a, *r, &b; end + for example -> a: { } traverses all nodes - for example self + for example var = 10; var traverses all nodes - for example -> do end + for example a b(c(d)), :e do end traverses all nodes - for example foo::Fun() + for example while class Foo a = tap do end; end; break; end traverses all nodes - for example %I[#@1] + for example def foo; end traverses all nodes - for example foo.a += 1 + for example return traverses all nodes - for example $var = 10 + for example case foo; in "a": 1 then true; end traverses all nodes - for example 1 in [a]; a + for example { } traverses all nodes - for example "a\ -b" + for example "#@1" traverses all nodes - for example begin; meth; rescue => @ex; bar; end + for example <<'HERE' +foo +bar +HERE traverses all nodes - for example @@foo + for example foo::fun (1) {} traverses all nodes - for example case foo; in [x, y,] then true; end + for example def f(foo); end traverses all nodes - for example f{ |a, *r, p, &b| } + for example -2 ** 10 traverses all nodes - for example ->(a) { } + for example begin foo!; bar! end traverses all nodes - for example a b(c(d)), /x/m do end + for example meth rescue bar traverses all nodes - for example def f(**foo); end + for example $var = 10 traverses all nodes - for example case foo; in * then nil; end + for example f{ |a, *s, &b| } traverses all nodes - for example a # -# -.foo + for example %x{#@1} traverses all nodes - for example foo = raise(bar) rescue nil + for example def f ((a, *, p)); end traverses all nodes - for example { } + for example case foo; in [x] then nil; end traverses all nodes - for example foo[0, 1] ||= 2 + for example m ->(a = ->{_1}) {a} traverses all nodes - for example case foo; in { a: 1 } then true; end + for example __FILE__ traverses all nodes - for example self.A, foo = foo + for example BEGIN { 1 } traverses all nodes - for example not foo + for example fun { } traverses all nodes - for example a&.b = 1 + for example # Extracted from `parser` gem. +# Add the following code at the beginning of `def assert_parses`: +# +# File.open('./out.rb', 'a+') do |f| +# f << code << "\n\n#----\n" if versions.include? '2.7' +# end + +alias $a $b traverses all nodes - for example case foo; in a: then true; end + for example def f(foo, bar); end traverses all nodes - for example meth 1 do end.fun(bar) + for example p <<~E + x + \ y +E traverses all nodes - for example def f *r, p, &b; end + for example /(?bar)/ =~ 'bar'; match traverses all nodes - for example f{ |; -a -| } + for example case foo; in [x, y] then true; end traverses all nodes - for example super do end + when a class defines on_arg + calls it for all arguments + for example `foobar` traverses all nodes - for example case foo; in x if true; nil; end + for example f{ | | } traverses all nodes - for example *b, c = bar + for example a b{c(d)}, :e do end traverses all nodes - for example class Foo < a:b; end + for example case foo; in **nil then true; end traverses all nodes - for example def x; ::A ||= 1; end + for example _1 traverses all nodes - for example case foo; in x, then nil; end + for example fun(foo, :foo => 1, &baz) traverses all nodes - for example a b{c(d)}, /x/ do end + for example foo >> 1 traverses all nodes - for example p <<~E - x - - y -E + for example case foo; when 'bar'; bar; end traverses all nodes - for example if /wat/; end + for example foo.m += raise(bar) rescue nil traverses all nodes - for example p :foo, {a: proc do end, b: proc do end} + for example foo.m += raise bar rescue nil traverses all nodes - for example %w{a\ -b} + for example 42.1ri traverses all nodes - for example %q{#@1} + for example p <<~E + E traverses all nodes - for example foo[0, 1] += 2 + for example foo += raise bar rescue nil traverses all nodes - for example a b{c(d)}, "x" do end + for example p :foo, {:a => proc do end, b: proc do end} traverses all nodes - for example def foo -=begin -=end -end + for example not m foo traverses all nodes - for example "#@a #@@a #$a" + for example class << foo; _1; end traverses all nodes - for example f{ |*, &b| } + for example foo::C ||= raise(bar) rescue nil traverses all nodes - for example case foo; in [x, y] then true; end + for example p <<~`E` + x + #{foo} +E traverses all nodes - for example case foo; when 'bar', 'baz'; bar; end + for example foo > 1 traverses all nodes - for example meth 1 do end.fun {} + for example 42r traverses all nodes - for example p p{p(p);p p}, tap do end + for example false traverses all nodes - for example m [] do end + for example foo = m foo traverses all nodes - for example f{ |a, o=1, p, &b| } + for example p :foo, {a: proc do end, b: proc do end} traverses all nodes - for example foo::A = 1 + for example a b{c d}, /x/m do end traverses all nodes - for example a, * = bar + for example :"foo#{bar}baz" traverses all nodes - for example -> a: 1 { } + for example next traverses all nodes - for example foo::A += m foo + for example if foo; bar; else baz; end traverses all nodes - for example meth[] {} + for example case foo; when 'bar' then bar; end traverses all nodes - for example meth 1 do end.fun(bar) {} + for example def f *r, p, &b; end traverses all nodes - for example a b{c(d)}, 1 do end + for example f{ |&b| } traverses all nodes - for example def f ((*)); end + for example case foo; when 1, *baz; bar; when *foo; end traverses all nodes - for example a b(c d), :e do end + for example a b(c(d)), "x" do end traverses all nodes - for example meth do; foo; rescue; bar; end + for example a b(c(d)), /x/ do end traverses all nodes - for example -> a: { } + for example f{ |a| } traverses all nodes - for example ?a + for example foo <= 1 traverses all nodes - for example 42.1ri + for example a ? b & '': nil traverses all nodes - for example case foo; in 1; end + for example f{ |a, o=1, p, &b| } traverses all nodes - for example ~foo + for example meth 1 do end::fun bar traverses all nodes - for example foo.A += 1 + for example -42 traverses all nodes - for example f{ | | } + for example case foo; in a: then true; end traverses all nodes - for example [ 1 => 2 ] + for example { foo: 2 } traverses all nodes - for example foo[0] += raise bar rescue nil + for example a # +# +.foo traverses all nodes - for example foo::(1) + for example super foo, bar do end traverses all nodes - for example case foo; - in {Foo: 42 - } - false - ; end + for example p <<~E +E traverses all nodes - for example %I[foo#{bar}] + for example unless foo then bar; end traverses all nodes - for example () + for example fun traverses all nodes - for example a, *, c = bar + for example @@var |= 10 traverses all nodes - for example def x; self::A ||= 1; end + for example next foo traverses all nodes - for example def f ((a, *r, p)); end + for example next(foo) traverses all nodes - for example a b(c(d)), "x" do end + for example a b(c d), 1.0r do end traverses all nodes - for example __ENCODING__ + for example def f ((a, *)); end traverses all nodes - for example def f (foo: 1, &b); end + for example case foo; in A(x:) then true; end traverses all nodes - for example p <<~E - x - y -E + for example 1..2 traverses all nodes - for example -> (a) { } + for example %I[foo#{bar}] traverses all nodes - for example <<~FOO - baz\ - qux -FOO + for example +foo traverses all nodes - for example a, b = *foo, bar + for example not() traverses all nodes - for example +42 + for example if foo +then bar end traverses all nodes - for example f{ |a, b,| } + for example case foo; in 1; end traverses all nodes - for example +foo + for example foo.a ||= 1 traverses all nodes - for example <<-"HERE" -#@1 -HERE + for example begin; meth; rescue; foo; else; bar; end traverses all nodes - for example case foo; - in a: {b:}, c: - p c - ; end + for example p :foo, {** proc do end, b: proc do end} + traverses all nodes + for example 1 in [a]; a + traverses all nodes + for example a b(c d), 1.0i do end traverses all nodes -RuboCop::AST::NodePattern - negation - on square brackets - with a node which meets all requirements of [] - behaves like nonmatching - doesn't match - with a node which meets only 1 requirement of [] - is expected to match code 1 - on a string - with a matching string - behaves like nonmatching - doesn't match - with a non-matching symbol - is expected to match code s(:str, "bar") and :upcase - when nested in complex ways - with (send str :+ (send str :to_i)) - is expected to match code s(:str, "abc"), :+, and s(:send, - s(:str, "1"), :to_i) - with (send str :<< str) - behaves like nonmatching - doesn't match - with (send int :- int) - is expected to match code s(:int, 1), :-, and s(:int, 1) - on a set - with a matching value - behaves like nonmatching - doesn't match - with a non-matching value - is expected to match code :@a and s(:int, 3) - on a symbol - with a matching symbol - behaves like nonmatching - doesn't match - with a non-matching symbol, but too many children - behaves like nonmatching - doesn't match - with a non-matching symbol - is expected to match code s(:send, nil, :obj) and :xyz - on a sequence - with a node with non-matching children - is expected to match code :@b and s(:int, 1) - with a node of different type - is expected to match code :@@a and s(:int, 1) - with a matching node - behaves like nonmatching - doesn't match - bad syntax - with negated closing curly - behaves like invalid - is invalid - with unmatched closing paren - behaves like invalid - is invalid - with unmatched closing curly - behaves like invalid - is invalid - with doubled comma in arg list - behaves like invalid - is invalid - with unmatched opening paren - behaves like invalid - is invalid - with empty intersection - behaves like invalid - is invalid - with negated closing paren - behaves like invalid - is invalid - with leading comma in arg list - behaves like invalid - is invalid - with empty parentheses - behaves like invalid - is invalid - with empty union - behaves like invalid - is invalid - with doubled ellipsis - is expected to match code "foo" - with unmatched opening curly - behaves like invalid - is invalid - with variadic unions where not supported - behaves like invalid - is invalid - with empty union subsequence in seq head - behaves like invalid - is invalid - with negated ellipsis - behaves like invalid - is invalid - with unsupported subsequence in seq head within union - behaves like invalid - is invalid - with unmatched opening paren and `...` - behaves like invalid - is invalid - descend - with an immediate match - behaves like single capture - returns captured values if there is no block - yields captured value(s) and returns true if there is a block - with a literal match - is expected to match code s(:int, 1) and s(:array, - s(:array, - s(:int, 2), - s(:int, 3), - s(:array, - s(:array, - s(:int, 5)))), - s(:int, 4)) - with a match multiple levels, depth first - behaves like single capture - returns captured values if there is no block - yields captured value(s) and returns true if there is a block - without match - behaves like nonmatching - doesn't match - nested - behaves like single capture - yields captured value(s) and returns true if there is a block - returns captured values if there is no block - sequence with trailing ... - on a node with the same type and exact number of children - is expected to match code s(:int, 1) and :blah - on a node with the same type and fewer children - behaves like nonmatching - doesn't match - on a node with fewer children, with a wildcard preceding - behaves like nonmatching - doesn't match - on a node with the same type and more children - with 1 child more - is expected to match code s(:int, 1), :blah, and s(:int, 1) - with 2 children more - is expected to match code s(:int, 1), :blah, s(:int, 1), and s(:sym, :something) - on a node with non-matching children - behaves like nonmatching - doesn't match - on a node with a different type - behaves like nonmatching - doesn't match - captures which also perform a match - on a literal - behaves like single capture - returns captured values if there is no block - yields captured value(s) and returns true if there is a block - when nested - behaves like multiple capture - returns captured values if there is no block - yields captured value(s) and returns true if there is a block - on a node type - behaves like single capture - yields captured value(s) and returns true if there is a block - returns captured values if there is no block - on a set - behaves like single capture - returns captured values if there is no block - yields captured value(s) and returns true if there is a block - on [] - behaves like single capture - returns captured values if there is no block - yields captured value(s) and returns true if there is a block - on a sequence - behaves like single capture - yields captured value(s) and returns true if there is a block - returns captured values if there is no block - repeated - using ? - with zero match - behaves like single capture - yields captured value(s) and returns true if there is a block - returns captured values if there is no block - with too many matching children - behaves like nonmatching - doesn't match - behaves like repeated pattern - at beginning of sequence - behaves like invalid - is invalid - with one match - behaves like single capture - yields captured value(s) and returns true if there is a block - returns captured values if there is no block - with an ellipsis in the same sequence - is expected to match code "[:hello, 1, 2, 3]" - using + - behaves like repeated pattern - at beginning of sequence - behaves like invalid - is invalid - with an ellipsis in the same sequence - is expected to match code "[:hello, 1, 2, 3]" - with one match - behaves like single capture - yields captured value(s) and returns true if there is a block - returns captured values if there is no block - with zero match - behaves like nonmatching - doesn't match - with matching children - behaves like single capture - returns captured values if there is no block - yields captured value(s) and returns true if there is a block - using * - behaves like repeated pattern - with an ellipsis in the same sequence - is expected to match code "[:hello, 1, 2, 3]" - at beginning of sequence - behaves like invalid - is invalid - with one match - behaves like single capture - returns captured values if there is no block - yields captured value(s) and returns true if there is a block - nested with multiple subcaptures - behaves like multiple capture - yields captured value(s) and returns true if there is a block - returns captured values if there is no block - with multiple subcaptures - behaves like multiple capture - yields captured value(s) and returns true if there is a block - returns captured values if there is no block - with zero match - behaves like single capture - returns captured values if there is no block - yields captured value(s) and returns true if there is a block - without capture - is expected to match code s(:sym, :hello), s(:int, 1), s(:int, 2), and s(:int, 3) - with matching children - behaves like single capture - yields captured value(s) and returns true if there is a block - returns captured values if there is no block - with no match - behaves like nonmatching - doesn't match - bare node type - #pattern - returns the pattern - yaml compatibility - is expected to match code s(:send, nil, :obj) and :method - #== - returns true iff the patterns are similar - on a node with the same type - is expected to match code s(:send, nil, :obj) and :method - on a node with a matching, hyphenated type - is expected to match code s(:lvasgn, :a), :+, and s(:int, 1) - #to_s - is instructive - marshal compatibility - is expected to match code s(:send, nil, :obj) and :method - on a node with a different type - behaves like nonmatching - doesn't match - #dup - is expected to match code s(:send, nil, :obj) and :method - captures on ... - with a remaining [] at the end - behaves like single capture - returns captured values if there is no block - yields captured value(s) and returns true if there is a block - with a remaining set at the end - behaves like single capture - yields captured value(s) and returns true if there is a block - returns captured values if there is no block - after a child - behaves like single capture - returns captured values if there is no block - yields captured value(s) and returns true if there is a block - with a remaining capture at the end - behaves like multiple capture - yields captured value(s) and returns true if there is a block - returns captured values if there is no block - with a remaining wildcard at the end - behaves like single capture - yields captured value(s) and returns true if there is a block - returns captured values if there is no block - with remaining patterns at the end - behaves like single capture - returns captured values if there is no block - yields captured value(s) and returns true if there is a block - at the very beginning of a sequence - behaves like single capture - yields captured value(s) and returns true if there is a block - returns captured values if there is no block - with a remaining sequence at the end - behaves like single capture - yields captured value(s) and returns true if there is a block - returns captured values if there is no block - with a remaining node type at the end - behaves like single capture - yields captured value(s) and returns true if there is a block - returns captured values if there is no block - with no remaining pattern at the end - behaves like single capture - returns captured values if there is no block - yields captured value(s) and returns true if there is a block - with a remaining literal at the end - behaves like single capture - returns captured values if there is no block - yields captured value(s) and returns true if there is a block - node type - in seq head - on a node with the same type - is expected to match code s(:ivar, :@ivar), :+, and s(:int, 2) - on a child with a different type - behaves like nonmatching - doesn't match - for a child - on a child with a different type - behaves like nonmatching - doesn't match - on a child with the same type - is expected to match code s(:send, nil, :foo) and :bar - on a child litteral - behaves like nonmatching - doesn't match - captures within union - on simple subpatterns - behaves like single capture - yields captured value(s) and returns true if there is a block - returns captured values if there is no block - within nested sequences - behaves like multiple capture - yields captured value(s) and returns true if there is a block - returns captured values if there is no block - with a different number of captures in each branch - behaves like invalid - is invalid - with complex nesting - behaves like multiple capture - yields captured value(s) and returns true if there is a block - returns captured values if there is no block - predicates - when captured - behaves like single capture - yields captured value(s) and returns true if there is a block - returns captured values if there is no block - applied to an integer for which the predicate is true - is expected to match code s(:int, 1) and :inc - with multiple arguments - for which the predicate is false - behaves like nonmatching - doesn't match - for which the predicate is true - is expected to match code s(:str, "c"), "a", and "d" - at head position of a sequence - is expected to match code s(:int, 1) and :inc - when in last-child position, but all children have already been matched - behaves like nonmatching - doesn't match - with a named argument - for which the predicate is false - behaves like nonmatching - doesn't match - for which the predicate is true - is expected to match code s(:send, - s(:int, 1), :+, - s(:int, 2)) and {:param=>1} - when not given - raises an error - with extra arguments - raises an error - with one extra argument - for which the predicate is true - is expected to match code s(:send, - s(:int, 1), :+, - s(:int, 2)) and 1 - for which the predicate is false - behaves like nonmatching - doesn't match - with an expression argument - for which the predicate is true - is expected to match code s(:int, 2), :+, and s(:float, 2.0) - for which the predicate is false - behaves like nonmatching - doesn't match - with a constant argument - for which the predicate is true - is expected to match code s(:int, 1), :+, and s(:int, 2) - for which the predicate is false - behaves like nonmatching - doesn't match - applied to an integer for which the predicate is false - behaves like nonmatching - doesn't match - when negated - is expected to match code s(:int, 1) and :inc - in root position - is expected to match code s(:int, 1) and :inc - with name containing a numeral - is expected to match code s(:int, 1) and :inc - macros - with a pattern without captures - def_node_matcher - returns the method name - when called on matching code - is expected to match code :hello - when called on non-matching code - behaves like nonmatching - doesn't match - when it errors - raises an error with the right location - def_node_search - returns the method name - with a predicate name - when called on matching code - is expected to match code nil, :foo, s(:sym, :hello), and s(:sym, :world) - when called on non-matching code - behaves like nonmatching - doesn't match - when it errors - raises an error with the right location - without a predicate name - when called on non-matching code - returns an enumerator yielding nothing - when it errors - raises an error with the right location - when called on matching code - returns an enumerator yielding the matches - with a pattern with a constant - is expected to match code :hello - when the value is not in the set - behaves like nonmatching - doesn't match - with a pattern with a namespaced call - is expected to match code :hello - when the value is not in the set - behaves like nonmatching - doesn't match - with a pattern with captures - def_node_search - without a predicate name - when it errors - raises an error with the right location - when called on matching code - returns an enumerator yielding the captures - when the pattern contains keyword_params - returns an enumerator yielding the captures - when helper is called with default keyword_params - is overridden when calling the matcher - and no value is given to the matcher - uses the defaults - some defaults are not params - raises an error - when called on non-matching code - returns an enumerator yielding nothing - with a predicate name - when called on matching code - is expected to match code nil, :foo, s(:sym, :hello), and s(:sym, :world) - when called on non-matching code - behaves like nonmatching - doesn't match - when it errors - raises an error with the right location - def_node_matcher - when called on matching code - is expected to eq :hello - when called on non-matching code - behaves like nonmatching - doesn't match - when it errors - raises an error with the right location - funcalls - without extra arguments - is expected to match code :a and s(:int, 1) - with one argument - is expected to match code s(:str, "foo") and "foo" - with multiple arguments - is expected to match code s(:str, "c"), "a", and "d" - regexp - matches symbols or strings - comments - behaves like single capture - yields captured value(s) and returns true if there is a block - returns captured values if there is no block - nil - against a node pattern (bug #5470) - behaves like nonmatching - doesn't match - nil value in AST - behaves like nonmatching - doesn't match - nil literals - is expected to match code - nil value in AST, use nil? method - is expected to match code nil and :foo - unions - with a nested sequence - is expected to match code s(:const, nil, :Const) and :method - nested inside a sequence - is expected to match code s(:const, nil, :Const) and :method - variadic - with fixed terms - works for cases with fixed arity before and after union - works for cases with variadic terms after union - works for cases with variadic terms before and after union - with variadic terms - works for cases with variadic terms after union - works for cases with fixed arity before and after union - works for cases with variadic terms before and after union - multiple - works for complex cases - at the top level - containing string literals - is expected to match code s(:str, "a") and :upcase - containing mixed node and literals - is expected to match code nil and :obj - containing integer literals - is expected to match code s(:int, 10) and :abs - containing symbol literals - when the AST has a matching symbol - is expected to match code s(:send, nil, :obj) and :b - when the AST does not have a matching symbol - behaves like nonmatching - doesn't match - containing multiple [] - on a node which meets all requirements of the first [] - is expected to match code 3 - on a node which meets all requirements of the second [] - is expected to match code 2.4 - on a node which meets some requirements but not all - behaves like nonmatching - doesn't match - simple sequence - on a node with a different type - behaves like nonmatching - doesn't match - on a node with the same type and matching children - is expected to match code s(:int, 1), :+, and s(:int, 1) - on a node with the same type and non-matching children - with non-matching receiver type - behaves like nonmatching - doesn't match - with non-matching selector - behaves like nonmatching - doesn't match - on a node with too many children - behaves like nonmatching - doesn't match - with a nested sequence in non-head position - is expected to match code s(:send, - s(:send, nil, :obj), :a) and :b - with a nested sequence in head position - behaves like invalid - is invalid - ellipsis - with a nested sequence at the end, but no remaining child - behaves like nonmatching - doesn't match - preceding a capture - behaves like single capture - yields captured value(s) and returns true if there is a block - returns captured values if there is no block - with a set at the end, but no remaining child to match it - behaves like nonmatching - doesn't match - preceding multiple captures - behaves like multiple capture - yields captured value(s) and returns true if there is a block - returns captured values if there is no block - with a wildcard at the end, but no remaining child to match it - behaves like nonmatching - doesn't match - at the very beginning of a sequence - is expected to match code s(:int, 10), :*, and s(:int, 1) - with a nodetype at the end, but no remaining child to match it - behaves like nonmatching - doesn't match - with [] at the end, but no remaining child to match it - behaves like nonmatching - doesn't match - commas - with commas randomly strewn around - behaves like invalid - is invalid - in any order - invalid - doubled with ellipsis - behaves like multiple capture - yields captured value(s) and returns true if there is a block - returns captured values if there is no block - doubled with ellipsis in wrong order - behaves like nonmatching - doesn't match - nested - behaves like invalid - is invalid - at the beginning of a sequence - behaves like invalid - is invalid - containing ellipsis not at the end - behaves like invalid - is invalid - with an ellipsis inside and outside - behaves like multiple capture - yields captured value(s) and returns true if there is a block - returns captured values if there is no block - captured - without ellipsis - behaves like single capture - yields captured value(s) and returns true if there is a block - returns captured values if there is no block - with an ellipsis - behaves like single capture - returns captured values if there is no block - yields captured value(s) and returns true if there is a block - doubled - separated by fixed argument - behaves like multiple capture - returns captured values if there is no block - yields captured value(s) and returns true if there is a block - separated by an ellipsis - behaves like multiple capture - returns captured values if there is no block - yields captured value(s) and returns true if there is a block - with a captured ellipsis - nested - behaves like multiple capture - yields captured value(s) and returns true if there is a block - returns captured values if there is no block - matching non sequential children - behaves like single capture - returns captured values if there is no block - yields captured value(s) and returns true if there is a block - matching all children - behaves like single capture - returns captured values if there is no block - yields captured value(s) and returns true if there is a block - without ellipsis - with too many children - behaves like nonmatching - doesn't match - with matching children - behaves like multiple capture - returns captured values if there is no block - yields captured value(s) and returns true if there is a block - with too few children - behaves like nonmatching - doesn't match - wildcards - unnamed wildcards - within a sequence - is expected to match code nil and :Const - in head position of a sequence - is expected to match code s(:int, 1), :+, and s(:send, nil, :a) - within a sequence with other patterns intervening - is expected to match code :@abc and s(:int, 22) - negated - behaves like nonmatching - doesn't match - at the root level - is expected to match code s(:sclass, - s(:self), - s(:def, :something, - s(:args), - s(:int, 1))) and :freeze - named wildcards - within a sequence - with values which can be unified - is expected to match code s(:int, 5), :+, and s(:int, 5) - unifying the node type with an argument - is expected to match code s(:send, nil, :obj) and :send - with values which cannot be unified - behaves like nonmatching - doesn't match - within a union - with a succeeding unifying constraint - with all branches with the wildcard - that can not be unified - behaves like nonmatching - doesn't match - matching another branch - is expected to match code s(:array, - s(:int, 2), - s(:int, 1)) and s(:int, 2) - matching the first branch - is expected to match code s(:array, - s(:int, 1), - s(:int, 2)) and s(:int, 2) - with branches without the wildcard - encountered first - behaves like invalid - is invalid - encountered after - behaves like invalid - is invalid - confined to the union - without unification - is expected to match code s(:int, 2) and s(:int, 1) - with partial unification - that can not be unified - behaves like nonmatching - doesn't match - matching the unified branch - is expected to match code s(:int, 5) and s(:int, 5) - matching the free branch - is expected to match code s(:int, 2) and s(:int, 1) - with a preceding unifying constraint - that can not be unified - behaves like nonmatching - doesn't match - matching a branch - is expected to match code s(:int, 2) and s(:array, - s(:int, 2), - s(:int, 1)) - at the root level - is expected to match code s(:sclass, - s(:self), - s(:def, :something, - s(:args), - s(:int, 1))) and :freeze - in head position of a sequence - is expected to match code s(:int, 1), :+, and s(:send, nil, :a) - within a sequence with other patterns intervening - is expected to match code :@abc and s(:int, 22) - params - when preceded by $... - behaves like single capture - yields captured value(s) and returns true if there is a block - returns captured values if there is no block - as named parameters - when extra are provided - raises an ArgumentError - when not provided - raises an ArgumentError - when provided as argument to match - is expected to match code s(:int, 10) and {:foo=>#} - param number zero - in a position which matches original target node - is expected to match code 1 - in a position which does not match original target node - behaves like nonmatching - doesn't match - when negated, with a matching value - behaves like nonmatching - doesn't match - when negated, with a nonmatching value - is expected to match code s(:const, - s(:const, nil, :Namespace), :B) and :A - without explicit number - is expected to match code s(:const, - s(:const, nil, :Namespace), :A), :A, and s(:const, nil, :Namespace) - when captured - behaves like single capture - returns captured values if there is no block - yields captured value(s) and returns true if there is a block - when inside a union, with a matching value - is expected to match code s(:int, 10) and 10 - when inside a union, with a nonmatching value - behaves like nonmatching - doesn't match - when inside an intersection - is expected to match code s(:int, 20), 10, and 20 - in a nested sequence - is expected to match code s(:send, - s(:send, - s(:int, 5), :dec), :inc), :inc, and :dec - when preceded by ... - is expected to match code s(:send, - s(:int, 1), :+, - s(:int, 10)) and s(:int, 10) - in root position - is expected to match code s(:int, 10) and s(:int, 10) - in root position - is expected to match code s(:int, 10) and # - captures on a wildcard - nested in any child - behaves like multiple capture - yields captured value(s) and returns true if there is a block - returns captured values if there is no block - in head position in a sequence against literal (bug #5470) - behaves like nonmatching - doesn't match - in head position in a sequence - behaves like single capture - yields captured value(s) and returns true if there is a block - returns captured values if there is no block - at the root level - behaves like single capture - yields captured value(s) and returns true if there is a block - returns captured values if there is no block - in non-head position in a sequence - behaves like single capture - yields captured value(s) and returns true if there is a block - returns captured values if there is no block - in a nested sequence - behaves like single capture - returns captured values if there is no block - yields captured value(s) and returns true if there is a block - in head position in a sequence against nil (bug #5470) - behaves like nonmatching - doesn't match - .descend - yields the given argument if it is not a Node - yields all children depth first - literals - double quoted string literals - is expected to match code "foo" - bare literal - on a node - behaves like nonmatching - doesn't match - on a matching literal - is expected to match code :bar - symbol literals - is expected to match code :foo - negative integer literals - is expected to match code -100 - single quoted string literals - is expected to match code "foo" - negative float literals - is expected to match code -2.5 - positive float literals - is expected to match code 1.0 - caret (ascend) - inside a union - is expected to match code "abc" - using unification to match self within parent - with self in the wrong position - behaves like nonmatching - doesn't match - with self in the right position - is expected to match code 2 - inside an intersection - is expected to match code 1 - repeated twice - is expected to match code 1 - within sequence - not in head - is expected to match code s(:int, 1) and :inc - of a sequence - is expected to match code s(:int, 1) and :inc - in head - is expected to match code 1 - of a sequence - is expected to match code 1 - used with a node type - which matches - is expected to match code 1 - which doesn't match - behaves like nonmatching - doesn't match +RuboCop::AST::Procarg0Node + #name + is expected to eq :x + .new + with a block + is expected to be a kind of RuboCop::AST::ArgNode -RuboCop::AST::StrNode - #heredoc? - with a heredoc - is expected to be heredoc - with a string with interpolation - is expected not to be heredoc - with a normal string - is expected not to be heredoc - #character_literal? - with a character literal - is expected to be character literal - with a normal string literal - is expected not to be character literal - with a heredoc - is expected not to be character literal +RuboCop::AST::ForNode + #post_condition_loop? + is expected not to be post condition loop + #loop_keyword? + is expected to be loop keyword + #body + is expected to be sym type + #do? + with a do keyword + is expected to be do + without a do keyword + is expected not to be do + #keyword + is expected to eq "for" + #collection + is expected to be sym type .new - with a normal string - is expected to be a kind of RuboCop::AST::StrNode - with a heredoc - is expected to be a kind of RuboCop::AST::StrNode - with a string with interpolation - is expected to be a kind of RuboCop::AST::StrNode + is expected to be a kind of RuboCop::AST::ForNode + #void_context? + without a do keyword + is expected to be void context + with a do keyword + is expected to be void context + #variable + is expected to be lvasgn type -RuboCop::AST::DefNode - #method_name - with a setter method - is expected to eq :foo= - with a unary method - is expected to eq :-@ - with a plain method - is expected to eq :foo - with an operator method - is expected to eq :== - when using Ruby 2.7 or newer - #argument_forwarding? - is expected to be argument forwarding - #first_argument - with a single rest argument - is expected to be restarg type - with a single regular argument - is expected to be arg type - with a single keyword argument - is expected to be kwoptarg type - with no arguments - is expected to be nil - with multiple regular arguments - is expected to be arg type - with multiple mixed arguments - is expected to be arg type - #block_argument? - with a block argument - is expected to be block argument - with regular arguments - is expected not to be block argument - with mixed arguments - is expected to be block argument - with no arguments - is expected not to be block argument - #method? - when message does not match - when argument is a string - is expected not to be method "foo" - when argument is a symbol - is expected not to be method :foo - when message matches - when argument is a symbol - is expected to be method :bar - when argument is a string - is expected to be method "bar" - #endless? - with standard method definition - is expected not to be endless - with endless method definition - is expected to be endless - #comparison_method? - with a comparison method - is expected to be comparison method - with a regular method - is expected not to be comparison method - #self_receiver? - with a singleton method definition - is expected not to be self receiver - with an instance method definition - is expected not to be self receiver - with a class method definition - is expected to be self receiver - #const_receiver? - with a class method definition - is expected not to be const receiver - with an instance method definition - is expected not to be const receiver - with a singleton method definition - is expected to be const receiver - #arguments? - with no arguments - is expected not to be arguments - with multiple regular arguments - is expected to be arguments - with a single regular argument - is expected to be arguments - with multiple mixed arguments - is expected to be arguments - with a single rest argument - is expected to be arguments - with a single keyword argument - is expected to be arguments +RuboCop::AST::ModuleNode + #identifier + is expected to be const type + .new + is expected to be a kind of RuboCop::AST::ModuleNode #body with a multi-expression body is expected to be begin type - with no body + with an empty body is expected to be nil with a single expression body is expected to be send type - #operator_method? - with a binary operator method - is expected to be operator method - with a setter method - is expected not to be operator method - with a regular method - is expected not to be operator method - with a unary operator method - is expected to be operator method - #camel_case_method? - with a regular method - is expected not to be camel case method - with a camel case method - is expected to be camel case method - #rest_argument? - with mixed arguments - is expected to be rest argument - with regular arguments - is expected not to be rest argument - with a rest argument - is expected to be rest argument - with no arguments - is expected not to be rest argument - .new - with a def node - is expected to be a kind of RuboCop::AST::DefNode - with a defs node - is expected to be a kind of RuboCop::AST::DefNode - #bang_method? - with a predicate method - is expected not to be bang method - with a bang method - is expected to be bang method - with a regular method - is expected not to be bang method - #arguments - with multiple mixed arguments - is expected to eq 2 - with no arguments - is expected to be empty - with multiple regular arguments + +RuboCop::AST::InPatternNode + when using Ruby 2.7 or newer + #then? + without a then keyword + is expected not to be then + with a then keyword + is expected to be then + #branch_index is expected to eq 2 - with argument forwarding - is expected to eq 1 - with a single rest argument is expected to eq 1 - with a single regular argument - is expected to eq 1 - #assignment_method? - with a bracket assignment method - is expected to be assignment method - with a comparison method - is expected not to be assignment method - with an assignment method - is expected to be assignment method - with a regular method - is expected not to be assignment method - #predicate_method? - with a bang method - is expected not to be predicate method - with a predicate method - is expected to be predicate method - with a regular method - is expected not to be predicate method - #void_context? - with a bracket assignment method - is expected to be void context - with an initializer method - is expected to be void context - with a regular method - is expected not to be void context - with a regular assignment method - is expected to be void context - with a comparison method - is expected not to be void context - #last_argument - with a single regular argument - is expected to be arg type - with multiple mixed arguments - is expected to be restarg type - with a single rest argument - is expected to be restarg type - with a single keyword argument - is expected to be kwoptarg type - with no arguments - is expected to be nil - with multiple regular arguments - is expected to be arg type - #receiver - with an instance method definition - is expected to be nil - with a class method definition - is expected to be self type - with a singleton method definition - is expected to be const type - -RuboCop::AST::ArgNode - .new - with a keyword argument - is expected to be a kind of RuboCop::AST::ArgNode - with a lambda literal - is expected to be a kind of RuboCop::AST::ArgNode - with a double splatted argument - is expected to be a kind of RuboCop::AST::ArgNode - with a block argument - is expected to be a kind of RuboCop::AST::ArgNode - with a block - is expected to be a kind of RuboCop::AST::ArgNode - with an optional argument - is expected to be a kind of RuboCop::AST::ArgNode - with a shadow argument - is expected to be a kind of RuboCop::AST::ArgNode - with argument forwarding - with Ruby >= 3.0 - is expected to be a kind of RuboCop::AST::ArgNode - with Ruby >= 2.7 - is expected to be a kind of RuboCop::AST::ArgNode - with a splatted argument - is expected to be a kind of RuboCop::AST::ArgNode - with an optional keyword argument - is expected to be a kind of RuboCop::AST::ArgNode - with a method definition - is expected to be a kind of RuboCop::AST::ArgNode - #default? - with a splatted argument - is expected to equal false - with an optional argument - is expected to equal true - with a regular argument - is expected to equal false - with a double splatted argument - is expected to equal false - with a shadow argument - is expected to equal false - with a block argument - is expected to equal false - with an optional keyword argument - is expected to equal true - with argument forwarding - with Ruby >= 3.0 - is expected to equal false - with Ruby >= 2.7 - is expected to equal false - with a block - is expected to equal false - #name - with a regular argument - is expected to eq :x - with a block argument - is expected to eq :x - with a block - is expected to eq :x - with an optional argument - is expected to eq :x - with a keyword argument - is expected to eq :x - with an optional keyword argument - is expected to eq :x - with a splatted argument - is expected to eq :x - with a shadow argument - is expected to eq :x - with a nameless splatted argument - is expected to be nil - with a double splatted argument - is expected to eq :x - with argument forwarding - with Ruby >= 2.7 - is expected to be nil - with Ruby >= 3.0 - is expected to be nil - with a nameless double splatted argument - is expected to be nil - #default_value - with a block argument - is expected to be nil - with an optional argument - is expected to eq s(:int, 42) - with a block - is expected to be nil - with a double splatted argument - is expected to be nil - with a regular argument - is expected to be nil - with a shadow argument - is expected to be nil - with a splatted argument - is expected to be nil - with an optional keyword argument - is expected to eq s(:int, 42) - with argument forwarding - with Ruby >= 3.0 - is expected to be nil - with Ruby >= 2.7 - is expected to be nil - -RuboCop::AST::CaseMatchNode - when using Ruby 2.7 or newer - #in_pattern_branches - is expected to all be in pattern type - is expected to eq 3 - #each_in_pattern - when not passed a block - is expected to be a kind of Enumerator - when passed a block - yields all the conditions - #keyword - is expected to eq "case" - #else_branch - #else? - with an else statement - is expected to be sym type - without an else statement - is expected to be nil - with an empty else statement - is expected to be empty else type - #else? - without an else statement - is expected not to be else - with an else statement - is expected to be else - .new - is expected to be a kind of RuboCop::AST::CaseMatchNode - #branches - when there is an else - with else body - returns all the bodies - with empty else - returns all the bodies - when there is no else keyword - returns only then when bodies - -RuboCop::AST::WhileNode - #inverse_keyword - is expected to eq "until" - #loop_keyword? - with a statement while - is expected to be loop keyword - with a modifier while - is expected to be loop keyword - #do? - without a do keyword - is expected not to be do - with a do keyword - is expected to be do - #post_condition_loop? - with a modifier while - is expected to be post condition loop - with a statement while - is expected not to be post condition loop - #keyword - is expected to eq "while" - .new - with a statement while - is expected to be a kind of RuboCop::AST::WhileNode - with a modifier while - is expected to be a kind of RuboCop::AST::WhileNode - -RuboCop::AST::InPatternNode - when using Ruby 2.7 or newer + is expected to eq 0 + #body + without a then keyword + is expected to be array type + with a then keyword + is expected to be sym type #pattern - with a variable pattern - is expected to be match var type - with a pin operator - is expected to be pin type - with an array pattern - is expected to be array pattern type with an alternative pattern is expected to be match alt type - with a hash pattern - is expected to be hash pattern type - with a value pattern - is expected to be int type + with an array pattern + is expected to be array pattern type with an as pattern is expected to be match as type - #branch_index - is expected to eq 0 - is expected to eq 2 - is expected to eq 1 + with a value pattern + is expected to be int type + with a pin operator + is expected to be pin type + with a hash pattern + is expected to be hash pattern type + with a variable pattern + is expected to be match var type .new is expected to be a kind of RuboCop::AST::InPatternNode - #then? - with a then keyword - is expected to be then - without a then keyword - is expected not to be then - #body - without a then keyword - is expected to be array type - with a then keyword + +RuboCop::AST::CaseNode + #when_branches + is expected to eq 3 + is expected to all be when type + #else_branch + #else? + with an else statement is expected to be sym type + with an empty else statement + is expected to be nil + without an else statement + is expected to be nil + #branches + when compared to an IfNode + returns the same + when there is no else keyword + returns only then when bodies + when there is an else + returns all the bodies + with an empty else + returns all the bodies + .new + is expected to be a kind of RuboCop::AST::CaseNode + #each_when + when passed a block + yields all the conditions + when not passed a block + is expected to be a kind of Enumerator + #keyword + is expected to eq "case" + #else? + with an else statement + is expected to be else + without an else statement + is expected not to be else -RuboCop::AST::BreakNode - behaves like wrapped arguments node - #arguments - with multiple literal arguments - is expected to eq 2 - with a single splat argument - is expected to eq 1 - with a single argument and braces - is expected to eq 1 - with no arguments and braces - is expected to be empty - with a single argument - is expected to eq 1 - with no arguments - is expected to be empty - .new - without arguments - is expected to be a kind of RuboCop::AST::BreakNode - with arguments - is expected to be a kind of RuboCop::AST::BreakNode +RuboCop::AST::SelfClassNode + #identifier + is expected to be self type + .new + is expected to be a kind of RuboCop::AST::SelfClassNode + #body + with an empty body + is expected to be nil + with a multi-expression body + is expected to be begin type + with a single expression body + is expected to be send type -RuboCop::AST::KeywordSplatNode +RuboCop::AST::FloatNode + #sign? + explicit positive float + is expected to be sign + explicit negative float + is expected to be sign #value - is expected to eq s(:kwsplat, - s(:send, nil, :foo)) + is expected to eq 1.5 + .new + is expected to be a kind of RuboCop::AST::FloatNode + +RuboCop::AST::NodePattern::Lexer + provides tokens via next_token + when given a regexp /back\\slash/ + round trips + when given a regexp /[abc]+\/()?/x + round trips + when given node types and constants + distinguishes them + when given arithmetic symbols + is parsed as `:&` + with $type+ + is parsed as `$ int + x` + when given a regexp ending with a backslash + does not lexes it properly + when given a regexp /test/ + round trips + +RuboCop::AST::KeywordSplatNode #hash_rocket? is expected not to be hash rocket .new is expected to be a kind of RuboCop::AST::KeywordSplatNode - #colon? - is expected not to be colon - #key - is expected to eq s(:kwsplat, - s(:send, nil, :foo)) - #value_delta - when using hash rocket delimiters - when keyword splat is behind - is expected to eq 0 - when keyword splat is ahead - is expected to eq 0 - when keyword splat is on the same line - is expected to eq 0 - when keyword splat is left aligned - is expected to eq 0 - when using colon delimiters - when keyword splat is behind - is expected to eq 0 - when keyword splat is on the same line - is expected to eq 0 - when keyword splat is ahead - is expected to eq 0 - when keyword splat is left aligned - is expected to eq 0 #key_delta - with alignment set to :right - when using hash rocket delimiters - when keyword splat is behind - is expected to eq 0 + with alignment set to :left + when using colon delimiters when keyword splat is aligned is expected to eq 0 - when keyword splat is on the same line - is expected to eq 0 when keyword splat is ahead - is expected to eq 0 - when using colon delimiters + is expected to eq 2 when keyword splat is behind + is expected to eq -2 + when keyword splat is on the same line is expected to eq 0 + when using hash rocket delimiters when keyword splat is aligned is expected to eq 0 - when keyword splat is ahead - is expected to eq 0 when keyword splat is on the same line is expected to eq 0 - with alignment set to :left - when using colon delimiters when keyword splat is behind is expected to eq -2 - when keyword splat is aligned + when keyword splat is ahead + is expected to eq 2 + with alignment set to :right + when using hash rocket delimiters + when keyword splat is behind is expected to eq 0 when keyword splat is on the same line is expected to eq 0 when keyword splat is ahead - is expected to eq 2 - when using hash rocket delimiters + is expected to eq 0 when keyword splat is aligned is expected to eq 0 - when keyword splat is on the same line + when using colon delimiters + when keyword splat is ahead + is expected to eq 0 + when keyword splat is aligned is expected to eq 0 when keyword splat is behind - is expected to eq -2 - when keyword splat is ahead - is expected to eq 2 + is expected to eq 0 + when keyword splat is on the same line + is expected to eq 0 #operator is expected to eq "**" #same_line? - when both pairs are on the same line - is expected to be same line s(:kwsplat, + when pairs are on separate lines + is expected not to be same line s(:kwsplat, s(:send, nil, :foo)) when a multiline pair shares the same line + is expected to be same line s(:kwsplat, + s(:send, nil, :foo)) is expected to be same line s(:pair, s(:sym, :a), s(:begin)) + when both pairs are on the same line is expected to be same line s(:kwsplat, s(:send, nil, :foo)) - when pairs are on separate lines - is expected not to be same line s(:kwsplat, + #value + is expected to eq s(:kwsplat, s(:send, nil, :foo)) + #colon? + is expected not to be colon + #key + is expected to eq s(:kwsplat, + s(:send, nil, :foo)) + #value_delta + when using hash rocket delimiters + when keyword splat is ahead + is expected to eq 0 + when keyword splat is behind + is expected to eq 0 + when keyword splat is left aligned + is expected to eq 0 + when keyword splat is on the same line + is expected to eq 0 + when using colon delimiters + when keyword splat is behind + is expected to eq 0 + when keyword splat is on the same line + is expected to eq 0 + when keyword splat is ahead + is expected to eq 0 + when keyword splat is left aligned + is expected to eq 0 -RuboCop::AST::AliasNode - #old_identifier - is expected to eq :bar - is expected to be sym type - .new - is expected to be a kind of RuboCop::AST::AliasNode - #new_identifier - is expected to be sym type - is expected to eq :foo - -RuboCop::AST::LambdaNode - #method_name - is expected to eq :lambda - #arguments - is expected to eq 2 +RuboCop::AST::SendNode #receiver - is expected to be nil - -RuboCop::AST::ProcessedSource - with heavily commented source - #comment_at_line - returns the comment at the given line number - returns nil if line has no comment - #line_with_comment? - returns false for lines without comments - returns true for lines with comments - #contains_comment? - provided source_range on line with comment - is expected to equal true - provided source_range on line without comment - is expected to equal false - provided source_range on comment line - is expected to equal true - provided a multiline source_range with at least one line with comment - is expected to equal true - #comments_before_line - returns comments on or before given line - #find_comment - yields nil when there is no match - yields correct comment - #each_comment_in_lines - yields the comments - #each_comment - yields all comments - #blank? - with source with content - returns false - with source of no content - returns true - #path - is the path passed to .new - #preceding_line - returns source of line before token - #first_token_of - accepts Node as an argument - returns first token for node - #lines - contains lines as string without linefeed - has same number of elements as line count - is an array - #[] - when start index and length are passed - returns the array of lines - when a range is passed - returns the array of lines - when an index is passed - returns the line - #file_path - returns file path - #comments - is an array of comments - when the source is invalid - returns [] - #last_token_of - accepts Node as an argument - returns last token for node - .from_file - raises a Errno::ENOENT when the file does not exist - when the file exists - returns an instance of ProcessedSource - sets the file path to the instance's #path - #tokens - has an array of tokens - #start_with? - with present source - returns false when passed string that does not start source - returns true when passed string that starts source - with blank source - returns false - #buffer - is a source buffer - token enumerables - #find_token - yields correct token - yields nil when there is no match - #each_token - yields all tokens - #tokens_within - accepts Node as an argument - returns tokens for node - when heredoc as argument is present - returns tokens for heredoc node - returns tokens for node after heredoc - returns tokens for node before heredoc - #following_line - returns source of line after token - #parser_error - when the source could not be parsed due to encoding error - returns the error - when the source was properly parsed - is nil - when the source lacks encoding comment and is really utf-8 encoded but has been read as US-ASCII - is nil - #ast - is the root node of AST - valid_syntax? - when the source could not be parsed due to encoding error - returns false - when the source is valid but has some warning diagnostics - returns true - when the source itself is valid encoding but includes strange encoding literals that are accepted by MRI - returns true - when the source is invalid - returns false - when the source is completely valid - returns true - when a line starts with an integer literal - tokenizes the source correctly - -RuboCop::AST::WhenNode - #branch_index - is expected to eq 1 - is expected to eq 2 - is expected to eq 0 - #body - with a then keyword - is expected to be sym type - without a then keyword - is expected to be array type - #then? - with a then keyword - is expected to be then - without a then keyword - is expected not to be then - .new - is expected to be a kind of RuboCop::AST::WhenNode - #each_condition - when passed a block - yields all the conditions - when not passed a block - is expected to be a kind of Enumerator - #conditions - with a multiple conditions - is expected to all be literal - is expected to eq 3 - with a single condition - is expected to eq 1 - is expected to all be literal - -RuboCop::AST::AsgnNode - .new - with a `cvasgn` node - is expected to be a kind of RuboCop::AST::AsgnNode - with a `gvasgn` node - is expected to be a kind of RuboCop::AST::AsgnNode - with a `lvasgn` node - is expected to be a kind of RuboCop::AST::AsgnNode - with a `ivasgn` node - is expected to be a kind of RuboCop::AST::AsgnNode - #name - with a `cvasgn` node - is expected to eq :@@var - with a `lvasgn` node - is expected to eq :var - with a `ivasgn` node - is expected to eq :@var - with a `gvasgn` node - is expected to eq :$var - #expression - with a `cvasgn` node - is expected to eq s(:send, nil, :value) - with a `gvasgn` node - is expected to eq s(:send, nil, :value) - with a `ivasgn` node - is expected to eq s(:send, nil, :value) - with a `lvasgn` node - is expected to eq s(:send, nil, :value) - -RuboCop::AST::ForNode - #void_context? - without a do keyword - is expected to be void context - with a do keyword - is expected to be void context - #collection - is expected to be sym type - #body - is expected to be sym type - .new - is expected to be a kind of RuboCop::AST::ForNode - #variable - is expected to be lvasgn type - #loop_keyword? - is expected to be loop keyword - #keyword - is expected to eq "for" - #do? - with a do keyword - is expected to be do - without a do keyword - is expected not to be do - #post_condition_loop? - is expected not to be post condition loop - -RuboCop::AST::Node - #parent_module_name - when node on singleton class - is expected to eq "Foo::#" - when node nested in an unknown block + with a variable receiver + is expected to be send type + with no receiver is expected to be nil - when node on class in singleton class - is expected to eq "Foo::#::Bar" - when node nested in a class << exp + with a literal receiver + is expected to be str type + #parenthesized? + with no arguments + when not using parentheses + is expected not to be parenthesized + when using parentheses + is expected to be parenthesized + with arguments + when using parentheses + is expected to be parenthesized + when not using parentheses + is expected not to be parenthesized + #method? + when message does not match + when argument is a string + is expected not to be method "foo" + when argument is a symbol + is expected not to be method :foo + when message matches + when argument is a symbol + is expected to be method :bar + when argument is a string + is expected to be method "bar" + #last_argument + with multiple mixed arguments + is expected to be splat type + with a single literal argument + is expected to be sym type + with multiple literal arguments + is expected to be sym type + with a single splat argument + is expected to be splat type + with no arguments is expected to be nil - when node on module - is expected to eq "Foo" - when node on top level - is expected to eq "Object" - #struct_constructor? - struct definition without block - does not match - ::Struct - matches - struct definition with a block - matches - #numeric_type? - when rational literal - is true - when string literal - is true - when integer literal - is true - when complex literal whose imaginary part is a rational - is true - when complex literal - is true - when float literal - is true - #value_used? - within a while node - is true only for the condition - at the end of a block - is always true - at the top level - is false - within a module definition node - is always true - within an array literal - at the top level - is always false - assigned to an ivar - is always true - within a singleton class node - is always true - within a method call node - is always true - within an if...else..end node - at the top level - is true only for the condition - nested in a method call - is always true - within a class definition node - is always true - sibling_access - returns trivial values for a root node - for a node with siblings - returns the expected values - for a single child - returns the expected values - #module_definition? - nested modules - matches - namespaced modules - matches - with ::ModuleName - matches - using module keyword - matches - prepend Module.new - matches - included module definition - matches - with Module.new - matches - when using numbered parameter - matches - #argument_type? - method arguments - returns true for all argument types - block arguments - returns true for all argument types - #recursive_basic_literal? - behaves like literal - returns true for `!true` - behaves like literal - returns true for `{ :a => 1, :b => 2 }` - behaves like literal - returns true for `{ a: 1, b: 2 }` - behaves like non literal - returns false for `{ :sym => some_method_call }` - behaves like non literal - returns false for `/.#{some_method_call}/` - behaves like literal - returns true for `1` - behaves like literal - returns true for `[1, 2, 3]` - behaves like literal - returns true for `/./` - behaves like literal - returns true for `'str'` - behaves like literal - returns true for `(1)` - behaves like literal - returns true for `(false && true)` - behaves like non literal - returns false for `some_method_call` - behaves like literal - returns true for `(false <=> true)` - behaves like non literal - returns false for `(x or false)` - behaves like non literal - returns false for `%r{abx#{foo}}ixo` - behaves like non literal - returns false for `(x && false)` - behaves like literal - returns true for `%r{abx}ixo` - behaves like literal - returns true for `"#{2}"` - behaves like non literal - returns false for `{ some_method_call => :sym }` - behaves like literal - returns true for `nil` - behaves like non literal - returns false for `[some_method_call]` - behaves like non literal - returns false for `some_method_call(x, y)` - behaves like non literal - returns false for `(x == false)` - behaves like literal - returns true for `(false or true)` - behaves like literal - returns true for `1.0` - behaves like literal - returns true for `false` - #class_constructor? - class definition - does not match - class definition on outer scope - matches - class definition with a block - matches - module definition with a block - matches - #class_definition? - with Struct - matches - when using numbered parameter - matches - constant defined as Struct without block - does not match - with self singleton class - matches - namespaced class - matches - with Class.new - matches - when using numbered parameter - matches - with ::ClassName - matches - with inheritance - matches - with object singleton class - matches - without inheritance - matches - #conditional? - when `case` node - is true - when `case_match` node - is true - when `while` node - is true - when post condition loop node - is false - when `until` node - is true - when `if` node - is true - #pure? - for a method call - returns false - for a cvar assignment - returns false - for a hash literal - which contains a method call - returns false - with only literal children - returns true - for a class definition - returns false - for an lvar assignment - returns false - for a nested if - where the innermost descendants are local vars and literals - returns true - where one branch contains a method call - returns false - where one branch contains an assignment statement - returns false - for an array literal - which contains a method call - returns false - with only literal children - returns true - for a gvar assignment - returns false - for a module definition - returns false - for an ivar assignment - returns false - for a regexp - with options - returns true - with interpolated segments - returns false - with no interpolation - returns true - for an integer literal - returns true - -RuboCop::AST::FloatNode - #value - is expected to eq 1.5 - #sign? - explicit positive float - is expected to be sign - explicit negative float - is expected to be sign - .new - is expected to be a kind of RuboCop::AST::FloatNode - -RuboCop::AST::SendNode - #nonmutating_unary_operator_method? - with a nonmutating unary operator method - is expected to be nonmutating unary operator method + #negation_method? + with suffix `not` + is expected not to be negation method + with prefix bang + is expected to be negation method + with a non-negated method + is expected not to be negation method + with prefix `not` + is expected to be negation method + #implicit_call? + with an explicit call method + is expected not to be implicit call + with an implicit call method + is expected to be implicit call with a regular method - is expected not to be nonmutating unary operator method - #non_bare_access_modifier? - when node is a non-bare `module_function` - is expected to be non bare access modifier - when node does not have an argument - is expected not to be non bare access modifier - when node is not an access modifier - is expected not to be non bare access modifier + is expected not to be implicit call + #def_modifier? + with several prefixed def modifiers + is expected to be def modifier + with a prefixed def modifier + is expected to be def modifier + with a block containing a method definition + is expected not to be def modifier + #def_modifier + with call with no argument + is expected to be nil + with several prefixed def modifiers + is expected to eq :qux + with a block containing a method definition + is expected to be nil + with a prefixed def modifier + is expected to eq :bar #nonmutating_array_method? + with a nonmutating Array method + is expected to be nonmutating array method with a regular method is expected not to be nonmutating array method with a mutating Array method is expected not to be nonmutating array method - with a nonmutating Array method - is expected to be nonmutating array method - #negation_method? - with prefix `not` - is expected to be negation method - with a non-negated method - is expected not to be negation method - with suffix `not` - is expected not to be negation method - with prefix bang - is expected to be negation method + #setter_method? + with an indexed setter method + is expected to be setter method + with a regular method + is expected not to be setter method + with an operator method + is expected not to be setter method + with a setter method + is expected to be setter method + #first_argument + with no arguments + is expected to be nil + with multiple literal arguments + is expected to be sym type + with multiple mixed arguments + is expected to be sym type + with a single splat argument + is expected to be splat type + with a single literal argument + is expected to be sym type + #lambda? + with a stabby lambda method + is expected to be lambda + with a lambda method + is expected to be lambda + with a method named lambda in a class + is expected not to be lambda + with a non-lambda method + is expected not to be lambda #const_receiver? - with a constant receiver - is expected to be const receiver with a non-constant receiver is expected not to be const receiver with a self receiver is expected not to be const receiver - #nonmutating_binary_operator_method? + with a constant receiver + is expected to be const receiver + #dot? + with a unary method + is expected not to be dot + with a dot + is expected to be dot + without a dot + is expected not to be dot + with a double colon + is expected not to be dot + #predicate_method? + with a predicate method + is expected to be predicate method with a regular method - is expected not to be nonmutating binary operator method - with a nonmutating binary operator method - is expected to be nonmutating binary operator method - with a mutating binary operator method - is expected not to be nonmutating binary operator method + is expected not to be predicate method + with a bang method + is expected not to be predicate method + #bare_access_modifier? + when node is not an access modifier + is expected not to be bare access modifier + when node is a bare `module_function` + is expected to be bare access modifier + with Ruby >= 2.7 + when node is access modifier in block + is expected to be bare access modifier + when node is access modifier in numblock + is expected to be bare access modifier + when node has an argument + is expected not to be bare access modifier + #splat_argument? + with no arguments + is expected not to be splat argument + with a splat argument + is expected to be splat argument + with regular arguments + is expected not to be splat argument + with mixed arguments + is expected to be splat argument + #unary_operation? + with a binary operation + is expected not to be unary operation + with an implicit call method + is expected not to be unary operation + with a regular method call + is expected not to be unary operation + with a unary operation + is expected to be unary operation + #bang_method? + with a bang method + is expected to be bang method + with a predicate method + is expected not to be bang method + with a regular method + is expected not to be bang method + #lambda_literal? + with a lambda method + is expected not to be lambda literal + with a non-lambda method + is expected not to be lambda + with a stabby lambda + is expected to be lambda literal + with `a.() {}` style method + is expected not to be lambda #command? when argument is a symbol with an implicit receiver @@ -5323,255 +3640,146 @@ is expected not to be command "bar" with an implicit receiver is expected to be command "bar" - #self_receiver? - with a non-self receiver - is expected not to be self receiver - with a self receiver - is expected to be self receiver - with an implicit receiver - is expected not to be self receiver - .new - with a safe navigation method send - is expected to be a kind of RuboCop::AST::SendNode - with a regular method send - is expected to be a kind of RuboCop::AST::SendNode + #attribute_accessor? + with an accessor + returns the accessor method and Array] + with a call without arguments + is expected to be nil + #enumerable_method? + with a regular method + is expected not to be enumerable method + with an enumerable method + is expected to be enumerable method + #camel_case_method? + with a camel case method + is expected to be camel case method + with a regular method + is expected not to be camel case method #binary_operation?? - with a unary operation - is expected not to be binary operation - with a regular method call - is expected not to be binary operation - with an implicit call method - is expected not to be binary operation with a binary operation is expected to be binary operation - #arithmetic_operation? - with a unary numeric operation - is expected not to be arithmetic operation - with a binary arithmetic operation - is expected to be arithmetic operation - with a regular method call - is expected not to be arithmetic operation - #lambda_literal? - with a lambda method - is expected not to be lambda literal - with a non-lambda method - is expected not to be lambda - with `a.() {}` style method - is expected not to be lambda - with a stabby lambda - is expected to be lambda literal - #unary_operation? - with a unary operation - is expected to be unary operation with an implicit call method - is expected not to be unary operation - with a binary operation - is expected not to be unary operation + is expected not to be binary operation with a regular method call - is expected not to be unary operation - #last_argument - with a single splat argument - is expected to be splat type - with multiple mixed arguments - is expected to be splat type - with multiple literal arguments - is expected to be sym type - with no arguments - is expected to be nil - with a single literal argument - is expected to be sym type + is expected not to be binary operation + with a unary operation + is expected not to be binary operation + #operator_method? + with a unary operator method + is expected to be operator method + with a binary operator method + is expected to be operator method + with a setter method + is expected not to be operator method + with a regular method + is expected not to be operator method #block_argument? + with a block argument + is expected to be block argument with no arguments is expected not to be block argument - with mixed arguments - is expected to be block argument with regular arguments is expected not to be block argument - with a block argument + with mixed arguments is expected to be block argument - #camel_case_method? - with a camel case method - is expected to be camel case method - with a regular method - is expected not to be camel case method - #nonmutating_hash_method? - with a mutating Hash method - is expected not to be nonmutating hash method - with a regular method - is expected not to be nonmutating hash method - with a nonmutating Hash method - is expected to be nonmutating hash method - #arguments - with a single literal argument - is expected to eq 1 - with multiple literal arguments - is expected to eq 2 - with multiple mixed arguments - is expected to eq 2 - with a single splat argument - is expected to eq 1 - with no arguments - is expected to be empty - #prefix_not? + #prefix_bang? with keyword `not` - is expected to be prefix not - with a bang method - is expected not to be prefix not + is expected not to be prefix bang with a non-negated method - is expected not to be prefix not - #implicit_call? - with an explicit call method - is expected not to be implicit call - with an implicit call method - is expected to be implicit call - with a regular method - is expected not to be implicit call - #lambda? - with a non-lambda method - is expected not to be lambda - with a lambda method - is expected to be lambda - with a stabby lambda method - is expected to be lambda - with a method named lambda in a class - is expected not to be lambda - #bang_method? - with a predicate method - is expected not to be bang method - with a regular method - is expected not to be bang method + is expected not to be prefix bang with a bang method - is expected to be bang method - #def_modifier? - with a block containing a method definition - is expected not to be def modifier - with several prefixed def modifiers - is expected to be def modifier - with a prefixed def modifier - is expected to be def modifier - #def_modifier - with a prefixed def modifier - is expected to eq :bar - with call with no argument - is expected to be nil - with a block containing a method definition - is expected to be nil - with several prefixed def modifiers - is expected to eq :qux + is expected to be prefix bang #macro? - with a receiver - when parent is a module - is expected not to be macro - when parent is a class - is expected not to be macro without a receiver - when parent is a block in a macro scope - is expected to be macro - when parent is a class constructor - is expected to be macro - when parent is a struct constructor - is expected to be macro - when parent is a keyword begin inside of an class - is expected to be macro when in the global scope is expected to be macro - when parent is a block not in a macro scope - is expected not to be macro when in an if is expected to be macro - without a parent + when parent is a method definition + is expected not to be macro + when parent is a keyword begin inside of an class is expected to be macro - when parent is a begin without a parent + when parent is a module is expected to be macro when parent is a class is expected to be macro + when parent is a block not in a macro scope + is expected not to be macro with Ruby >= 2.7 when parent is a numblock in a macro scope is expected to be macro + when parent is a begin without a parent + is expected to be macro + when parent is a block in a macro scope + is expected to be macro + without a parent + is expected to be macro + when parent is a struct constructor + is expected to be macro when the condition of an if is expected not to be macro + when parent is a class constructor + is expected to be macro when parent is a singleton class is expected to be macro + with a receiver when parent is a module - is expected to be macro - when parent is a method definition is expected not to be macro + when parent is a class + is expected not to be macro + #block_node + with a block literal + is expected to be block type + with Ruby >= 2.7 + with a numblock literal + is expected to be numblock type + with no block + is expected to be nil + with a block argument + is expected to be nil + #arguments + with no arguments + is expected to be empty + with multiple literal arguments + is expected to eq 2 + with a single literal argument + is expected to eq 1 + with multiple mixed arguments + is expected to eq 2 + with a single splat argument + is expected to eq 1 + #nonmutating_hash_method? + with a nonmutating Hash method + is expected to be nonmutating hash method + with a regular method + is expected not to be nonmutating hash method + with a mutating Hash method + is expected not to be nonmutating hash method + #prefix_not? + with a bang method + is expected not to be prefix not + with a non-negated method + is expected not to be prefix not + with keyword `not` + is expected to be prefix not + #nonmutating_binary_operator_method? + with a regular method + is expected not to be nonmutating binary operator method + with a mutating binary operator method + is expected not to be nonmutating binary operator method + with a nonmutating binary operator method + is expected to be nonmutating binary operator method + #post_condition_loop? + is expected not to be post condition loop #method_name - with an operator method - is expected to eq :== - with an implicit call method - is expected to eq :call with a setter method is expected to eq :bar= + with an implicit call method + is expected to eq :call + with an operator method + is expected to eq :== with a plain method is expected to eq :bar - #prefix_bang? - with a non-negated method - is expected not to be prefix bang - with a bang method - is expected to be prefix bang - with keyword `not` - is expected not to be prefix bang - #loop_keyword? - is expected not to be loop keyword - #assignment_method? - with a bracket assignment method - is expected to be assignment method - with a regular method - is expected not to be assignment method - with a comparison method - is expected not to be assignment method - with an assignment method - is expected to be assignment method - #bare_access_modifier? - when node is a bare `module_function` - is expected to be bare access modifier - when node has an argument - is expected not to be bare access modifier - with Ruby >= 2.7 - when node is access modifier in block - is expected to be bare access modifier - when node is access modifier in numblock - is expected to be bare access modifier - when node is not an access modifier - is expected not to be bare access modifier - #splat_argument? - with no arguments - is expected not to be splat argument - with a splat argument - is expected to be splat argument - with mixed arguments - is expected to be splat argument - with regular arguments - is expected not to be splat argument - #double_colon? - with a double colon - is expected to be double colon - with a dot - is expected not to be double colon - without a dot - is expected not to be double colon - with a unary method - is expected not to be double colon - #attribute_accessor? - with an accessor - returns the accessor method and Array] - with a call without arguments - is expected to be nil - #receiver - with a variable receiver - is expected to be send type - with a literal receiver - is expected to be str type - with no receiver - is expected to be nil - #predicate_method? - with a regular method - is expected not to be predicate method - with a predicate method - is expected to be predicate method - with a bang method - is expected not to be predicate method #access_modifier? when node is not an access modifier is expected not to be bare access modifier @@ -5579,6 +3787,28 @@ is expected to be access modifier when node is a non-bare `module_function` is expected to be access modifier + #nonmutating_unary_operator_method? + with a nonmutating unary operator method + is expected to be nonmutating unary operator method + with a regular method + is expected not to be nonmutating unary operator method + #arithmetic_operation? + with a binary arithmetic operation + is expected to be arithmetic operation + with a regular method call + is expected not to be arithmetic operation + with a unary numeric operation + is expected not to be arithmetic operation + #block_literal? + with no block + is expected not to be block literal + with a block argument + is expected not to be block literal + with Ruby >= 2.7 + with a numblock literal + is expected to be block literal + with a block literal + is expected to be block literal #nonmutating_string_method? with a regular method is expected not to be nonmutating string method @@ -5586,28 +3816,264 @@ is expected not to be nonmutating string method with a nonmutating String method is expected to be nonmutating string method - #first_argument - with a single literal argument - is expected to be sym type - with a single splat argument - is expected to be splat type + #arguments? + with no arguments + is expected not to be arguments with multiple literal arguments - is expected to be sym type + is expected to be arguments with multiple mixed arguments + is expected to be arguments + with a single splat argument + is expected to be arguments + with a single literal argument + is expected to be arguments + #nonmutating_operator_method? + with a nonmutating binary operator method + is expected to be nonmutating operator method + with a mutating binary operator method + is expected not to be nonmutating operator method + with a regular method + is expected not to be nonmutating operator method + with a nonmutating unary operator method + is expected to be nonmutating operator method + #double_colon? + without a dot + is expected not to be double colon + with a double colon + is expected to be double colon + with a dot + is expected not to be double colon + with a unary method + is expected not to be double colon + #comparison_method? + with a comparison method + is expected to be comparison method + with a regular method + is expected not to be comparison method + with a negation method + is expected not to be comparison method + #self_receiver? + with an implicit receiver + is expected not to be self receiver + with a self receiver + is expected to be self receiver + with a non-self receiver + is expected not to be self receiver + #assignment_method? + with a regular method + is expected not to be assignment method + with a bracket assignment method + is expected to be assignment method + with an assignment method + is expected to be assignment method + with a comparison method + is expected not to be assignment method + #loop_keyword? + is expected not to be loop keyword + #non_bare_access_modifier? + when node is not an access modifier + is expected not to be non bare access modifier + when node is a non-bare `module_function` + is expected to be non bare access modifier + when node does not have an argument + is expected not to be non bare access modifier + .new + with a safe navigation method send + is expected to be a kind of RuboCop::AST::SendNode + with a regular method send + is expected to be a kind of RuboCop::AST::SendNode + +RuboCop::AST::PairNode + #delimiter + when using a colon delimiter + is expected to eq ":" + is expected to eq ": " + when using a hash rocket delimiter + is expected to eq " => " + is expected to eq "=>" + #same_line? + when pairs are on separate lines + when both pairs are explicit pairs + is expected not to be same line s(:pair, + s(:sym, :b), + s(:int, 2)) + when last pair is a keyword splat + is expected not to be same line s(:kwsplat, + s(:send, nil, :foo)) + when a multiline pair shares the same line + when last pair is a keyword splat + is expected to be same line s(:pair, + s(:sym, :a), + s(:begin)) + is expected to be same line s(:kwsplat, + s(:send, nil, :foo)) + when both pairs are explicit pairs + is expected to be same line s(:pair, + s(:sym, :a), + s(:begin)) + is expected to be same line s(:pair, + s(:sym, :b), + s(:int, 2)) + when both pairs are on the same line + when both pairs are explicit pairs + is expected to be same line s(:pair, + s(:sym, :b), + s(:int, 2)) + when both pair is a keyword splat + is expected to be same line s(:kwsplat, + s(:send, nil, :foo)) + .new + is expected to be a kind of RuboCop::AST::PairNode + #value_omission? + when not using hash value omission + is expected not to be value omission + when using hash value omission + is expected to be value omission + #value_delta + when using hash rocket delimiters + when both pairs are on the same line + is expected to eq 0 + when values are aligned + when second pair is a keyword splat + is expected to eq 0 + when both pairs are explicit pairs + is expected to eq 0 + when receiver value is behind + is expected to eq -2 + when receiver value is ahead + is expected to eq 2 + when using colon delimiters + when both pairs are on the same line + is expected to eq 0 + when receiver value is behind + is expected to eq -2 + when values are aligned + when second pair is a keyword splat + is expected to eq 0 + when both pairs are explicit pairs + is expected to eq 0 + when receiver value is ahead + is expected to eq 2 + #key + when using a symbol key is expected to be sym type - with no arguments - is expected to be nil - #parenthesized? - with no arguments - when not using parentheses - is expected not to be parenthesized - when using parentheses - is expected to be parenthesized - with arguments - when using parentheses - is expected to be parenthesized - when not using parentheses - is expected not to be parenthesized + when using a string key + is expected to be str type + #key_delta + with alignment set to :left + when using colon delimiters + when receiver key is ahead + when second pair is a keyword splat + is expected to eq 2 + when both pairs are explicit pairs + is expected to eq 2 + when keys are aligned + when second pair is a keyword splat + is expected to eq 0 + when both pairs are explicit pairs + is expected to eq 0 + when both keys are on the same line + when both pairs are explicit pairs + is expected to eq 0 + when second pair is a keyword splat + is expected to eq 0 + when receiver key is behind + when second pair is a keyword splat + is expected to eq -2 + when both pairs are reail pairs + is expected to eq -2 + when using hash rocket delimiters + when both keys are on the same line + when second pair is a keyword splat + is expected to eq 0 + when both pairs are explicit pairs + is expected to eq 0 + when keys are aligned + when second key is a keyword splat + is expected to eq 0 + when both keys are explicit keys + is expected to eq 0 + when receiver key is ahead + when both pairs are explicit pairs + is expected to eq 2 + when second pair is a keyword splat + is expected to eq 2 + when receiver key is behind + when second pair is a keyword splat + is expected to eq -2 + when both pairs are explicit pairs + is expected to eq -2 + with alignment set to :right + when using hash rocket delimiters + when receiver key is behind + when second pair is a keyword splat + is expected to eq 0 + when both pairs are explicit pairs + is expected to eq -2 + when keys are aligned + when second key is a keyword splat + is expected to eq 0 + when both keys are explicit keys + is expected to eq 0 + when receiver key is ahead + when both pairs are explicit pairs + is expected to eq 2 + when second pair is a keyword splat + is expected to eq 0 + when both keys are on the same line + when second pair is a keyword splat + is expected to eq 0 + when both pairs are explicit pairs + is expected to eq 0 + when using colon delimiters + when receiver key is behind + when both pairs are reail pairs + is expected to eq -2 + when second pair is a keyword splat + is expected to eq 0 + when receiver key is ahead + when both pairs are explicit pairs + is expected to eq 2 + when second pair is a keyword splat + is expected to eq 0 + when both keys are on the same line + when both pairs are explicit pairs + is expected to eq 0 + when second pair is a keyword splat + is expected to eq 0 + when keys are aligned + when second pair is a keyword splat + is expected to eq 0 + when both pairs are explicit pairs + is expected to eq 0 + #colon? + when using a colon delimiter + is expected to be colon + when using a hash rocket delimiter + is expected not to be colon + #hash_rocket? + when using a colon delimiter + is expected not to be hash rocket + when using a hash rocket delimiter + is expected to be hash rocket + #value + is expected to be int type + #value_on_new_line? + when value spans multiple lines + is expected not to be value on new line + when value starts on a new line + is expected to be value on new line + when pair is on a single line + is expected not to be value on new line + #inverse_delimiter + when using a hash rocket delimiter + is expected to eq ":" + is expected to eq ": " + when using a colon delimiter + is expected to eq " => " + is expected to eq "=>" + +RuboCop::AST::DefNode #method? when message matches when argument is a symbol @@ -5615,146 +4081,410 @@ when argument is a string is expected to be method "bar" when message does not match - when argument is a string - is expected not to be method "foo" when argument is a symbol is expected not to be method :foo - #block_node - with no block + when argument is a string + is expected not to be method "foo" + #bang_method? + with a regular method + is expected not to be bang method + with a bang method + is expected to be bang method + with a predicate method + is expected not to be bang method + #predicate_method? + with a regular method + is expected not to be predicate method + with a predicate method + is expected to be predicate method + with a bang method + is expected not to be predicate method + #const_receiver? + with a class method definition + is expected not to be const receiver + with a singleton method definition + is expected to be const receiver + with an instance method definition + is expected not to be const receiver + when using Ruby 2.7 or newer + #argument_forwarding? + is expected to be argument forwarding + #body + with a multi-expression body + is expected to be begin type + with a single expression body + is expected to be send type + with no body is expected to be nil - with a block literal - is expected to be block type + #block_argument? + with no arguments + is expected not to be block argument + with regular arguments + is expected not to be block argument with a block argument - is expected to be nil - with Ruby >= 2.7 - with a numblock literal - is expected to be numblock type - #enumerable_method? - with an enumerable method - is expected to be enumerable method + is expected to be block argument + with mixed arguments + is expected to be block argument + #rest_argument? + with mixed arguments + is expected to be rest argument + with a rest argument + is expected to be rest argument + with no arguments + is expected not to be rest argument + with regular arguments + is expected not to be rest argument + #camel_case_method? with a regular method - is expected not to be enumerable method - #comparison_method? - with a negation method - is expected not to be comparison method + is expected not to be camel case method + with a camel case method + is expected to be camel case method + #assignment_method? with a regular method - is expected not to be comparison method + is expected not to be assignment method + with an assignment method + is expected to be assignment method + with a comparison method + is expected not to be assignment method + with a bracket assignment method + is expected to be assignment method + .new + with a defs node + is expected to be a kind of RuboCop::AST::DefNode + with a def node + is expected to be a kind of RuboCop::AST::DefNode + #self_receiver? + with an instance method definition + is expected not to be self receiver + with a singleton method definition + is expected not to be self receiver + with a class method definition + is expected to be self receiver + #arguments + with multiple mixed arguments + is expected to eq 2 + with no arguments + is expected to be empty + with a single regular argument + is expected to eq 1 + with a single rest argument + is expected to eq 1 + with argument forwarding + is expected to eq 1 + with multiple regular arguments + is expected to eq 2 + #arguments? + with multiple mixed arguments + is expected to be arguments + with a single keyword argument + is expected to be arguments + with multiple regular arguments + is expected to be arguments + with a single regular argument + is expected to be arguments + with no arguments + is expected not to be arguments + with a single rest argument + is expected to be arguments + #last_argument + with no arguments + is expected to be nil + with a single rest argument + is expected to be restarg type + with multiple mixed arguments + is expected to be restarg type + with a single keyword argument + is expected to be kwoptarg type + with multiple regular arguments + is expected to be arg type + with a single regular argument + is expected to be arg type + #comparison_method? with a comparison method is expected to be comparison method - #post_condition_loop? - is expected not to be post condition loop - #operator_method? with a regular method - is expected not to be operator method - with a unary operator method - is expected to be operator method + is expected not to be comparison method + #operator_method? with a binary operator method is expected to be operator method + with a unary operator method + is expected to be operator method + with a regular method + is expected not to be operator method with a setter method is expected not to be operator method - #dot? - without a dot - is expected not to be dot + #method_name + with a setter method + is expected to eq :foo= + with an operator method + is expected to eq :== + with a plain method + is expected to eq :foo with a unary method - is expected not to be dot - with a double colon - is expected not to be dot - with a dot - is expected to be dot - #nonmutating_operator_method? - with a nonmutating binary operator method - is expected to be nonmutating operator method - with a nonmutating unary operator method - is expected to be nonmutating operator method - with a mutating binary operator method - is expected not to be nonmutating operator method + is expected to eq :-@ + #endless? + with standard method definition + is expected not to be endless + with endless method definition + is expected to be endless + #void_context? + with a bracket assignment method + is expected to be void context + with a regular assignment method + is expected to be void context with a regular method - is expected not to be nonmutating operator method - #arguments? - with multiple mixed arguments - is expected to be arguments + is expected not to be void context + with an initializer method + is expected to be void context + with a comparison method + is expected not to be void context + #first_argument with no arguments - is expected not to be arguments - with a single literal argument - is expected to be arguments - with multiple literal arguments - is expected to be arguments - with a single splat argument - is expected to be arguments - #block_literal? - with no block - is expected not to be block literal - with a block literal - is expected to be block literal - with Ruby >= 2.7 - with a numblock literal - is expected to be block literal - with a block argument - is expected not to be block literal - #setter_method? - with a regular method - is expected not to be setter method - with an operator method - is expected not to be setter method - with an indexed setter method - is expected to be setter method - with a setter method - is expected to be setter method + is expected to be nil + with multiple regular arguments + is expected to be arg type + with a single keyword argument + is expected to be kwoptarg type + with a single rest argument + is expected to be restarg type + with a single regular argument + is expected to be arg type + with multiple mixed arguments + is expected to be arg type + #receiver + with an instance method definition + is expected to be nil + with a singleton method definition + is expected to be const type + with a class method definition + is expected to be self type + +RuboCop::AST::ProcessedSource + #ast + is the root node of AST + #start_with? + with blank source + returns false + with present source + returns false when passed string that does not start source + returns true when passed string that starts source + #buffer + is a source buffer + token enumerables + #find_token + yields correct token + yields nil when there is no match + #each_token + yields all tokens + #comments + is an array of comments + when the source is invalid + returns [] + #following_line + returns source of line after token + #[] + when a range is passed + returns the array of lines + when an index is passed + returns the line + when start index and length are passed + returns the array of lines + #tokens_within + returns tokens for node + accepts Node as an argument + when heredoc as argument is present + returns tokens for node after heredoc + returns tokens for heredoc node + returns tokens for node before heredoc + #parser_error + when the source was properly parsed + is nil + when the source could not be parsed due to encoding error + returns the error + when the source lacks encoding comment and is really utf-8 encoded but has been read as US-ASCII + is nil + valid_syntax? + when the source could not be parsed due to encoding error + returns false + when the source is invalid + returns false + when the source is valid but has some warning diagnostics + returns true + when the source itself is valid encoding but includes strange encoding literals that are accepted by MRI + returns true + when a line starts with an integer literal + tokenizes the source correctly + when the source is completely valid + returns true + #tokens + has an array of tokens + #preceding_line + returns source of line before token + with heavily commented source + #comment_at_line + returns nil if line has no comment + returns the comment at the given line number + #find_comment + yields nil when there is no match + yields correct comment + #each_comment + yields all comments + #contains_comment? + provided source_range on line without comment + is expected to equal false + provided a multiline source_range with at least one line with comment + is expected to equal true + provided source_range on line with comment + is expected to equal true + provided source_range on comment line + is expected to equal true + #comments_before_line + returns comments on or before given line + #line_with_comment? + returns true for lines with comments + returns false for lines without comments + #each_comment_in_lines + yields the comments + #lines + has same number of elements as line count + is an array + contains lines as string without linefeed + #blank? + with source of no content + returns true + with source with content + returns false + #path + is the path passed to .new + #first_token_of + returns first token for node + accepts Node as an argument + .from_file + raises a Errno::ENOENT when the file does not exist + when the file exists + sets the file path to the instance's #path + returns an instance of ProcessedSource + #file_path + returns file path + #last_token_of + returns last token for node + accepts Node as an argument RuboCop::AST::DefinedNode #receiver is expected to be nil #arguments - is expected to all be sym type is expected to eq 1 + is expected to all be sym type #method_name is expected to eq :defined? .new with a defined? node is expected to be a kind of RuboCop::AST::DefinedNode -RuboCop::AST::OpAsgnNode - #expression - is expected to eq s(:send, nil, :value) - #assignment_node - is expected to be a kind of RuboCop::AST::AsgnNode +RuboCop::AST::ResbodyNode .new - with an `op_asgn_node` node - is expected to be a kind of RuboCop::AST::OpAsgnNode - #name - is expected to eq :var - #operator - with -= - is expected to eq :- - with |= - is expected to eq :| - with **= - is expected to eq :** - with *= - is expected to eq :* - with %= - is expected to eq :% - with /= - is expected to eq :/ - with += - is expected to eq :+ - with &= - is expected to eq :& + is expected to be a kind of RuboCop::AST::ResbodyNode + #exception_variable + for an implicit rescue + is expected to eq "ex" + when an exception variable is not given + is expected to be nil + for an explicit rescue + is expected to eq "ex" + #branch_index + is expected to eq 2 + is expected to eq 1 + is expected to eq 0 + #exceptions + with a single exception + is expected to eq 1 + is expected to all be const type + with multiple exceptions + is expected to eq 2 + is expected to all be const type + without exception + is expected to eq 0 + #body + is expected to be sym type -RuboCop::AST::IntNode - #value - is expected to eq 10 - #sign? - explicit positive int - is expected to be sign - explicit negative int - is expected to be sign +RuboCop::AST::HashNode + #values + with a hash with string keys + is expected to eq 2 + is expected to all be send type + with an empty hash + is expected to be empty + with a hash with literal values + is expected to eq 3 + is expected to all be literal + #each_pair + when not passed a block + is expected to be a kind of Enumerator + when passed a block + yields all the pairs + #mixed_delimiters? + when all pairs are using a colon delimiter + is expected not to be mixed delimiters + when pairs are using different delimiters + is expected to be mixed delimiters + when all pairs are using a hash rocket delimiter + is expected not to be mixed delimiters + #braces? + with braces + is expected to be braces + as an argument with no braces + is expected not to be braces + as an argument with braces + is expected to be braces + #each_value + when not passed a block + is expected to be a kind of Enumerator + when passed a block + yields all the pairs .new - is expected to be a kind of RuboCop::AST::IntNode + is expected to be a kind of RuboCop::AST::HashNode + #pairs_on_same_line? + with some pairs on the same line + is expected to be pairs on same line + with all pairs on the same line + is expected to be pairs on same line + with no pairs on the same line + is expected not to be pairs on same line + #keys + with an empty hash + is expected to be empty + with a hash with symbol keys + is expected to all be sym type + is expected to eq 3 + with a hash with string keys + is expected to eq 2 + is expected to all be str type + #pairs + with an empty hash + is expected to be empty + with a hash of variables + is expected to all be pair type + is expected to eq 2 + with a hash of literals + is expected to all be pair type + is expected to eq 3 + #each_key + when passed a block + yields all the pairs + when not passed a block + is expected to be a kind of Enumerator + #empty? + with an empty hash + is expected to be empty + with a hash containing a keyword splat + is expected not to be empty + with a hash containing pairs + is expected not to be empty -RuboCop::AST::SelfClassNode +RuboCop::AST::ClassNode .new - is expected to be a kind of RuboCop::AST::SelfClassNode + is expected to be a kind of RuboCop::AST::ClassNode #body with a single expression body is expected to be send type @@ -5762,719 +4492,2025 @@ is expected to be begin type with an empty body is expected to be nil + #parent_class + when no parent class is specified + is expected to be nil + when a parent class is specified + is expected to be const type #identifier - is expected to be self type + is expected to be const type -RuboCop::AST::ForwardArgsNode - when using Ruby 2.7 or newer - #to_a - is expected to contain exactly (be forward arg type) +RuboCop::AST::NodePattern + caret (ascend) + within sequence + not in head + is expected to match code s(:int, 1) and :inc + of a sequence + is expected to match code s(:int, 1) and :inc + in head + is expected to match code 1 + of a sequence + is expected to match code 1 + inside a union + is expected to match code "abc" + used with a node type + which matches + is expected to match code 1 + which doesn't match + behaves like nonmatching + doesn't match + repeated twice + is expected to match code 1 + using unification to match self within parent + with self in the wrong position + behaves like nonmatching + doesn't match + with self in the right position + is expected to match code 2 + inside an intersection + is expected to match code 1 + descend + with a match multiple levels, depth first + behaves like single capture + returns captured values if there is no block + yields captured value(s) and returns true if there is a block + with an immediate match + behaves like single capture + returns captured values if there is no block + yields captured value(s) and returns true if there is a block + without match + behaves like nonmatching + doesn't match + nested + behaves like single capture + returns captured values if there is no block + yields captured value(s) and returns true if there is a block + with a literal match + is expected to match code s(:int, 1) and s(:array, + s(:array, + s(:int, 2), + s(:int, 3), + s(:array, + s(:array, + s(:int, 5)))), + s(:int, 4)) + in any order + with a captured ellipsis + nested + behaves like multiple capture + returns captured values if there is no block + yields captured value(s) and returns true if there is a block + matching all children + behaves like single capture + yields captured value(s) and returns true if there is a block + returns captured values if there is no block + matching non sequential children + behaves like single capture + yields captured value(s) and returns true if there is a block + returns captured values if there is no block + captured + without ellipsis + behaves like single capture + returns captured values if there is no block + yields captured value(s) and returns true if there is a block + without ellipsis + with too few children + behaves like nonmatching + doesn't match + with too many children + behaves like nonmatching + doesn't match + with matching children + behaves like multiple capture + yields captured value(s) and returns true if there is a block + returns captured values if there is no block + with an ellipsis + behaves like single capture + yields captured value(s) and returns true if there is a block + returns captured values if there is no block + invalid + nested + behaves like invalid + is invalid + doubled with ellipsis in wrong order + behaves like nonmatching + doesn't match + with an ellipsis inside and outside + behaves like multiple capture + yields captured value(s) and returns true if there is a block + returns captured values if there is no block + doubled with ellipsis + behaves like multiple capture + yields captured value(s) and returns true if there is a block + returns captured values if there is no block + at the beginning of a sequence + behaves like invalid + is invalid + containing ellipsis not at the end + behaves like invalid + is invalid + doubled + separated by an ellipsis + behaves like multiple capture + returns captured values if there is no block + yields captured value(s) and returns true if there is a block + separated by fixed argument + behaves like multiple capture + yields captured value(s) and returns true if there is a block + returns captured values if there is no block + captures on ... + with a remaining sequence at the end + behaves like single capture + returns captured values if there is no block + yields captured value(s) and returns true if there is a block + with a remaining set at the end + behaves like single capture + yields captured value(s) and returns true if there is a block + returns captured values if there is no block + with a remaining [] at the end + behaves like single capture + yields captured value(s) and returns true if there is a block + returns captured values if there is no block + with a remaining wildcard at the end + behaves like single capture + yields captured value(s) and returns true if there is a block + returns captured values if there is no block + after a child + behaves like single capture + returns captured values if there is no block + yields captured value(s) and returns true if there is a block + with no remaining pattern at the end + behaves like single capture + yields captured value(s) and returns true if there is a block + returns captured values if there is no block + with a remaining literal at the end + behaves like single capture + yields captured value(s) and returns true if there is a block + returns captured values if there is no block + with a remaining capture at the end + behaves like multiple capture + returns captured values if there is no block + yields captured value(s) and returns true if there is a block + with a remaining node type at the end + behaves like single capture + returns captured values if there is no block + yields captured value(s) and returns true if there is a block + with remaining patterns at the end + behaves like single capture + yields captured value(s) and returns true if there is a block + returns captured values if there is no block + at the very beginning of a sequence + behaves like single capture + returns captured values if there is no block + yields captured value(s) and returns true if there is a block + bad syntax + with variadic unions where not supported + behaves like invalid + is invalid + with unmatched opening paren and `...` + behaves like invalid + is invalid + with leading comma in arg list + behaves like invalid + is invalid + with doubled ellipsis + is expected to match code "foo" + with negated closing paren + behaves like invalid + is invalid + with negated closing curly + behaves like invalid + is invalid + with unmatched closing curly + behaves like invalid + is invalid + with unmatched closing paren + behaves like invalid + is invalid + with doubled comma in arg list + behaves like invalid + is invalid + with empty intersection + behaves like invalid + is invalid + with empty union subsequence in seq head + behaves like invalid + is invalid + with negated ellipsis + behaves like invalid + is invalid + with empty union + behaves like invalid + is invalid + with unmatched opening paren + behaves like invalid + is invalid + with empty parentheses + behaves like invalid + is invalid + with unsupported subsequence in seq head within union + behaves like invalid + is invalid + with unmatched opening curly + behaves like invalid + is invalid + bare node type + #to_s + is instructive + #== + returns true iff the patterns are similar + #dup + is expected to match code s(:send, nil, :obj) and :method + on a node with a matching, hyphenated type + is expected to match code s(:lvasgn, :a), :+, and s(:int, 1) + yaml compatibility + is expected to match code s(:send, nil, :obj) and :method + #pattern + returns the pattern + on a node with a different type + behaves like nonmatching + doesn't match + marshal compatibility + is expected to match code s(:send, nil, :obj) and :method + on a node with the same type + is expected to match code s(:send, nil, :obj) and :method + wildcards + named wildcards + within a union + confined to the union + with partial unification + that can not be unified + behaves like nonmatching + doesn't match + matching the free branch + is expected to match code s(:int, 2) and s(:int, 1) + matching the unified branch + is expected to match code s(:int, 5) and s(:int, 5) + without unification + is expected to match code s(:int, 2) and s(:int, 1) + with a succeeding unifying constraint + with all branches with the wildcard + matching the first branch + is expected to match code s(:array, + s(:int, 1), + s(:int, 2)) and s(:int, 2) + matching another branch + is expected to match code s(:array, + s(:int, 2), + s(:int, 1)) and s(:int, 2) + that can not be unified + behaves like nonmatching + doesn't match + with branches without the wildcard + encountered first + behaves like invalid + is invalid + encountered after + behaves like invalid + is invalid + with a preceding unifying constraint + matching a branch + is expected to match code s(:int, 2) and s(:array, + s(:int, 2), + s(:int, 1)) + that can not be unified + behaves like nonmatching + doesn't match + at the root level + is expected to match code s(:sclass, + s(:self), + s(:def, :something, + s(:args), + s(:int, 1))) and :freeze + in head position of a sequence + is expected to match code s(:int, 1), :+, and s(:send, nil, :a) + within a sequence + with values which can be unified + is expected to match code s(:int, 5), :+, and s(:int, 5) + with values which cannot be unified + behaves like nonmatching + doesn't match + unifying the node type with an argument + is expected to match code s(:send, nil, :obj) and :send + within a sequence with other patterns intervening + is expected to match code :@abc and s(:int, 22) + unnamed wildcards + within a sequence with other patterns intervening + is expected to match code :@abc and s(:int, 22) + within a sequence + is expected to match code nil and :Const + negated + behaves like nonmatching + doesn't match + at the root level + is expected to match code s(:sclass, + s(:self), + s(:def, :something, + s(:args), + s(:int, 1))) and :freeze + in head position of a sequence + is expected to match code s(:int, 1), :+, and s(:send, nil, :a) + node type + in seq head + on a child with a different type + behaves like nonmatching + doesn't match + on a node with the same type + is expected to match code s(:ivar, :@ivar), :+, and s(:int, 2) + for a child + on a child with the same type + is expected to match code s(:send, nil, :foo) and :bar + on a child with a different type + behaves like nonmatching + doesn't match + on a child litteral + behaves like nonmatching + doesn't match + regexp + matches symbols or strings + macros + with a pattern with a constant + is expected to match code :hello + when the value is not in the set + behaves like nonmatching + doesn't match + with a pattern without captures + def_node_matcher + returns the method name + when called on matching code + is expected to match code :hello + when it errors + raises an error with the right location + when called on non-matching code + behaves like nonmatching + doesn't match + def_node_search + returns the method name + with a predicate name + when called on matching code + is expected to match code nil, :foo, s(:sym, :hello), and s(:sym, :world) + when called on non-matching code + behaves like nonmatching + doesn't match + when it errors + raises an error with the right location + without a predicate name + when it errors + raises an error with the right location + when called on matching code + returns an enumerator yielding the matches + when called on non-matching code + returns an enumerator yielding nothing + with a pattern with a namespaced call + is expected to match code :hello + when the value is not in the set + behaves like nonmatching + doesn't match + with a pattern with captures + def_node_search + with a predicate name + when called on matching code + is expected to match code nil, :foo, s(:sym, :hello), and s(:sym, :world) + when it errors + raises an error with the right location + when called on non-matching code + behaves like nonmatching + doesn't match + without a predicate name + when called on matching code + returns an enumerator yielding the captures + when the pattern contains keyword_params + returns an enumerator yielding the captures + when helper is called with default keyword_params + is overridden when calling the matcher + some defaults are not params + raises an error + and no value is given to the matcher + uses the defaults + when called on non-matching code + returns an enumerator yielding nothing + when it errors + raises an error with the right location + def_node_matcher + when called on matching code + is expected to eq :hello + when called on non-matching code + behaves like nonmatching + doesn't match + when it errors + raises an error with the right location + params + as named parameters + when not provided + raises an ArgumentError + when extra are provided + raises an ArgumentError + when provided as argument to match + is expected to match code s(:int, 10) and {:foo=>#} + when inside a union, with a matching value + is expected to match code s(:int, 10) and 10 + param number zero + in a position which does not match original target node + behaves like nonmatching + doesn't match + in a position which matches original target node + is expected to match code 1 + when negated, with a matching value + behaves like nonmatching + doesn't match + when negated, with a nonmatching value + is expected to match code s(:const, + s(:const, nil, :Namespace), :B) and :A + when inside a union, with a nonmatching value + behaves like nonmatching + doesn't match + when preceded by ... + is expected to match code s(:send, + s(:int, 1), :+, + s(:int, 10)) and s(:int, 10) + when preceded by $... + behaves like single capture + yields captured value(s) and returns true if there is a block + returns captured values if there is no block + in root position + is expected to match code s(:int, 10) and s(:int, 10) + in root position + is expected to match code s(:int, 10) and # + when captured + behaves like single capture + yields captured value(s) and returns true if there is a block + returns captured values if there is no block + when inside an intersection + is expected to match code s(:int, 20), 10, and 20 + in a nested sequence + is expected to match code s(:send, + s(:send, + s(:int, 5), :dec), :inc), :inc, and :dec + without explicit number + is expected to match code s(:const, + s(:const, nil, :Namespace), :A), :A, and s(:const, nil, :Namespace) + negation + on a set + with a matching value + behaves like nonmatching + doesn't match + with a non-matching value + is expected to match code :@a and s(:int, 3) + on a symbol + with a non-matching symbol, but too many children + behaves like nonmatching + doesn't match + with a non-matching symbol + is expected to match code s(:send, nil, :obj) and :xyz + with a matching symbol + behaves like nonmatching + doesn't match + on a string + with a matching string + behaves like nonmatching + doesn't match + with a non-matching symbol + is expected to match code s(:str, "bar") and :upcase + when nested in complex ways + with (send str :+ (send str :to_i)) + is expected to match code s(:str, "abc"), :+, and s(:send, + s(:str, "1"), :to_i) + with (send str :<< str) + behaves like nonmatching + doesn't match + with (send int :- int) + is expected to match code s(:int, 1), :-, and s(:int, 1) + on square brackets + with a node which meets only 1 requirement of [] + is expected to match code 1 + with a node which meets all requirements of [] + behaves like nonmatching + doesn't match + on a sequence + with a node of different type + is expected to match code :@@a and s(:int, 1) + with a matching node + behaves like nonmatching + doesn't match + with a node with non-matching children + is expected to match code :@b and s(:int, 1) + ellipsis + preceding a capture + behaves like single capture + yields captured value(s) and returns true if there is a block + returns captured values if there is no block + with a nodetype at the end, but no remaining child to match it + behaves like nonmatching + doesn't match + with a set at the end, but no remaining child to match it + behaves like nonmatching + doesn't match + preceding multiple captures + behaves like multiple capture + yields captured value(s) and returns true if there is a block + returns captured values if there is no block + with a wildcard at the end, but no remaining child to match it + behaves like nonmatching + doesn't match + with [] at the end, but no remaining child to match it + behaves like nonmatching + doesn't match + at the very beginning of a sequence + is expected to match code s(:int, 10), :*, and s(:int, 1) + with a nested sequence at the end, but no remaining child + behaves like nonmatching + doesn't match + repeated + using + + with zero match + behaves like nonmatching + doesn't match + behaves like repeated pattern + with an ellipsis in the same sequence + is expected to match code "[:hello, 1, 2, 3]" + with one match + behaves like single capture + yields captured value(s) and returns true if there is a block + returns captured values if there is no block + at beginning of sequence + behaves like invalid + is invalid + with matching children + behaves like single capture + yields captured value(s) and returns true if there is a block + returns captured values if there is no block + using ? + with zero match + behaves like single capture + yields captured value(s) and returns true if there is a block + returns captured values if there is no block + with too many matching children + behaves like nonmatching + doesn't match + behaves like repeated pattern + with one match + behaves like single capture + yields captured value(s) and returns true if there is a block + returns captured values if there is no block + with an ellipsis in the same sequence + is expected to match code "[:hello, 1, 2, 3]" + at beginning of sequence + behaves like invalid + is invalid + using * + with no match + behaves like nonmatching + doesn't match + behaves like repeated pattern + with one match + behaves like single capture + returns captured values if there is no block + yields captured value(s) and returns true if there is a block + with an ellipsis in the same sequence + is expected to match code "[:hello, 1, 2, 3]" + at beginning of sequence + behaves like invalid + is invalid + with multiple subcaptures + behaves like multiple capture + yields captured value(s) and returns true if there is a block + returns captured values if there is no block + without capture + is expected to match code s(:sym, :hello), s(:int, 1), s(:int, 2), and s(:int, 3) + with matching children + behaves like single capture + yields captured value(s) and returns true if there is a block + returns captured values if there is no block + nested with multiple subcaptures + behaves like multiple capture + yields captured value(s) and returns true if there is a block + returns captured values if there is no block + with zero match + behaves like single capture + returns captured values if there is no block + yields captured value(s) and returns true if there is a block + funcalls + without extra arguments + is expected to match code :a and s(:int, 1) + with one argument + is expected to match code s(:str, "foo") and "foo" + with multiple arguments + is expected to match code s(:str, "c"), "a", and "d" + comments + behaves like single capture + returns captured values if there is no block + yields captured value(s) and returns true if there is a block + commas + with commas randomly strewn around + behaves like invalid + is invalid + unions + nested inside a sequence + is expected to match code s(:const, nil, :Const) and :method + variadic + multiple + works for complex cases + with variadic terms + works for cases with fixed arity before and after union + works for cases with variadic terms after union + works for cases with variadic terms before and after union + with fixed terms + works for cases with fixed arity before and after union + works for cases with variadic terms before and after union + works for cases with variadic terms after union + with a nested sequence + is expected to match code s(:const, nil, :Const) and :method + at the top level + containing string literals + is expected to match code s(:str, "a") and :upcase + containing mixed node and literals + is expected to match code nil and :obj + containing multiple [] + on a node which meets some requirements but not all + behaves like nonmatching + doesn't match + on a node which meets all requirements of the second [] + is expected to match code 2.4 + on a node which meets all requirements of the first [] + is expected to match code 3 + containing symbol literals + when the AST does not have a matching symbol + behaves like nonmatching + doesn't match + when the AST has a matching symbol + is expected to match code s(:send, nil, :obj) and :b + containing integer literals + is expected to match code s(:int, 10) and :abs + sequence with trailing ... + on a node with non-matching children + behaves like nonmatching + doesn't match + on a node with the same type and fewer children + behaves like nonmatching + doesn't match + on a node with a different type + behaves like nonmatching + doesn't match + on a node with the same type and more children + with 2 children more + is expected to match code s(:int, 1), :blah, s(:int, 1), and s(:sym, :something) + with 1 child more + is expected to match code s(:int, 1), :blah, and s(:int, 1) + on a node with fewer children, with a wildcard preceding + behaves like nonmatching + doesn't match + on a node with the same type and exact number of children + is expected to match code s(:int, 1) and :blah + captures which also perform a match + on a sequence + behaves like single capture + returns captured values if there is no block + yields captured value(s) and returns true if there is a block + on a literal + behaves like single capture + yields captured value(s) and returns true if there is a block + returns captured values if there is no block + on a set + behaves like single capture + yields captured value(s) and returns true if there is a block + returns captured values if there is no block + on a node type + behaves like single capture + yields captured value(s) and returns true if there is a block + returns captured values if there is no block + on [] + behaves like single capture + returns captured values if there is no block + yields captured value(s) and returns true if there is a block + when nested + behaves like multiple capture + yields captured value(s) and returns true if there is a block + returns captured values if there is no block + captures within union + with a different number of captures in each branch + behaves like invalid + is invalid + with complex nesting + behaves like multiple capture + yields captured value(s) and returns true if there is a block + returns captured values if there is no block + within nested sequences + behaves like multiple capture + returns captured values if there is no block + yields captured value(s) and returns true if there is a block + on simple subpatterns + behaves like single capture + yields captured value(s) and returns true if there is a block + returns captured values if there is no block + nil + nil literals + is expected to match code + against a node pattern (bug #5470) + behaves like nonmatching + doesn't match + nil value in AST + behaves like nonmatching + doesn't match + nil value in AST, use nil? method + is expected to match code nil and :foo + simple sequence + on a node with the same type and non-matching children + with non-matching receiver type + behaves like nonmatching + doesn't match + with non-matching selector + behaves like nonmatching + doesn't match + on a node with the same type and matching children + is expected to match code s(:int, 1), :+, and s(:int, 1) + with a nested sequence in non-head position + is expected to match code s(:send, + s(:send, nil, :obj), :a) and :b + on a node with too many children + behaves like nonmatching + doesn't match + on a node with a different type + behaves like nonmatching + doesn't match + with a nested sequence in head position + behaves like invalid + is invalid + literals + double quoted string literals + is expected to match code "foo" + bare literal + on a matching literal + is expected to match code :bar + on a node + behaves like nonmatching + doesn't match + single quoted string literals + is expected to match code "foo" + positive float literals + is expected to match code 1.0 + negative float literals + is expected to match code -2.5 + symbol literals + is expected to match code :foo + negative integer literals + is expected to match code -100 + .descend + yields all children depth first + yields the given argument if it is not a Node + captures on a wildcard + in head position in a sequence against nil (bug #5470) + behaves like nonmatching + doesn't match + in non-head position in a sequence + behaves like single capture + yields captured value(s) and returns true if there is a block + returns captured values if there is no block + in a nested sequence + behaves like single capture + returns captured values if there is no block + yields captured value(s) and returns true if there is a block + at the root level + behaves like single capture + returns captured values if there is no block + yields captured value(s) and returns true if there is a block + nested in any child + behaves like multiple capture + returns captured values if there is no block + yields captured value(s) and returns true if there is a block + in head position in a sequence against literal (bug #5470) + behaves like nonmatching + doesn't match + in head position in a sequence + behaves like single capture + yields captured value(s) and returns true if there is a block + returns captured values if there is no block + predicates + when negated + is expected to match code s(:int, 1) and :inc + with an expression argument + for which the predicate is false + behaves like nonmatching + doesn't match + for which the predicate is true + is expected to match code s(:int, 2), :+, and s(:float, 2.0) + applied to an integer for which the predicate is false + behaves like nonmatching + doesn't match + with multiple arguments + for which the predicate is false + behaves like nonmatching + doesn't match + for which the predicate is true + is expected to match code s(:str, "c"), "a", and "d" + at head position of a sequence + is expected to match code s(:int, 1) and :inc + with a named argument + for which the predicate is true + is expected to match code s(:send, + s(:int, 1), :+, + s(:int, 2)) and {:param=>1} + when not given + raises an error + with extra arguments + raises an error + for which the predicate is false + behaves like nonmatching + doesn't match + applied to an integer for which the predicate is true + is expected to match code s(:int, 1) and :inc + with a constant argument + for which the predicate is true + is expected to match code s(:int, 1), :+, and s(:int, 2) + for which the predicate is false + behaves like nonmatching + doesn't match + with one extra argument + for which the predicate is true + is expected to match code s(:send, + s(:int, 1), :+, + s(:int, 2)) and 1 + for which the predicate is false + behaves like nonmatching + doesn't match + when captured + behaves like single capture + yields captured value(s) and returns true if there is a block + returns captured values if there is no block + in root position + is expected to match code s(:int, 1) and :inc + with name containing a numeral + is expected to match code s(:int, 1) and :inc + when in last-child position, but all children have already been matched + behaves like nonmatching + doesn't match -RuboCop::AST::DstrNode - #value - with a multiline string - is expected to eq "this is a multiline string" - with implicit concatenation - is expected to eq "foo bar baz" - with interpolation - is expected to eq "foo \#{bar} baz" +RuboCop::AST::ArgNode + #name + with an optional argument + is expected to eq :x + with a nameless double splatted argument + is expected to be nil + with a regular argument + is expected to eq :x + with an optional keyword argument + is expected to eq :x + with a nameless splatted argument + is expected to be nil + with a keyword argument + is expected to eq :x + with a double splatted argument + is expected to eq :x + with argument forwarding + with Ruby >= 2.7 + is expected to be nil + with Ruby >= 3.0 + is expected to be nil + with a block argument + is expected to eq :x + with a block + is expected to eq :x + with a shadow argument + is expected to eq :x + with a splatted argument + is expected to eq :x + #default? + with an optional keyword argument + is expected to equal true + with a shadow argument + is expected to equal false + with a block + is expected to equal false + with argument forwarding + with Ruby >= 3.0 + is expected to equal false + with Ruby >= 2.7 + is expected to equal false + with a regular argument + is expected to equal false + with a splatted argument + is expected to equal false + with a double splatted argument + is expected to equal false + with a block argument + is expected to equal false + with an optional argument + is expected to equal true + #default_value + with a block + is expected to be nil + with argument forwarding + with Ruby >= 2.7 + is expected to be nil + with Ruby >= 3.0 + is expected to be nil + with a regular argument + is expected to be nil + with an optional keyword argument + is expected to eq s(:int, 42) + with an optional argument + is expected to eq s(:int, 42) + with a splatted argument + is expected to be nil + with a block argument + is expected to be nil + with a shadow argument + is expected to be nil + with a double splatted argument + is expected to be nil + .new + with a double splatted argument + is expected to be a kind of RuboCop::AST::ArgNode + with a block argument + is expected to be a kind of RuboCop::AST::ArgNode + with a lambda literal + is expected to be a kind of RuboCop::AST::ArgNode + with an optional argument + is expected to be a kind of RuboCop::AST::ArgNode + with a shadow argument + is expected to be a kind of RuboCop::AST::ArgNode + with an optional keyword argument + is expected to be a kind of RuboCop::AST::ArgNode + with a method definition + is expected to be a kind of RuboCop::AST::ArgNode + with a block + is expected to be a kind of RuboCop::AST::ArgNode + with a splatted argument + is expected to be a kind of RuboCop::AST::ArgNode + with argument forwarding + with Ruby >= 2.7 + is expected to be a kind of RuboCop::AST::ArgNode + with Ruby >= 3.0 + is expected to be a kind of RuboCop::AST::ArgNode + with a keyword argument + is expected to be a kind of RuboCop::AST::ArgNode -RuboCop::AST::OrAsgnNode +RuboCop::AST::LambdaNode + #method_name + is expected to eq :lambda + #receiver + is expected to be nil + #arguments + is expected to eq 2 + +RuboCop::AST::ArrayNode + #square_brackets? + with square brackets + is expected to be square brackets + with a percent literal + is expected not to be square brackets .new - is expected to be a kind of RuboCop::AST::OrAsgnNode - #expression - is expected to eq s(:send, nil, :value) - #assignment_node - is expected to be a kind of RuboCop::AST::AsgnNode - #operator - is expected to eq :"||" - #name - is expected to eq :var + is expected to be a kind of RuboCop::AST::ArrayNode + #each_value + without block + is expected to be a kind of Enumerator + with block + is expected to be a kind of RuboCop::AST::ArrayNode + is expected to eq ["(int 1)", "(int 2)", "(int 3)"] + #bracketed? + with square brackets + is expected to be bracketed + unbracketed + is expected to be nil + with a percent literal + is expected to be bracketed + #values + with an empty array + is expected to be empty + with an array of variables + is expected to all be send type + is expected to eq 2 + with an array of literals + is expected to all be literal + is expected to eq 3 + #percent_literal? + with a string percent literal + is expected to be percent literal + is expected not to be percent literal :symbol + is expected to be percent literal :string + with a symbol percent literal + is expected not to be percent literal :string + is expected to be percent literal + is expected to be percent literal :symbol + with square brackets + is expected not to be percent literal :symbol + is expected not to be percent literal :string + is expected not to be percent literal -RuboCop::AST::NextNode +RuboCop::AST::UntilNode + #do? + without a do keyword + is expected not to be do + with a do keyword + is expected to be do + #loop_keyword? + with a modifier until + is expected to be loop keyword + with a statement until + is expected to be loop keyword + .new + with a statement until + is expected to be a kind of RuboCop::AST::UntilNode + with a modifier until + is expected to be a kind of RuboCop::AST::UntilNode + #post_condition_loop? + with a statement until + is expected not to be post condition loop + with a modifier until + is expected to be post condition loop + #inverse_keyword + is expected to eq "while" + #keyword + is expected to eq "until" + +RuboCop::AST::ReturnNode behaves like wrapped arguments node + .new + without arguments + is expected to be a kind of RuboCop::AST::ReturnNode + with arguments + is expected to be a kind of RuboCop::AST::ReturnNode #arguments - with no arguments and braces - is expected to be empty with multiple literal arguments is expected to eq 2 - with no arguments - is expected to be empty with a single splat argument is expected to eq 1 + with no arguments + is expected to be empty with a single argument and braces is expected to eq 1 + with no arguments and braces + is expected to be empty with a single argument is expected to eq 1 + +RuboCop::AST::NextNode + behaves like wrapped arguments node .new with arguments is expected to be a kind of RuboCop::AST::NextNode without arguments is expected to be a kind of RuboCop::AST::NextNode + #arguments + with multiple literal arguments + is expected to eq 2 + with a single argument and braces + is expected to eq 1 + with no arguments + is expected to be empty + with no arguments and braces + is expected to be empty + with a single argument + is expected to eq 1 + with a single splat argument + is expected to eq 1 -RuboCop::AST::ArgsNode - #empty_and_without_delimiters? - with delimiters - with a lambda literal - is expected to equal false - with a block - is expected to equal false - with a method definition - is expected to equal false - with arguments - with a lambda literal - is expected to equal false - with a method definition - is expected to equal false - with empty arguments - with a lambda literal - is expected to equal true - with a block - is expected to equal true - with a method definition - is expected to equal true - #argument_list - is expected to eq [s(:arg, :a), s(:optarg, :b, - s(:int, 42)), s(:arg, :c), s(:restarg, :d), s(:kwarg, :e), s(:kwoptarg, :f, - s(:int, 42)), s(:kwrestarg, :g), s(:blockarg, :h), s(:shadowarg, :i)] - when using Ruby 2.7 or newer - with argument forwarding - is expected to eq [s(:forward_arg)] - .new - with a block - is expected to be a kind of RuboCop::AST::ArgsNode - with a method definition - is expected to be a kind of RuboCop::AST::ArgsNode - with a lambda literal - is expected to be a kind of RuboCop::AST::ArgsNode - -RuboCop::AST::SymbolNode - #value - is expected to eq :foo - .new - with a symbol node - is expected to be a kind of RuboCop::AST::SymbolNode - -RuboCop::AST::Token - #end_pos - returns index of last char in token range of entire source - #begin_pos - returns index of first char in token range of entire source - .from_parser_token - returns a #to_s useful for debugging - sets parser token's range to rubocop token's pos - sets parser token's type to rubocop token's type - sets parser token's text to rubocop token's text - #space_after - returns truthy MatchData when there is a space after token - returns nil when there is not a space after token - type predicates - #left_ref_bracket? - returns false for non left_ref_bracket tokens - returns true for left_ref_bracket tokens - #dot? - returns true for dot tokens - returns false for non dot tokens - #equals_sign? - returns true for equals sign tokens - returns false for non equals sign tokens - #comment? - returns false for non comment tokens - returns true for comment tokens - #end? - returns true for end tokens - returns false for non end tokens - #new_line? - returns false for non new line tokens - returns true for new line tokens - #right_bracket? - returns true for all right_bracket tokens - returns false for non right_bracket tokens - with braces & parens - #left_parens? - returns true for left parens tokens - returns false for non left parens tokens - #right_curly_brace? - returns true for all right brace tokens - returns false for non right brace tokens - #right_parens? - returns false for non right parens tokens - returns true for right parens tokens - #left_brace? - returns true for left hash brace tokens - returns false for non left hash brace tokens - #left_curly_brace? - returns true for left block brace tokens - returns false for non left block brace tokens - #regexp_dots? - returns true for regexp tokens - returns false for non comma tokens - #semicolon? - returns false for non semicolon tokens - returns true for semicolon tokens - #left_array_bracket? - returns true for left_array_bracket tokens - returns false for non left_array_bracket tokens - #left_brace? - returns true for right_bracket tokens - returns false for non right_bracket tokens - #rescue_modifier? - returns true for rescue modifier tokens - returns false for non rescue modifier tokens - #left_bracket? - returns false for non left_bracket tokens - returns true for all left_bracket tokens - #comma? - returns false for non comma tokens - returns true for comma tokens - #to_s - returns string of token data - #line - returns line of token - #column - returns index of first char in token range on that line - #space_before - returns nil when it is on the first line - returns nil when there is not a space before token - returns truthy MatchData when there is a space before token +RuboCop::AST::ConstNode + #namespace + is expected to eq "::Foo::Bar" + #relative? + with a non-namespaced constant + is expected to be relative + #short_name + is expected to eq :BAZ + #each_path + yields all parts of the namespace + #module_name? + is expected not to be module name + with a constant with a lowercase letter + is expected to be module name + #absolute? + is expected to be absolute + with a non-namespaced constant + is expected not to be absolute + with a constant not starting with :: + is expected not to be absolute -RuboCop::AST::CaseNode - #when_branches - is expected to all be when type - is expected to eq 3 - #branches - when there is an else - returns all the bodies - with an empty else - returns all the bodies - when compared to an IfNode - returns the same - when there is no else keyword - returns only then when bodies - #keyword - is expected to eq "case" - .new - is expected to be a kind of RuboCop::AST::CaseNode - #else? - without an else statement - is expected not to be else - with an else statement - is expected to be else - #else_branch +RuboCop::AST::CaseMatchNode + when using Ruby 2.7 or newer + #branches + when there is no else keyword + returns only then when bodies + when there is an else + with else body + returns all the bodies + with empty else + returns all the bodies + #in_pattern_branches + is expected to eq 3 + is expected to all be in pattern type + #each_in_pattern + when not passed a block + is expected to be a kind of Enumerator + when passed a block + yields all the conditions + #else_branch + #else? + without an else statement + is expected to be nil + with an empty else statement + is expected to be empty else type + with an else statement + is expected to be sym type #else? - with an else statement - is expected to be sym type - with an empty else statement - is expected to be nil without an else statement - is expected to be nil - #each_when - when passed a block - yields all the conditions - when not passed a block - is expected to be a kind of Enumerator + is expected not to be else + with an else statement + is expected to be else + #keyword + is expected to eq "case" + .new + is expected to be a kind of RuboCop::AST::CaseMatchNode -RuboCop::AST::CasgnNode - #name - is expected to eq :VAR - #expression - is expected to eq s(:send, nil, :value) +RuboCop::AST::OrNode .new - with a `casgn` node - is expected to be a kind of RuboCop::AST::CasgnNode - #namespace - when the parent is a `cbase` - is expected to eq s(:cbase) - when the parent is a `const` - is expected to eq s(:const, nil, :FOO) - when there is no parent - is expected to be nil + with a logical or node + is expected to be a kind of RuboCop::AST::OrNode + with a semantic or node + is expected to be a kind of RuboCop::AST::OrNode + #lhs + with a semantic or node + is expected to be sym type + with a logical or node + is expected to be sym type + #rhs + with a logical or node + is expected to be int type + with a semantic or node + is expected to be int type + #inverse_operator + with a semantic or node + is expected to eq "and" + with a logical or node + is expected to eq "&&" + #operator + with a semantic or node + is expected to eq "or" + with a logical or node + is expected to eq "||" + #logical_operator? + with a semantic or node + is expected not to be logical operator + with a logical or node + is expected to be logical operator + #semantic_operator? + with a semantic or node + is expected to be semantic operator + with a logical or node + is expected not to be semantic operator + #alternate_operator + with a logical or node + is expected to eq "or" + with a semantic or node + is expected to eq "||" -RuboCop::AST::ModuleNode - #body - with a single expression body - is expected to be send type - with a multi-expression body - is expected to be begin type - with an empty body +RuboCop::AST::Node + #pure? + for an array literal + which contains a method call + returns false + with only literal children + returns true + for a gvar assignment + returns false + for an ivar assignment + returns false + for a regexp + with options + returns true + with no interpolation + returns true + with interpolated segments + returns false + for a nested if + where the innermost descendants are local vars and literals + returns true + where one branch contains an assignment statement + returns false + where one branch contains a method call + returns false + for an integer literal + returns true + for a cvar assignment + returns false + for a class definition + returns false + for a method call + returns false + for a hash literal + which contains a method call + returns false + with only literal children + returns true + for an lvar assignment + returns false + for a module definition + returns false + #argument_type? + block arguments + returns true for all argument types + method arguments + returns true for all argument types + #value_used? + within a module definition node + is always true + within a while node + is true only for the condition + within a singleton class node + is always true + at the end of a block + is always true + within an array literal + at the top level + is always false + assigned to an ivar + is always true + within a class definition node + is always true + within an if...else..end node + nested in a method call + is always true + at the top level + is true only for the condition + at the top level + is false + within a method call node + is always true + #class_constructor? + module definition with a block + matches + class definition with a block + matches + class definition + does not match + class definition on outer scope + matches + #conditional? + when `case_match` node + is true + when `until` node + is true + when post condition loop node + is false + when `case` node + is true + when `while` node + is true + when `if` node + is true + #class_definition? + without inheritance + matches + with self singleton class + matches + constant defined as Struct without block + does not match + with ::ClassName + matches + with Class.new + matches + when using numbered parameter + matches + with Struct + matches + when using numbered parameter + matches + namespaced class + matches + with object singleton class + matches + with inheritance + matches + #parent_module_name + when node on singleton class + is expected to eq "Foo::#" + when node nested in a class << exp is expected to be nil - #identifier - is expected to be const type + when node on module + is expected to eq "Foo" + when node on top level + is expected to eq "Object" + when node nested in an unknown block + is expected to be nil + when node on class in singleton class + is expected to eq "Foo::#::Bar" + #module_definition? + using module keyword + matches + prepend Module.new + matches + with ::ModuleName + matches + with Module.new + matches + when using numbered parameter + matches + namespaced modules + matches + included module definition + matches + nested modules + matches + #recursive_basic_literal? + behaves like literal + returns true for `1` + behaves like non literal + returns false for `{ :sym => some_method_call }` + behaves like literal + returns true for `(false && true)` + behaves like non literal + returns false for `(x or false)` + behaves like non literal + returns false for `(x == false)` + behaves like literal + returns true for `!true` + behaves like non literal + returns false for `some_method_call` + behaves like literal + returns true for `"#{2}"` + behaves like literal + returns true for `(false or true)` + behaves like non literal + returns false for `(x && false)` + behaves like literal + returns true for `'str'` + behaves like literal + returns true for `%r{abx}ixo` + behaves like non literal + returns false for `/.#{some_method_call}/` + behaves like literal + returns true for `/./` + behaves like non literal + returns false for `some_method_call(x, y)` + behaves like literal + returns true for `(false <=> true)` + behaves like literal + returns true for `nil` + behaves like non literal + returns false for `{ some_method_call => :sym }` + behaves like literal + returns true for `{ :a => 1, :b => 2 }` + behaves like non literal + returns false for `%r{abx#{foo}}ixo` + behaves like literal + returns true for `(1)` + behaves like literal + returns true for `1.0` + behaves like literal + returns true for `[1, 2, 3]` + behaves like literal + returns true for `false` + behaves like non literal + returns false for `[some_method_call]` + behaves like literal + returns true for `{ a: 1, b: 2 }` + sibling_access + returns trivial values for a root node + for a node with siblings + returns the expected values + for a single child + returns the expected values + #struct_constructor? + struct definition without block + does not match + ::Struct + matches + struct definition with a block + matches + #numeric_type? + when string literal + is true + when rational literal + is true + when float literal + is true + when complex literal whose imaginary part is a rational + is true + when complex literal + is true + when integer literal + is true + +RuboCop::AST::AndAsgnNode + #expression + is expected to eq s(:send, nil, :value) + #name + is expected to eq :var .new - is expected to be a kind of RuboCop::AST::ModuleNode + is expected to be a kind of RuboCop::AST::AndAsgnNode + #operator + is expected to eq :"&&" + #assignment_node + is expected to be a kind of RuboCop::AST::AsgnNode -RuboCop::AST::NodePattern::Parser - sequences - parses unions of literals as a set - parses capture vs repetition with correct priority - parses simple sequences properly - expands ... in sequence head deep inside unions - generates specialized nodes - parses function calls +RuboCop::AST::RegexpNode + #extended? + with only x option + is expected to be extended + with no options + is expected not to be extended + with other options + is expected not to be extended + with x and other options + is expected to be extended + #fixed_encoding? + with u and other options + is expected to be fixed encoding + with only u option + is expected to be fixed encoding + with other options + is expected not to be fixed encoding + with no options + is expected not to be fixed encoding + #slash_literal? + with %r/-delimiters + is expected not to be slash literal + with multi-line %r{-delimiters + is expected not to be slash literal + with %r<-delimiters + is expected not to be slash literal + with /-delimiters + is expected to be slash literal + with %r{-delimiters + is expected not to be slash literal + #delimiters + with %r<-delimiters + is expected to eq ["<", ">"] + with %r/-delimiters + is expected to eq ["/", "/"] + with /-delimiters + is expected to eq ["/", "/"] + with multi-line %r{-delimiters + is expected to eq ["{", "}"] + with %r{-delimiters + is expected to eq ["{", "}"] + .new + is expected to be a kind of RuboCop::AST::RegexpNode + #single_interpolation? + with only o option + is expected to be single interpolation + with no options + is expected not to be single interpolation + with other options + is expected not to be single interpolation + with o and other options + is expected to be single interpolation + #interpolation? + with no interpolation returns false + is expected not to be interpolation + with regexp quote + is expected to be interpolation + with direct variable interpoation + is expected to be interpolation + #content + with a multi-line regexp with option + is expected to eq "\n.+\n" + with a multi-line regexp without option + is expected to eq "\n.+\n" + with a regexp with option + is expected to eq ".+" + with a regexp without option + is expected to eq ".+" + with an empty regexp with option + is expected to eq "" + with an empty regexp + is expected to eq "" + #multiline_mode? + with other options + is expected not to be multiline mode + with only m option + is expected to be multiline mode + with no options + is expected not to be multiline mode + with m and other options + is expected to be multiline mode + #delimiter? + with %r<-delimiters + is expected not to be delimiter "%" + is expected not to be delimiter "%r<" + is expected to be delimiter ">" + is expected not to be delimiter "r" + is expected not to be delimiter "}" + is expected not to be delimiter "%r" + is expected not to be delimiter "%r{" + is expected not to be delimiter "{" + is expected not to be delimiter "/" + is expected to be delimiter "<" + is expected not to be delimiter "%r/" + with %r/-delimiters + is expected not to be delimiter "r" + is expected not to be delimiter "%" + is expected not to be delimiter "}" + is expected not to be delimiter "%r" + is expected to be delimiter "/" + is expected not to be delimiter "{" + is expected not to be delimiter "%r/" + with multi-line %r{-delimiters + is expected not to be delimiter "r" + is expected not to be delimiter "%r" + is expected to be delimiter "{" + is expected not to be delimiter "%r/" + is expected to be delimiter "}" + is expected not to be delimiter "/" + is expected not to be delimiter "%r{" + is expected not to be delimiter "%" + with %r{-delimiters + is expected to be delimiter "}" + is expected not to be delimiter "%" + is expected to be delimiter "{" + is expected not to be delimiter "%r" + is expected not to be delimiter "r" + is expected not to be delimiter "%r{" + is expected not to be delimiter "/" + is expected not to be delimiter "%r/" + with /-delimiters + is expected to be delimiter "/" + is expected not to be delimiter "{" + #regopt + with an empty regexp + is expected to be regopt type + is expected to be empty + with an empty regexp with option + is expected to eq [:i, :x] + is expected to be regopt type + with a multi-line regexp without option + is expected to be empty + is expected to be regopt type + with a regexp without option + is expected to be regopt type + is expected to be empty + with a regexp with option + is expected to be regopt type + is expected to eq [:i, :m, :x] + with a multi-line regexp with option + is expected to eq [:i, :m, :x] + is expected to be regopt type + #to_regexp + with a regexp with option + is expected to eq /.+/mix + with a regexp with an "o" option + is expected to eq "/abc/i" + with an empty regexp + is expected to eq // + with a regexp with an "n" option + is expected to eq "/abc/n" + with a regexp with an "u" option + is expected to eq "/abc/" + with a regexp without option + is expected to eq /.+/ + with an empty regexp with option + is expected to eq //ix + with a multi-line regexp without option + is expected to eq / +.+ +/ + with a multi-line regexp with option + is expected to eq / +.+ +/ix + #options + with an empty regexp + is expected to eq 0 + with a regexp with "o" option + is expected to eq 0 + with a regexp with single option + is expected to eq 1 + with a regexp without option + is expected to eq 0 + with a regexp with multiple options + is expected to eq 3 + #no_encoding? + with other options + is expected not to be no encoding + with no options + is expected not to be no encoding + with n and other options + is expected to be no encoding + with only n option + is expected to be no encoding + #ignore_case? + with other options + is expected not to be ignore case + with only i option + is expected to be ignore case + with i and other options + is expected to be ignore case + with no options + is expected not to be ignore case + #percent_r_literal? + with multi-line %r{-delimiters + is expected to be percent r literal + with %r/-delimiters + is expected to be percent r literal + with /-delimiters + is expected not to be percent r literal + with %r<-delimiters + is expected to be percent r literal + with %r{-delimiters + is expected to be percent r literal -Set#=== - tests for inclusion +RuboCop::AST::SymbolNode + #value + is expected to eq :foo + .new + with a symbol node + is expected to be a kind of RuboCop::AST::SymbolNode -RuboCop::AST::NodePattern::Lexer - provides tokens via next_token - when given a regexp /test/ - round trips - when given a regexp /back\\slash/ - round trips - with $type+ - is parsed as `$ int + x` - when given arithmetic symbols - is parsed as `:&` - when given node types and constants - distinguishes them - when given a regexp ending with a backslash - does not lexes it properly - when given a regexp /[abc]+\/()?/x - round trips +RuboCop::AST::NodePattern::Sets + is expected to eq "::RuboCop::AST::NodePattern::Sets::SET_1_2_3_ETC" + creates a constant with the right value + is expected to eq "::RuboCop::AST::NodePattern::Sets::SET_1_2_3_ETC" + is expected not to eq "::RuboCop::AST::NodePattern::Sets::SET_1_2_3_ETC_2" -RuboCop::AST::ConstNode - #module_name? - is expected not to be module name - with a constant with a lowercase letter - is expected to be module name - #each_path - yields all parts of the namespace - #short_name - is expected to eq :BAZ - #namespace - is expected to eq "::Foo::Bar" - #absolute? - is expected to be absolute - with a non-namespaced constant - is expected not to be absolute - with a constant not starting with :: - is expected not to be absolute - #relative? - with a non-namespaced constant - is expected to be relative +RuboCop::AST::EnsureNode + .new + is expected to be a kind of RuboCop::AST::EnsureNode + #body + is expected to be sym type RuboCop::AST::BlockNode - #braces? - when enclosed in do-end keywords - is expected not to be braces - when enclosed in braces - is expected to be braces - #void_context? - when block method is tap - is expected to be void context - when block method is not each - is expected not to be void context - when block method is each - is expected to be void context #arguments? with a single argument is expected to be arguments - with multiple mixed arguments - is expected to be arguments - with no arguments - is expected not to be arguments with a single splat argument is expected to be arguments + with destructuring arguments + is expected to be arguments + with multiple mixed arguments + is expected to be arguments >= Ruby 2.7 using numbered parameters is expected not to be arguments - with destructuring arguments - is expected to be arguments + with no arguments + is expected not to be arguments #arguments >= Ruby 2.7 using numbered parameters is expected to be empty - with destructured arguments - is expected to eq 2 with no arguments is expected to be empty + with a single splat argument + is expected to eq 1 with a single literal argument is expected to eq 1 with multiple mixed arguments is expected to eq 2 - with a single splat argument - is expected to eq 1 + with destructured arguments + is expected to eq 2 + #delimiters + when enclosed in braces + is expected to eq ["{", "}"] + when enclosed in do-end keywords + is expected to eq ["do", "end"] + .new + is expected to be a kind of RuboCop::AST::BlockNode + #braces? + when enclosed in braces + is expected to be braces + when enclosed in do-end keywords + is expected not to be braces #multiline? + when block is on several lines + is expected to be multiline when block is on a single line is expected not to be multiline + #receiver + with safe navigation operator call + is expected to eq "foo" + with dot operator call + is expected to eq "foo" + #void_context? + when block method is each + is expected to be void context + when block method is not each + is expected not to be void context + when block method is tap + is expected to be void context + #single_line? + when block is on a single line + is expected to be single line when block is on several lines - is expected to be multiline + is expected not to be single line + #lambda? + when block belongs to a non-lambda method + is expected not to be lambda + when block belongs to a method lambda + is expected to be lambda + when block belongs to a stabby lambda + is expected to be lambda + #keywords? + when enclosed in braces + is expected not to be keywords + when enclosed in do-end keywords + is expected to be keywords #closing_delimiter + when enclosed in braces + is expected to eq "}" when enclosed in do-end keywords is expected to eq "end" + #opening_delimiter + when enclosed in do-end keywords + is expected to eq "do" when enclosed in braces - is expected to eq "}" - .new - is expected to be a kind of RuboCop::AST::BlockNode + is expected to eq "{" #argument_list - with no arguments - is expected to be empty - all argument types - is expected to eq [:a, :b, :c, :d, :e, :f, :g, :h, :i] >= Ruby 2.7 using numbered parameters with skipped params is expected to eq [:_1, :_2, :_3, :_4, :_5, :_6, :_7] with sequential params is expected to eq [:_1, :_2] - #delimiters - when enclosed in do-end keywords - is expected to eq ["do", "end"] - when enclosed in braces - is expected to eq ["{", "}"] - #opening_delimiter - when enclosed in braces - is expected to eq "{" - when enclosed in do-end keywords - is expected to eq "do" - #keywords? - when enclosed in do-end keywords - is expected to be keywords - when enclosed in braces - is expected not to be keywords - #single_line? - when block is on several lines - is expected not to be single line - when block is on a single line - is expected to be single line - #lambda? - when block belongs to a method lambda - is expected to be lambda - when block belongs to a stabby lambda - is expected to be lambda - when block belongs to a non-lambda method - is expected not to be lambda - #receiver - with dot operator call - is expected to eq "foo" - with safe navigation operator call - is expected to eq "foo" - -RuboCop::AST::RuboCopCompatibility - when ran from a compatible version of Rubocop - issues a warning - when ran from an incompatible version of Rubocop - issues a warning + with no arguments + is expected to be empty + all argument types + is expected to eq [:a, :b, :c, :d, :e, :f, :g, :h, :i] -RuboCop::AST::OrNode - #inverse_operator - with a semantic or node - is expected to eq "and" - with a logical or node - is expected to eq "&&" - .new - with a semantic or node - is expected to be a kind of RuboCop::AST::OrNode - with a logical or node - is expected to be a kind of RuboCop::AST::OrNode - #logical_operator? - with a semantic or node - is expected not to be logical operator - with a logical or node - is expected to be logical operator - #semantic_operator? - with a logical or node - is expected not to be semantic operator - with a semantic or node - is expected to be semantic operator - #lhs - with a logical or node - is expected to be sym type - with a semantic or node - is expected to be sym type - #rhs - with a semantic or node - is expected to be int type - with a logical or node - is expected to be int type - #alternate_operator - with a semantic or node - is expected to eq "||" - with a logical or node - is expected to eq "or" - #operator - with a logical or node - is expected to eq "||" - with a semantic or node - is expected to eq "or" +RuboCop::AST::NodePattern::Parser + sequences + generates specialized nodes + expands ... in sequence head deep inside unions + parses function calls + parses capture vs repetition with correct priority + parses simple sequences properly + parses unions of literals as a set -RuboCop::AST::UntilNode - #do? - with a do keyword - is expected to be do - without a do keyword - is expected not to be do - #keyword - is expected to eq "until" - #loop_keyword? - with a statement until - is expected to be loop keyword - with a modifier until - is expected to be loop keyword - #post_condition_loop? - with a statement until - is expected not to be post condition loop - with a modifier until - is expected to be post condition loop - .new - with a modifier until - is expected to be a kind of RuboCop::AST::UntilNode - with a statement until - is expected to be a kind of RuboCop::AST::UntilNode - #inverse_keyword - is expected to eq "while" +Changelog + merges correctly + parses correctly + Changelog::Entry + generates correct content -RuboCop::AST::ClassNode - #parent_class - when no parent class is specified - is expected to be nil - when a parent class is specified - is expected to be const type - #identifier - is expected to be const type - .new - is expected to be a kind of RuboCop::AST::ClassNode - #body - with an empty body - is expected to be nil - with a multi-expression body - is expected to be begin type - with a single expression body - is expected to be send type +Set#=== + tests for inclusion -RuboCop::AST::Procarg0Node - #name - is expected to eq :x +RuboCop::AST::ArgsNode + #empty_and_without_delimiters? + with empty arguments + with a lambda literal + is expected to equal true + with a method definition + is expected to equal true + with a block + is expected to equal true + with arguments + with a lambda literal + is expected to equal false + with a method definition + is expected to equal false + with delimiters + with a lambda literal + is expected to equal false + with a method definition + is expected to equal false + with a block + is expected to equal false + #argument_list + is expected to eq [s(:arg, :a), s(:optarg, :b, + s(:int, 42)), s(:arg, :c), s(:restarg, :d), s(:kwarg, :e), s(:kwoptarg, :f, + s(:int, 42)), s(:kwrestarg, :g), s(:blockarg, :h), s(:shadowarg, :i)] + when using Ruby 2.7 or newer + with argument forwarding + is expected to eq [s(:forward_arg)] .new with a block - is expected to be a kind of RuboCop::AST::ArgNode + is expected to be a kind of RuboCop::AST::ArgsNode + with a lambda literal + is expected to be a kind of RuboCop::AST::ArgsNode + with a method definition + is expected to be a kind of RuboCop::AST::ArgsNode -RuboCop::AST::NodePattern::Sets - is expected not to eq "::RuboCop::AST::NodePattern::Sets::SET_1_2_3_ETC_2" - is expected to eq "::RuboCop::AST::NodePattern::Sets::SET_1_2_3_ETC" - is expected to eq "::RuboCop::AST::NodePattern::Sets::SET_1_2_3_ETC" - creates a constant with the right value +RuboCop::AST::ForwardArgsNode + when using Ruby 2.7 or newer + #to_a + is expected to contain exactly (be forward arg type) -RuboCop::AST::PairNode - #value_delta - when using hash rocket delimiters - when values are aligned - when both pairs are explicit pairs - is expected to eq 0 - when second pair is a keyword splat - is expected to eq 0 - when receiver value is ahead - is expected to eq 2 - when receiver value is behind - is expected to eq -2 - when both pairs are on the same line - is expected to eq 0 - when using colon delimiters - when receiver value is ahead - is expected to eq 2 - when both pairs are on the same line - is expected to eq 0 - when values are aligned - when both pairs are explicit pairs - is expected to eq 0 - when second pair is a keyword splat - is expected to eq 0 - when receiver value is behind - is expected to eq -2 - #key - when using a string key - is expected to be str type - when using a symbol key +RuboCop::AST::WhenNode + .new + is expected to be a kind of RuboCop::AST::WhenNode + #body + without a then keyword + is expected to be array type + with a then keyword is expected to be sym type - #key_delta - with alignment set to :right - when using hash rocket delimiters - when keys are aligned - when second key is a keyword splat - is expected to eq 0 - when both keys are explicit keys - is expected to eq 0 - when both keys are on the same line - when both pairs are explicit pairs - is expected to eq 0 - when second pair is a keyword splat - is expected to eq 0 - when receiver key is ahead - when second pair is a keyword splat - is expected to eq 0 - when both pairs are explicit pairs - is expected to eq 2 - when receiver key is behind - when second pair is a keyword splat - is expected to eq 0 - when both pairs are explicit pairs - is expected to eq -2 - when using colon delimiters - when receiver key is ahead - when second pair is a keyword splat - is expected to eq 0 - when both pairs are explicit pairs - is expected to eq 2 - when both keys are on the same line - when both pairs are explicit pairs - is expected to eq 0 - when second pair is a keyword splat - is expected to eq 0 - when keys are aligned - when second pair is a keyword splat - is expected to eq 0 - when both pairs are explicit pairs - is expected to eq 0 - when receiver key is behind - when both pairs are reail pairs - is expected to eq -2 - when second pair is a keyword splat - is expected to eq 0 - with alignment set to :left - when using hash rocket delimiters - when receiver key is behind - when both pairs are explicit pairs - is expected to eq -2 - when second pair is a keyword splat - is expected to eq -2 - when keys are aligned - when second key is a keyword splat - is expected to eq 0 - when both keys are explicit keys - is expected to eq 0 - when receiver key is ahead - when second pair is a keyword splat - is expected to eq 2 - when both pairs are explicit pairs - is expected to eq 2 - when both keys are on the same line - when second pair is a keyword splat - is expected to eq 0 - when both pairs are explicit pairs - is expected to eq 0 - when using colon delimiters - when keys are aligned - when both pairs are explicit pairs - is expected to eq 0 - when second pair is a keyword splat - is expected to eq 0 - when receiver key is ahead - when both pairs are explicit pairs - is expected to eq 2 - when second pair is a keyword splat - is expected to eq 2 - when receiver key is behind - when both pairs are reail pairs - is expected to eq -2 - when second pair is a keyword splat - is expected to eq -2 - when both keys are on the same line - when second pair is a keyword splat - is expected to eq 0 - when both pairs are explicit pairs - is expected to eq 0 - #inverse_delimiter - when using a hash rocket delimiter - is expected to eq ":" - is expected to eq ": " - when using a colon delimiter - is expected to eq "=>" - is expected to eq " => " + #then? + with a then keyword + is expected to be then + without a then keyword + is expected not to be then + #each_condition + when not passed a block + is expected to be a kind of Enumerator + when passed a block + yields all the conditions + #branch_index + is expected to eq 0 + is expected to eq 2 + is expected to eq 1 + #conditions + with a multiple conditions + is expected to eq 3 + is expected to all be literal + with a single condition + is expected to eq 1 + is expected to all be literal + +RuboCop::AST::IntNode + #sign? + explicit negative int + is expected to be sign + explicit positive int + is expected to be sign #value - is expected to be int type - #colon? - when using a hash rocket delimiter - is expected not to be colon - when using a colon delimiter - is expected to be colon - #delimiter - when using a colon delimiter - is expected to eq ":" - is expected to eq ": " - when using a hash rocket delimiter - is expected to eq " => " - is expected to eq "=>" - #value_omission? - when using hash value omission - is expected to be value omission - when not using hash value omission - is expected not to be value omission - #hash_rocket? - when using a colon delimiter - is expected not to be hash rocket - when using a hash rocket delimiter - is expected to be hash rocket - #same_line? - when pairs are on separate lines - when both pairs are explicit pairs - is expected not to be same line s(:pair, - s(:sym, :b), - s(:int, 2)) - when last pair is a keyword splat - is expected not to be same line s(:kwsplat, - s(:send, nil, :foo)) - when a multiline pair shares the same line - when last pair is a keyword splat - is expected to be same line s(:kwsplat, - s(:send, nil, :foo)) - is expected to be same line s(:pair, - s(:sym, :a), - s(:begin)) - when both pairs are explicit pairs - is expected to be same line s(:pair, - s(:sym, :b), - s(:int, 2)) - is expected to be same line s(:pair, - s(:sym, :a), - s(:begin)) - when both pairs are on the same line - when both pairs are explicit pairs - is expected to be same line s(:pair, - s(:sym, :b), - s(:int, 2)) - when both pair is a keyword splat - is expected to be same line s(:kwsplat, - s(:send, nil, :foo)) - #value_on_new_line? - when pair is on a single line - is expected not to be value on new line - when value spans multiple lines - is expected not to be value on new line - when value starts on a new line - is expected to be value on new line + is expected to eq 10 .new - is expected to be a kind of RuboCop::AST::PairNode + is expected to be a kind of RuboCop::AST::IntNode -RuboCop::AST::ResbodyNode - #exceptions - with multiple exceptions - is expected to all be const type +RuboCop::AST::SuperNode + #arguments? + with multiple literal arguments + is expected to be arguments + with multiple mixed arguments + is expected to be arguments + with a single literal argument + is expected to be arguments + with a single splat argument + is expected to be arguments + with no arguments + is expected not to be arguments + #bang_method? + is expected not to be bang method + #const_receiver? + is expected not to be const receiver + #assignment_method? + is expected not to be assignment method + #predicate_method? + is expected not to be predicate method + #command? + when argument is a symbol + is expected to be command :super + when argument is a string + is expected to be command "super" + #block_node + with a block literal + is expected to be block type + with no block + is expected to be nil + with a block argument + is expected to be nil + #receiver + is expected to be nil + #splat_argument? + with mixed arguments + is expected to be splat argument + with regular arguments + is expected not to be splat argument + with a splat argument + is expected to be splat argument + with no arguments + is expected not to be splat argument + #setter_method? + is expected not to be setter method + #block_literal? + with no block + is expected not to be block literal + with a block argument + is expected not to be block literal + with a block literal + is expected to be block literal + #dot? + is expected not to be dot + #camel_case_method? + is expected not to be camel case method + #macro? + is expected not to be macro + #implicit_call? + is expected not to be implicit call + #method? + when message matches + when argument is a string + is expected to be method "super" + when argument is a symbol + is expected to be method :super + when message does not match + when argument is a string + is expected not to be method "foo" + when argument is a symbol + is expected not to be method :foo + #first_argument + with a single literal argument + is expected to be sym type + with multiple mixed arguments + is expected to be sym type + with a single splat argument + is expected to be splat type + with no arguments + is expected to be nil + with multiple literal arguments + is expected to be sym type + #operator_method? + is expected not to be operator method + #method_name + is expected to eq :super + #last_argument + with multiple mixed arguments + is expected to be splat type + with no arguments + is expected to be nil + with a single literal argument + is expected to be sym type + with multiple literal arguments + is expected to be sym type + with a single splat argument + is expected to be splat type + #parenthesized? + with no arguments + when using parentheses + is expected to be parenthesized + when not using parentheses + is expected not to be parenthesized + with arguments + when not using parentheses + is expected not to be parenthesized + when using parentheses + is expected to be parenthesized + #self_receiver? + is expected not to be self receiver + #double_colon? + is expected not to be double colon + .new + with a zsuper node + is expected to be a kind of RuboCop::AST::SuperNode + with a super node + is expected to be a kind of RuboCop::AST::SuperNode + #block_argument? + with mixed arguments + is expected to be block argument + with no arguments + is expected not to be block argument + with regular arguments + is expected not to be block argument + with a block argument + is expected to be block argument + #arguments + with no arguments + is expected to be empty + with a single literal argument + is expected to eq 1 + with multiple mixed arguments is expected to eq 2 - without exception - is expected to eq 0 - with a single exception - is expected to all be const type + with a single splat argument is expected to eq 1 - #branch_index - is expected to eq 2 - is expected to eq 1 - is expected to eq 0 - #body - is expected to be sym type - #exception_variable - when an exception variable is not given - is expected to be nil - for an explicit rescue - is expected to eq "ex" - for an implicit rescue - is expected to eq "ex" + with multiple literal arguments + is expected to eq 2 + #comparison_method? + is expected not to be comparison method + +RuboCop::AST::RangeNode .new - is expected to be a kind of RuboCop::AST::ResbodyNode + with an infinite range + is expected to be range type + is expected to be a kind of RuboCop::AST::RangeNode + with an exclusive range + is expected to be range type + is expected to be a kind of RuboCop::AST::RangeNode + with a beignless range + is expected to be range type + is expected to be a kind of RuboCop::AST::RangeNode + with an inclusive range + is expected to be range type + is expected to be a kind of RuboCop::AST::RangeNode + +RuboCop::AST::OpAsgnNode + #assignment_node + is expected to be a kind of RuboCop::AST::AsgnNode + #operator + with &= + is expected to eq :& + with **= + is expected to eq :** + with *= + is expected to eq :* + with |= + is expected to eq :| + with /= + is expected to eq :/ + with += + is expected to eq :+ + with %= + is expected to eq :% + with -= + is expected to eq :- + #expression + is expected to eq s(:send, nil, :value) + .new + with an `op_asgn_node` node + is expected to be a kind of RuboCop::AST::OpAsgnNode + #name + is expected to eq :var -Finished in 3.21 seconds (files took 1.19 seconds to load) +Finished in 3.23 seconds (files took 1.18 seconds to load) 2392 examples, 0 failures -Randomized with seed 46231 +Randomized with seed 34457 ┌──────────────────────────────────────────────────────────────────────────────┐ @@ -6509,12 +6545,14 @@ dpkg-buildpackage: info: binary-only upload (no source included) dpkg-genchanges: info: not including original source code in upload I: copying local configuration +I: user script /srv/workspace/pbuilder/433812/tmp/hooks/B01_cleanup starting +I: user script /srv/workspace/pbuilder/433812/tmp/hooks/B01_cleanup finished I: unmounting dev/ptmx filesystem I: unmounting dev/pts filesystem I: unmounting dev/shm filesystem I: unmounting proc filesystem I: unmounting sys filesystem I: cleaning the build env -I: removing directory /srv/workspace/pbuilder/2893848 and its subdirectories -I: Current time: Fri May 29 13:18:44 -12 2026 -I: pbuilder-time-stamp: 1780103924 +I: removing directory /srv/workspace/pbuilder/433812 and its subdirectories +I: Current time: Sun Apr 27 08:56:34 +14 2025 +I: pbuilder-time-stamp: 1745693794 Compressing the 2nd log... /var/lib/jenkins/userContent/reproducible/debian/logdiffs/unstable/arm64/ruby-rubocop-ast_1.24.0-2.diff: 86.1% -- replaced with /var/lib/jenkins/userContent/reproducible/debian/logdiffs/unstable/arm64/ruby-rubocop-ast_1.24.0-2.diff.gz b2/build.log: 85.6% -- replaced with stdout Compressing the 1st log... b1/build.log: 85.9% -- replaced with stdout Sat Apr 26 18:56:37 UTC 2025 I: diffoscope 294 will be used to compare the two builds: ++ date -u +%s + DIFFOSCOPE_STAMP=/var/log/reproducible-builds/diffoscope_stamp_ruby-rubocop-ast_unstable_arm64_1745693797 + touch /var/log/reproducible-builds/diffoscope_stamp_ruby-rubocop-ast_unstable_arm64_1745693797 + RESULT=0 + systemd-run '--description=diffoscope on ruby-rubocop-ast/1.24.0-2 in unstable/arm64' --slice=rb-build-diffoscope.slice -u rb-diffoscope-arm64_6-90431 '--property=SuccessExitStatus=1 124' --user --send-sighup --pipe --wait -E TMPDIR timeout 155m nice schroot --directory /srv/reproducible-results/rbuild-debian/r-b-build.XpjqCx9r --run-session -c jenkins-reproducible-unstable-diffoscope-a900aba2-3502-4478-a4a1-391e14008b20 -- sh -c 'export TMPDIR=/srv/reproducible-results/rbuild-debian/r-b-build.XpjqCx9r/dbd-tmp-48xE501 ; timeout 150m diffoscope --timeout 7200 --html /srv/reproducible-results/rbuild-debian/r-b-build.XpjqCx9r/ruby-rubocop-ast_1.24.0-2.diffoscope.html --text /srv/reproducible-results/rbuild-debian/r-b-build.XpjqCx9r/ruby-rubocop-ast_1.24.0-2.diffoscope.txt --json /srv/reproducible-results/rbuild-debian/r-b-build.XpjqCx9r/ruby-rubocop-ast_1.24.0-2.diffoscope.json --profile=- /srv/reproducible-results/rbuild-debian/r-b-build.XpjqCx9r/b1/ruby-rubocop-ast_1.24.0-2_arm64.changes /srv/reproducible-results/rbuild-debian/r-b-build.XpjqCx9r/b2/ruby-rubocop-ast_1.24.0-2_arm64.changes' + false + set +x Running as unit: rb-diffoscope-arm64_6-90431.service # Profiling output for: /usr/bin/diffoscope --timeout 7200 --html /srv/reproducible-results/rbuild-debian/r-b-build.XpjqCx9r/ruby-rubocop-ast_1.24.0-2.diffoscope.html --text /srv/reproducible-results/rbuild-debian/r-b-build.XpjqCx9r/ruby-rubocop-ast_1.24.0-2.diffoscope.txt --json /srv/reproducible-results/rbuild-debian/r-b-build.XpjqCx9r/ruby-rubocop-ast_1.24.0-2.diffoscope.json --profile=- /srv/reproducible-results/rbuild-debian/r-b-build.XpjqCx9r/b1/ruby-rubocop-ast_1.24.0-2_arm64.changes /srv/reproducible-results/rbuild-debian/r-b-build.XpjqCx9r/b2/ruby-rubocop-ast_1.24.0-2_arm64.changes ## command (total time: 0.000s) 0.000s 1 call cmp (internal) ## has_same_content_as (total time: 0.000s) 0.000s 1 call diffoscope.comparators.binary.FilesystemFile ## main (total time: 0.003s) 0.003s 2 calls outputs 0.000s 1 call cleanup Finished with result: success Main processes terminated with: code=exited/status=0 Service runtime: 240ms CPU time consumed: 240ms _ _ _ __ _ _| |__ _ _ _ __ _ _| |__ ___ ___ ___ _ __ | '__| | | | '_ \| | | |_____| '__| | | | '_ \ / _ \ / __/ _ \| '_ \ _____ | | | |_| | |_) | |_| |_____| | | |_| | |_) | (_) | (_| (_) | |_) |_____| |_| \__,_|_.__/ \__, | |_| \__,_|_.__/ \___/ \___\___/| .__/ |___/ |_| _ __ _ ___| |_ / _` / __| __| | (_| \__ \ |_ \__,_|___/\__| Sat Apr 26 18:56:38 UTC 2025 I: diffoscope 294 found no differences in the changes files, and a .buildinfo file also exists. Sat Apr 26 18:56:38 UTC 2025 I: ruby-rubocop-ast from unstable built successfully and reproducibly on arm64. INSERT 0 1 INSERT 0 1 DELETE 1 [2025-04-26 18:56:38] INFO: Starting at 2025-04-26 18:56:38.599277 [2025-04-26 18:56:38] INFO: Generating the pages of 1 package(s) [2025-04-26 18:56:38] CRITICAL: https://tests.reproducible-builds.org/debian/unstable/arm64/ruby-rubocop-ast didn't produce a buildlog, even though it has been built. [2025-04-26 18:56:38] INFO: Finished at 2025-04-26 18:56:38.926405, took: 0:00:00.327133 Sat Apr 26 18:56:39 UTC 2025 - successfully updated the database and updated https://tests.reproducible-builds.org/debian/rb-pkg/unstable/arm64/ruby-rubocop-ast.html Sat Apr 26 18:56:39 UTC 2025 I: Submitting .buildinfo files to external archives: Sat Apr 26 18:56:39 UTC 2025 I: Submitting 12K b1/ruby-rubocop-ast_1.24.0-2_arm64.buildinfo.asc Sat Apr 26 18:57:09 UTC 2025 E: Could not submit buildinfo from b1 to http://buildinfo.debian.net/api/submit Sat Apr 26 18:57:09 UTC 2025 I: Submitting 12K b2/ruby-rubocop-ast_1.24.0-2_arm64.buildinfo.asc Rejecting submission: Could not determine GPG uid Sat Apr 26 18:57:26 UTC 2025 I: Done submitting .buildinfo files to http://buildinfo.debian.net/api/submit. Sat Apr 26 18:57:26 UTC 2025 I: Done submitting .buildinfo files. Sat Apr 26 18:57:26 UTC 2025 I: Removing signed ruby-rubocop-ast_1.24.0-2_arm64.buildinfo.asc files: removed './b1/ruby-rubocop-ast_1.24.0-2_arm64.buildinfo.asc' removed './b2/ruby-rubocop-ast_1.24.0-2_arm64.buildinfo.asc' 1745693846 arm64 unstable ruby-rubocop-ast Starting cleanup. /var/lib/jenkins/userContent/reproducible/debian/rbuild/unstable/arm64/ruby-rubocop-ast_1.24.0-2.rbuild.log: 85.1% -- replaced with /var/lib/jenkins/userContent/reproducible/debian/rbuild/unstable/arm64/ruby-rubocop-ast_1.24.0-2.rbuild.log.gz [2025-04-26 18:57:27] INFO: Starting at 2025-04-26 18:57:27.068173 [2025-04-26 18:57:27] INFO: Generating the pages of 1 package(s) [2025-04-26 18:57:27] INFO: Finished at 2025-04-26 18:57:27.435196, took: 0:00:00.367041 All cleanup done. Sat Apr 26 18:57:27 UTC 2025 - total duration: 0h 2m 3s. Sat Apr 26 18:57:27 UTC 2025 - reproducible_build.sh stopped running as /tmp/jenkins-script-KUI0McnZ, removing. Finished with result: success Main processes terminated with: code=exited/status=0 Service runtime: 2min 52.250s CPU time consumed: 7.785s