Diff of the two buildlogs: -- --- b1/build.log 2024-12-03 23:10:35.732475207 +0000 +++ b2/build.log 2024-12-03 23:12:42.178737158 +0000 @@ -1,6 +1,6 @@ I: pbuilder: network access will be disabled during build -I: Current time: Tue Dec 3 11:08:00 -12 2024 -I: pbuilder-time-stamp: 1733267280 +I: Current time: Wed Dec 4 13:10:45 +14 2024 +I: pbuilder-time-stamp: 1733267445 I: Building the build Environment I: extracting base tarball [/var/cache/pbuilder/trixie-reproducible-base.tgz] I: copying local configuration @@ -29,52 +29,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/31364/tmp/hooks/D02_print_environment starting +I: user script /srv/workspace/pbuilder/14701/tmp/hooks/D01_modify_environment starting +debug: Running on virt64b. +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 Dec 3 23:10 /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/14701/tmp/hooks/D01_modify_environment finished +I: user script /srv/workspace/pbuilder/14701/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='armhf' - DEBIAN_FRONTEND='noninteractive' - DEB_BUILD_OPTIONS='buildinfo=+all reproducible=+all parallel=3 ' - DISTRIBUTION='trixie' - HOME='/root' - HOST_ARCH='armhf' + 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]="32" [3]="1" [4]="release" [5]="arm-unknown-linux-gnueabihf") + BASH_VERSION='5.2.32(1)-release' + BUILDDIR=/build/reproducible-path + BUILDUSERGECOS='second user,second room,second work-phone,second home-phone,second other' + BUILDUSERNAME=pbuilder2 + BUILD_ARCH=armhf + DEBIAN_FRONTEND=noninteractive + DEB_BUILD_OPTIONS='buildinfo=+all reproducible=+all parallel=4 ' + DIRSTACK=() + DISTRIBUTION=trixie + EUID=0 + FUNCNAME=([0]="Echo" [1]="main") + GROUPS=() + HOME=/root + HOSTNAME=i-capture-the-hostname + HOSTTYPE=arm + HOST_ARCH=armhf IFS=' ' - INVOCATION_ID='354743f05d554be98e593376ba940c0b' - 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='31364' - PS1='# ' - PS2='> ' + INVOCATION_ID=3d9335d50dba43e8ba16bfd6397a3bf7 + LANG=C + LANGUAGE=it_CH:it + LC_ALL=C + MACHTYPE=arm-unknown-linux-gnueabihf + MAIL=/var/mail/root + OPTERR=1 + OPTIND=1 + OSTYPE=linux-gnueabihf + 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=14701 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.rKIEYXCF/pbuilderrc_EV4d --distribution trixie --hookdir /etc/pbuilder/first-build-hooks --debbuildopts -b --basetgz /var/cache/pbuilder/trixie-reproducible-base.tgz --buildresult /srv/reproducible-results/rbuild-debian/r-b-build.rKIEYXCF/b1 --logfile b1/build.log ruby-rubocop-ast_1.24.0-2.dsc' - SUDO_GID='112' - SUDO_UID='106' - SUDO_USER='jenkins' - TERM='unknown' - TZ='/usr/share/zoneinfo/Etc/GMT+12' - USER='root' - _='/usr/bin/systemd-run' - http_proxy='http://10.0.0.15:3142/' + 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.rKIEYXCF/pbuilderrc_XGlh --distribution trixie --hookdir /etc/pbuilder/rebuild-hooks --debbuildopts -b --basetgz /var/cache/pbuilder/trixie-reproducible-base.tgz --buildresult /srv/reproducible-results/rbuild-debian/r-b-build.rKIEYXCF/b2 --logfile b2/build.log ruby-rubocop-ast_1.24.0-2.dsc' + SUDO_GID=113 + SUDO_UID=107 + SUDO_USER=jenkins + TERM=unknown + TZ=/usr/share/zoneinfo/Etc/GMT-14 + UID=0 + USER=root + _='I: set' + http_proxy=http://10.0.0.15:3142/ I: uname -a - Linux virt32b 6.1.0-28-armmp-lpae #1 SMP Debian 6.1.119-1 (2024-11-22) armv7l GNU/Linux + Linux i-capture-the-hostname 6.1.0-28-arm64 #1 SMP Debian 6.1.119-1 (2024-11-22) aarch64 GNU/Linux I: ls -l /bin lrwxrwxrwx 1 root root 7 Nov 22 14:40 /bin -> usr/bin -I: user script /srv/workspace/pbuilder/31364/tmp/hooks/D02_print_environment finished +I: user script /srv/workspace/pbuilder/14701/tmp/hooks/D02_print_environment finished -> Attempting to satisfy build-dependencies -> Creating pbuilder-satisfydepends-dummy package Package: pbuilder-satisfydepends-dummy @@ -261,7 +293,7 @@ Get: 137 http://deb.debian.org/debian trixie/main armhf ruby-rspec-mocks all 3.13.0c0e0m0s1-2 [81.3 kB] Get: 138 http://deb.debian.org/debian trixie/main armhf ruby-rspec all 3.13.0c0e0m0s1-2 [5184 B] Get: 139 http://deb.debian.org/debian trixie/main armhf ruby-whitequark-parser all 3.1.3.0-1 [424 kB] -Fetched 42.5 MB in 2s (19.4 MB/s) +Fetched 42.5 MB in 1s (35.0 MB/s) debconf: delaying package configuration, since apt-utils is not installed Selecting previously unselected package libpython3.12-minimal:armhf. (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 ... 19683 files and directories currently installed.) @@ -729,8 +761,8 @@ Setting up tzdata (2024b-3) ... Current default time zone: 'Etc/UTC' -Local time is now: Tue Dec 3 23:09:25 UTC 2024. -Universal Time is now: Tue Dec 3 23:09:25 UTC 2024. +Local time is now: Tue Dec 3 23:11:46 UTC 2024. +Universal Time is now: Tue Dec 3 23:11:46 UTC 2024. Run 'dpkg-reconfigure tzdata' if you wish to change it. Setting up autotools-dev (20220109.1) ... @@ -853,7 +885,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/14701/tmp/hooks/A99_set_merged_usr starting +Not re-configuring usrmerge for trixie +I: user script /srv/workspace/pbuilder/14701/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 @@ -893,7 +929,7 @@ │ ruby-rubocop-ast: Installing files and building extensions for ruby3.1 │ └──────────────────────────────────────────────────────────────────────────────┘ -/usr/bin/ruby3.1 -S gem build --config-file /dev/null --verbose /tmp/d20241203-3626-h6hhxf/gemspec +/usr/bin/ruby3.1 -S gem build --config-file /dev/null --verbose /tmp/d20241204-19453-kg7lsx/gemspec Failed to load /dev/null because it doesn't contain valid YAML hash WARNING: open-ended dependency on parser (>= 3.1.1.0) is not recommended if parser is semantically versioned, use: @@ -903,7 +939,7 @@ Name: rubocop-ast Version: 1.24.0 File: rubocop-ast-1.24.0.gem -/usr/bin/ruby3.1 -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/d20241203-3626-h6hhxf/rubocop-ast-1.24.0.gem +/usr/bin/ruby3.1 -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/d20241204-19453-kg7lsx/rubocop-ast-1.24.0.gem Failed to load /dev/null because it doesn't contain valid YAML hash /build/reproducible-path/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 @@ -1030,960 +1066,1017 @@ warning: parser/current is loading parser/ruby31, which recognizes3.1.3-compliant syntax, but you are running 3.1.2. Please see https://github.com/whitequark/parser#compatibility-with-ruby-mri. -Randomized with seed 28886 +Randomized with seed 30384 -Changelog - merges correctly - parses correctly - Changelog::Entry - generates correct content - -RuboCop::AST::DstrNode - #value - with a multiline string - is expected to eq "this is a multiline string" - with interpolation - is expected to eq "foo \#{bar} baz" - with implicit concatenation - is expected to eq "foo bar baz" - -RuboCop::AST::RegexpNode - #interpolation? - with direct variable interpoation - is expected to be interpolation - with no interpolation returns false - is expected not to be interpolation - with regexp quote - is expected to be interpolation - #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 "" - #no_encoding? - with n and other options - is expected to be no encoding - with other options - is expected not to be no encoding - with no options - is expected not to be no encoding - with only n option - is expected to be no encoding - #multiline_mode? - with only m option - is expected to be multiline mode - with other options - is expected not to be multiline mode - with m and other options - is expected to be multiline mode - with no options - is expected not to be multiline mode - .new - is expected to be a kind of RuboCop::AST::RegexpNode - #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 - #slash_literal? - with multi-line %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 - with %r<-delimiters - is expected not to be slash literal - with %r/-delimiters - is expected not to be slash literal - #delimiter? - with /-delimiters - is expected to be delimiter "/" - is expected not to be delimiter "{" - with multi-line %r{-delimiters - 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 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 "%r{" - 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 "%" - is expected to be delimiter "{" - with %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 "/" - 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 to be delimiter "<" - with %r/-delimiters - is expected 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 "%" - is expected not to be delimiter "}" - #fixed_encoding? - with only u option - is expected to be fixed encoding - with other options - is expected not to be fixed encoding - with u and other options - is expected to be fixed encoding - with no options - is expected not to be fixed encoding - #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 - #to_regexp - with a multi-line regexp with option - is expected to eq / -.+ -/ix - with a regexp with an "o" option - is expected to eq "/abc/i" - with a regexp with option - is expected to eq /.+/mix - with an empty regexp with option - is expected to eq //ix - with a regexp without option - is expected to eq /.+/ - with a regexp with an "n" option - is expected to eq "/abc/n" - with a multi-line regexp without option - is expected to eq / -.+ -/ - with an empty regexp - is expected to eq // - with a regexp with an "u" option - is expected to eq "/abc/" - #delimiters - with %r{-delimiters - is expected to eq ["{", "}"] - with %r<-delimiters - is expected to eq ["<", ">"] - with /-delimiters - is expected to eq ["/", "/"] - with %r/-delimiters - is expected to eq ["/", "/"] - with multi-line %r{-delimiters - is expected to eq ["{", "}"] - #options - with a regexp with multiple options - is expected to eq 3 - with an empty regexp - is expected to eq 0 - with a regexp with single option - is expected to eq 1 - with a regexp with "o" option - is expected to eq 0 - with a regexp without option - is expected to eq 0 - #regopt - with an empty regexp with option - is expected to eq [:i, :x] - is expected to be regopt type - with an empty regexp - is expected to be regopt type - is expected to be empty - with a multi-line regexp with option - is expected to eq [:i, :m, :x] - is expected to be regopt type - with a regexp without option - is expected to be empty - is expected to be regopt type - 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 - #percent_r_literal? - with %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 - with multi-line %r{-delimiters - is expected to be percent r literal - with /-delimiters - is expected not to be percent r literal - #single_interpolation? - with other options - is expected not to be single interpolation - with no options - is expected not to be single interpolation - with o and other options - is expected to be single interpolation - with only o option - is expected to be single interpolation - -RuboCop::AST::OpAsgnNode - #name - is expected to eq :var - #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 - #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) - -Set#=== - tests for inclusion - -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 - #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 - #rhs - with a logical and node - is expected to be int type - with a semantic and node - is expected to be int type - #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 - .new - with a semantic and node - is expected to be a kind of RuboCop::AST::AndNode - with a logical and node - is expected to be a kind of RuboCop::AST::AndNode - #inverse_operator - with a logical and node - is expected to eq "||" - with a semantic and node - is expected to eq "or" - #alternate_operator - with a semantic and node - is expected to eq "&&" - with a logical and node - is expected to eq "and" - #operator - with a logical and node - is expected to eq "&&" - with a semantic and node - is expected to eq "and" - -RuboCop::AST::SuperNode - #bang_method? - is expected not to be bang method - #comparison_method? - is expected not to be comparison method +RuboCop::AST::SendNode + #arithmetic_operation? + with a binary arithmetic operation + is expected to be arithmetic operation + with a unary numeric operation + is expected not to be arithmetic operation + with a regular method call + is expected not to be arithmetic operation + #access_modifier? + when node is a bare `module_function` + is expected to be access modifier + when node is not an access modifier + is expected not to be bare access modifier + when node is a non-bare `module_function` + is expected to be access modifier #method_name - is expected to eq :super - #splat_argument? - with regular arguments - is expected not to be splat argument - with mixed arguments - is expected to be splat argument - with a splat argument - is expected to be splat argument + 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 + #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 numblock + is expected to be bare access modifier + when node is access modifier in block + is expected to be bare access modifier + when node has an argument + is expected not to be bare access modifier + when node is not an access modifier + is expected not to be bare access modifier + #double_colon? + with a unary method + is expected not to be 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 + #def_modifier? + with a block containing a method definition + is expected not to be def modifier + with a prefixed def modifier + is expected to be def modifier + with several prefixed def modifiers + is expected to be def modifier + #first_argument with no arguments - is expected not to be splat argument - #last_argument - with multiple mixed arguments - is expected to be splat type - with multiple literal 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 no arguments - is expected to be nil + with multiple mixed arguments + is expected to be sym type + with multiple literal arguments + is expected to be sym type + #last_argument with a single literal argument is expected to be sym type - #assignment_method? - is expected not to be assignment method - #parenthesized? - with arguments - when using parentheses - is expected to be parenthesized - when not using parentheses - is expected not to be parenthesized + with multiple literal arguments + is expected to be sym type with no arguments - when using parentheses - is expected to be parenthesized - when not using parentheses - is expected not to be parenthesized - #arguments? + is expected to be nil + with multiple mixed arguments + is expected to be splat type with a single splat argument + is expected to be splat type + #comparison_method? + with a negation method + is expected not to be comparison method + with a comparison method + is expected to be comparison method + with a regular method + is expected not to be comparison method + #lambda? + with a non-lambda method + is expected not to be lambda + with a method named lambda in a class + is expected not to be lambda + with a stabby lambda method + is expected to be lambda + with a lambda method + is expected to be lambda + #arguments? + with a single literal 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 no arguments + is expected not to be arguments with multiple literal arguments is expected to be arguments - with a single literal argument + with a single splat argument is expected to be arguments - #double_colon? - is expected not to be double colon - #camel_case_method? - is expected not to be camel case method - #operator_method? - is expected not to be operator method + #attribute_accessor? + with an accessor + returns the accessor method and Array] + with a call without arguments + is expected to be nil + #unary_operation? + with a regular method call + is expected not to be 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 unary operation + is expected to be unary operation + #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 + 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 + #post_condition_loop? + is expected not to be post condition loop + #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 + #setter_method? + with a 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 an indexed setter method + is expected to be setter method + #binary_operation?? + with a binary operation + is expected to be binary operation + with a unary operation + is expected not 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 + #arguments + with multiple literal arguments + is expected to eq 2 + 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 no arguments + is expected to be empty + #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 + with a regular method + is expected not to be nonmutating string method + #negation_method? + with suffix `not` + is expected not to be negation method + with prefix `not` + is expected 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 + #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 #dot? - is expected not to be dot + without a dot + is expected not to be dot + with a double colon + is expected not to be dot + with a dot + is expected to be dot + with a unary method + is expected not to be dot + #def_modifier + 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 + with call with no argument + 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 #block_argument? + with a block argument + is expected to be block argument with regular arguments is expected not to be block argument with no arguments is expected not to be block argument with mixed arguments is expected to be block argument - with a block argument - is expected to be block argument - #implicit_call? - is expected not to be implicit call - #receiver - is expected to be nil - #macro? - is expected not to be macro - #command? - when argument is a string - is expected to be command "super" - when argument is a symbol - is expected to be command :super - #setter_method? - is expected not to be setter method - #const_receiver? - is expected not to be const receiver + #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 #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" - when message matches - when argument is a symbol - is expected to be method :super - when argument is a string - is expected to be method "super" + #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 #self_receiver? - is expected not to be self receiver - .new - with a super node - is expected to be a kind of RuboCop::AST::SuperNode - with a zsuper node - is expected to be a kind of RuboCop::AST::SuperNode + with a self receiver + is expected to be self receiver + with an implicit receiver + is expected not to be self receiver + with a non-self receiver + is expected not to be self receiver #block_node + 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 with no block is expected to be nil - with a block literal - is expected to be block type - #first_argument - with multiple mixed 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 - with multiple literal arguments - is expected to be sym type - with no arguments + #receiver + with no receiver is expected to be nil - #arguments - with a single literal argument - is expected to eq 1 - with a single splat argument - is expected to eq 1 - with no arguments - is expected to be empty - with multiple literal arguments - is expected to eq 2 - with multiple mixed arguments - is expected to eq 2 - #predicate_method? - is expected not to be predicate method + with a literal receiver + is expected to be str type + with a variable receiver + is expected to be send type + #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 + #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 + with a regular method + is expected not to be nonmutating array 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 + #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 #block_literal? - with a block argument - 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 with no block is expected not to be block literal - -RuboCop::AST::KeywordSplatNode + #macro? + with a receiver + when parent is a class + is expected not to be macro + when parent is a module + is expected not to be macro + without a receiver + when in the global scope + is expected to be macro + without a parent + is expected to be macro + when parent is a singleton class + is expected to be macro + when parent is a block in a macro scope + is expected 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 class constructor + is expected to be macro + when parent is a struct constructor + is expected to be macro + when parent is a class + 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 begin without a parent + is expected to be macro + when in an if + is expected to be macro + when parent is a block not in a macro scope + is expected not to be macro + when the condition of an if + is expected not to be macro + when parent is a module + is expected to be macro + #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 + #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 + #command? + when argument is a symbol + with an explicit receiver + is expected not to be command :bar + with an implicit receiver + is expected to be command :bar + when argument is a string + with an implicit receiver + is expected to be command "bar" + with an explicit receiver + is expected not to be command "bar" + #implicit_call? + with a regular method + is expected not to be 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 + #assignment_method? + with a comparison 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 regular method + is expected not to be assignment method + #nonmutating_unary_operator_method? + with a regular method + is expected not to be nonmutating unary operator method + with a nonmutating unary operator method + is expected to be nonmutating unary operator method + #loop_keyword? + is expected not to be loop keyword + #enumerable_method? + with an enumerable method + is expected to be enumerable method + with a regular method + is expected not to be enumerable method + #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 + with a regular method + is expected not to be nonmutating binary operator method + #lambda_literal? + with a stabby lambda + is expected to be lambda literal + with a non-lambda method + is expected not to be lambda + with a lambda method + is expected not to be lambda literal + with `a.() {}` style method + is expected not to be lambda + #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 unary operator method + is expected to be operator method + with a regular method + is expected not to be operator method .new - is expected to be a kind of RuboCop::AST::KeywordSplatNode - #hash_rocket? - is expected not to be hash rocket - #same_line? - 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, - s(:send, nil, :foo)) - #value_delta - when using colon delimiters - 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 keyword splat is behind - is expected to eq 0 - when using hash rocket delimiters - 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 keyword splat is behind - is expected to eq 0 - when keyword splat is ahead - 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 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 - when keyword splat is behind - is expected to eq 0 - with alignment set to :left - when using hash rocket 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 on the same line - is expected to eq 0 - when keyword splat is behind - is expected to eq -2 - 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 + with a regular method send + is expected to be a kind of RuboCop::AST::SendNode + with a safe navigation method send + is expected to be a kind of RuboCop::AST::SendNode + +RuboCop::AST::DstrNode #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)) - #operator - is expected to eq "**" + with implicit concatenation + is expected to eq "foo bar baz" + with a multiline string + is expected to eq "this is a multiline string" + with interpolation + is expected to eq "foo \#{bar} baz" -RuboCop::AST::SymbolNode +RuboCop::AST::NodePattern::Lexer + provides tokens via next_token + when given a regexp /[abc]+\/()?/x + round trips + when given node types and constants + distinguishes them + when given a regexp /test/ + round trips + with $type+ + is parsed as `$ int + x` + when given a regexp ending with a backslash + does not lexes it properly + when given arithmetic symbols + is parsed as `:&` + when given a regexp /back\\slash/ + round trips + +RuboCop::AST::CaseMatchNode + when using Ruby 2.7 or newer + .new + is expected to be a kind of RuboCop::AST::CaseMatchNode + #else_branch + #else? + with an else statement + is expected to be sym type + with an empty else statement + is expected to be empty else type + without an else statement + is expected to be nil + #each_in_pattern + when not passed a block + is expected to be a kind of Enumerator + when passed a block + yields all the conditions + #branches + when there is no else keyword + returns only then when bodies + when there is an else + with empty else + returns all the bodies + with else body + returns all the bodies + #else? + with an else statement + is expected to be else + without an else statement + is expected not to be else + #in_pattern_branches + is expected to all be in pattern type + is expected to eq 3 + #keyword + is expected to eq "case" + +RuboCop::AST::FloatNode + .new + is expected to be a kind of 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 :foo + is expected to eq 1.5 + +RuboCop::AST::CaseNode + #each_when + when not passed a block + is expected to be a kind of Enumerator + when passed a block + yields all the conditions + #else? + without an else statement + is expected not to be else + with an else statement + is expected to be else + #else_branch + #else? + without an else statement + is expected to be nil + with an empty else statement + is expected to be nil + with an else statement + is expected to be sym type .new - with a symbol node - is expected to be a kind of RuboCop::AST::SymbolNode + is expected to be a kind of RuboCop::AST::CaseNode + #when_branches + is expected to eq 3 + is expected to all be when type + #branches + when there is no else keyword + returns only then when bodies + when compared to an IfNode + returns the same + when there is an else + returns all the bodies + with an empty else + returns all the bodies + #keyword + is expected to eq "case" -RuboCop::AST::ResbodyNode +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::ForNode + #variable + is expected to be lvasgn type #body is expected to be sym type .new - is expected to be a kind of RuboCop::AST::ResbodyNode - #exceptions - with multiple exceptions - is expected to all be const type - is expected to eq 2 - with a single exception - is expected to all be const type - is expected to eq 1 - without exception - is expected to eq 0 - #exception_variable - for an explicit rescue - is expected to eq "ex" - for an implicit rescue - is expected to eq "ex" - when an exception variable is not given - is expected to be nil - #branch_index - is expected to eq 0 - is expected to eq 1 - is expected to eq 2 + is expected to be a kind of RuboCop::AST::ForNode + #post_condition_loop? + is expected not to be post condition loop + #do? + without a do keyword + is expected not to be do + with a do keyword + is expected to be do + #collection + is expected to be sym type + #void_context? + without a do keyword + is expected to be void context + with a do keyword + is expected to be void context + #keyword + is expected to eq "for" + #loop_keyword? + is expected to be loop keyword -RuboCop::AST::AsgnNode - #name - with a `ivasgn` node - is expected to eq :@var - with a `gvasgn` node - is expected to eq :$var - with a `cvasgn` node - is expected to eq :@@var - with a `lvasgn` node - is expected to eq :var +RuboCop::AST::ForwardArgsNode + when using Ruby 2.7 or newer + #to_a + is expected to contain exactly (be forward arg type) + +RuboCop::AST::StrNode + #heredoc? + with a heredoc + is expected to be heredoc + with a normal string + is expected not to be heredoc + with a string with interpolation + is expected not to be heredoc .new - with a `cvasgn` 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 - with a `lvasgn` 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 - #expression - with a `cvasgn` node - is expected to eq s(:send, nil, :value) - with a `lvasgn` 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 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 + 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 heredoc + is expected not to be character literal + with a normal string literal + is expected not to be character literal + +RuboCop::AST::SymbolNode + .new + with a symbol node + is expected to be a kind of RuboCop::AST::SymbolNode + #value + is expected to eq :foo RuboCop::AST::AndAsgnNode #expression is expected to eq s(:send, nil, :value) .new is expected to be a kind of RuboCop::AST::AndAsgnNode + #assignment_node + is expected to be a kind of RuboCop::AST::AsgnNode #operator is expected to eq :"&&" #name is expected to eq :var - #assignment_node - is expected to be a kind of RuboCop::AST::AsgnNode -RuboCop::AST::Token - #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 - type predicates - with braces & parens - #left_brace? - returns false for non left hash brace tokens - returns true for left hash brace tokens - #left_parens? - returns true for left parens tokens - returns false for non left parens tokens - #right_curly_brace? - returns false for non right brace tokens - returns true for all right brace 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 - #new_line? - returns true for new line tokens - returns false for non new line tokens - #comment? - returns false for non comment tokens - returns true for comment tokens - #equals_sign? - returns false for non equals sign tokens - returns true for equals sign tokens - #dot? - returns false for non dot tokens - returns true for dot tokens - #rescue_modifier? - returns false for non rescue modifier tokens - returns true for rescue modifier tokens - #comma? - returns true for comma tokens - returns false for non comma tokens - #left_ref_bracket? - returns true for left_ref_bracket tokens - returns false for non left_ref_bracket tokens - #left_bracket? - returns false for non left_bracket tokens - returns true for all left_bracket tokens - #left_array_bracket? - returns true for left_array_bracket tokens - returns false for non left_array_bracket tokens - #end? - returns true for end tokens - returns false for non end tokens - #right_bracket? - returns true for all right_bracket tokens - returns false for non right_bracket tokens - #regexp_dots? - returns false for non comma tokens - returns true for regexp tokens - #left_brace? - returns true for right_bracket tokens - returns false for non right_bracket tokens - #semicolon? - returns false for non semicolon tokens - returns true for semicolon tokens - .from_parser_token - sets parser token's type to rubocop token's type - sets parser token's text to rubocop token's text - sets parser token's range to rubocop token's pos - returns a #to_s useful for debugging - #line - returns line of token - #to_s - returns string of token data - #space_before - returns nil when there is not a space before token - returns nil when it is on the first line - returns truthy MatchData when there is a space before token - #column - returns index of first char in token range on that line - #begin_pos - returns index of first char in token range of entire source +RuboCop::AST::ArgNode + #name + with a keyword argument + is expected to eq :x + with a splatted argument + is expected to eq :x + with a double splatted argument + is expected to eq :x + with a regular argument + is expected to eq :x + with an optional keyword argument + is expected to eq :x + with a block + is expected to eq :x + with a block argument + is expected to eq :x + with an optional argument + is expected to eq :x + with a nameless splatted argument + is expected to be nil + with a nameless double splatted argument + is expected to be nil + with argument forwarding + with Ruby >= 3.0 + is expected to be nil + with Ruby >= 2.7 + is expected to be nil + with a shadow argument + is expected to eq :x + #default_value + with a shadow argument + is expected to be nil + with a block argument + is expected to be nil + with a regular argument + is expected to be nil + with a splatted argument + is expected to be nil + with an optional 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 + with a block + is expected to be nil + with an optional keyword argument + is expected to eq s(:int, 42) + with a double splatted argument + is expected to be nil + #default? + with a block + is expected to equal false + with an optional keyword argument + is expected to equal true + with a regular 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 a splatted argument + 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 an optional argument + is expected to equal true + with a double splatted argument + is expected to equal false + .new + with an optional keyword argument + is expected to be a kind of RuboCop::AST::ArgNode + with a keyword argument + 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 a block + 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 shadow argument + 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 an optional 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 a method definition + is expected to be a kind of RuboCop::AST::ArgNode + +RuboCop::AST::IntNode + #sign? + explicit negative int + is expected to be sign + explicit positive int + is expected to be sign + .new + is expected to be a kind of RuboCop::AST::IntNode + #value + is expected to eq 10 + +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::RescueNode + #branches + when there is an else + returns all the bodies + with an empty else + returns all the bodies + when there is no else keyword + returns only then rescue bodies + .new + is expected to be a kind of 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 + without an else statement + is expected to be nil + with an else statement + is expected to be send type + #else? + without an else statement + is expected not to be else + with an else statement + is expected to be else RuboCop::AST::ProcessedSource - #preceding_line - returns source of line before token + #ast + is the root node of AST #tokens_within accepts Node as an argument returns tokens for node when heredoc as argument is present - returns tokens for node before heredoc returns tokens for node after heredoc returns tokens for heredoc node - #lines - is an array - contains lines as string without linefeed - has same number of elements as line count - #start_with? - with present source - returns true when passed string that starts source - returns false when passed string that does not start source - with blank source - returns false - #file_path - returns file path - #blank? - with source of no content - returns true - with source with content - returns false + returns tokens for node before heredoc + #path + is the path passed to .new + #preceding_line + returns source of line before token #[] when start index and length are passed returns the array of lines - when an index is passed - returns the line when a range is passed returns the array of lines - #tokens - has an array of tokens - #buffer - is a source buffer + when an index is passed + returns the line + token enumerables + #find_token + yields correct token + yields nil when there is no match + #each_token + yields all tokens + #following_line + returns source of line after token + #lines + contains lines as string without linefeed + is an array + has same number of elements as line count + #file_path + returns file path .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 with heavily commented source - #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 - #find_comment - yields nil when there is no match - yields correct comment - #each_comment_in_lines - yields the 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 comment line - is expected to equal true provided a multiline source_range with at least one 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 source_range on line with comment + is expected to equal true + #each_comment + yields all comments #comment_at_line returns the comment at the given line number returns nil if line has no comment - #each_comment - yields all comments - token enumerables - #each_token - yields all tokens - #find_token + #find_comment + yields correct comment yields nil when there is no match - yields correct token - valid_syntax? - when the source is valid but has some warning diagnostics - returns true + #comments_before_line + returns comments on or before given line + #each_comment_in_lines + yields the comments + #last_token_of + accepts Node as an argument + returns last token for node + #comments + is an array of comments + when the source is invalid + returns [] + #parser_error 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 + when the source was properly parsed + is nil + valid_syntax? + when the source is invalid returns false - when the source itself is valid encoding but includes strange encoding literals that are accepted by MRI - returns true - when the source is completely valid - returns true when a line starts with an integer literal tokenizes the source correctly - when the source is invalid + when the source is completely valid + returns true + when the source itself is valid encoding but includes strange encoding literals that are accepted by MRI + returns true + when the source could not be parsed due to encoding error returns false - #path - is the path passed to .new + when the source is valid but has some warning diagnostics + returns true #first_token_of returns first token for node accepts Node as an argument - #following_line - returns source of line after token - #ast - is the root node of AST - #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 - #last_token_of - accepts Node as an argument - returns last token for node - #comments - is an array of comments - when the source is invalid - returns [] + #tokens + has an array of tokens + #start_with? + with present source + returns true when passed string that starts source + returns false when passed string that does not start source + with blank source + returns false + #blank? + with source with content + returns false + with source of no content + returns true + #buffer + is a source buffer + +Changelog + parses correctly + merges correctly + Changelog::Entry + generates correct content + +RuboCop::AST::ArgsNode + #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)] + #empty_and_without_delimiters? + with delimiters + with a block + is expected to equal false + 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 + with arguments + with a lambda literal + is expected to equal false + with a method definition + is expected to equal false + .new + 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 + with a block + is expected to be a kind of RuboCop::AST::ArgsNode + +RuboCop::AST::Ext::Range + #line_span + returns the range of lines a range occupies + accepts an `exclude_end` keyword argument + +Set#=== + tests for inclusion + +RuboCop::AST::NodePattern::Parser + sequences + parses function calls + generates specialized nodes + expands ... in sequence head deep inside unions + parses unions of literals as a set + parses simple sequences properly + parses capture vs repetition with correct priority + +RuboCop::AST::WhenNode + .new + is expected to be a kind of RuboCop::AST::WhenNode + #conditions + with a single condition + is expected to all be literal + is expected to eq 1 + with a multiple conditions + is expected to all be literal + is expected to eq 3 + #body + without a then keyword + is expected to be array type + with a then keyword + is expected to be sym type + #branch_index + is expected to eq 2 + is expected to eq 1 + is expected to eq 0 + #then? + without a then keyword + is expected not to be then + with a then keyword + is expected 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 RuboCop::AST::OrNode - #semantic_operator? + .new with a logical or node - is expected not to be semantic operator + is expected to be a kind of RuboCop::AST::OrNode with a semantic or node - is expected to be semantic operator + is expected to be a kind of RuboCop::AST::OrNode + #inverse_operator + with a logical or node + is expected to eq "&&" + with a semantic or node + is expected to eq "and" + #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 logical or node is expected to be int type with a semantic or node is expected to be int type + #operator + with a logical or node + is expected to eq "||" + with a semantic or node + is expected to eq "or" #alternate_operator with a semantic or node is expected to eq "||" with a logical or node is expected to eq "or" - #operator + #semantic_operator? with a semantic or node - is expected to eq "or" - with a logical or node - is expected to eq "||" - #lhs + is expected to be semantic operator with a logical or node - is expected to be sym type - with a semantic or node - is expected to be sym type + is expected not to be semantic operator #logical_operator? with a logical or node is expected to be logical operator with a semantic or node is expected not to be logical operator - .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 - #inverse_operator - with a logical or node - is expected to eq "&&" - with a semantic or node - is expected to eq "and" - -RuboCop::AST::NodePattern::Parser - sequences - parses simple sequences properly - expands ... in sequence head deep inside unions - generates specialized nodes - parses capture vs repetition with correct priority - parses function calls - parses unions of literals as a set - -RuboCop::AST::HashNode - #each_value - when passed a block - yields all the pairs - when not passed a block - is expected to be a kind of Enumerator - #each_key - when passed a block - yields all the pairs - when not passed a block - is expected to be a kind of Enumerator - #values - with a hash with string keys - is expected to eq 2 - is expected to all be send type - with a hash with literal values - is expected to eq 3 - is expected to all be literal - with an empty hash - is expected to be empty - #braces? - as an argument with braces - is expected to be braces - with braces - is expected to be braces - as an argument with no braces - is expected not to be braces - #empty? - with a hash containing a keyword splat - is expected not to be empty - with an empty hash - is expected to be empty - with a hash containing pairs - is expected not to be empty - #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 - #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 - with all pairs on the same line - is expected to be pairs on same line - .new - is expected to be a kind of RuboCop::AST::HashNode - #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 - #each_pair - when passed a block - yields all the pairs - when not passed a block - is expected to be a kind of Enumerator - #pairs - with a hash of literals - is expected to eq 3 - is expected to all be pair type - 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 -RuboCop::AST::SendNode - #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_operator_method? - with a nonmutating unary operator method - is expected to be nonmutating operator method - with a regular method - is expected not to be 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 - #lambda? - with a non-lambda method - is expected not to be lambda - with a method named lambda in a class - 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 - #binary_operation?? - with a binary operation - is expected to be binary operation - with a unary operation - is expected not 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 - #last_argument +RuboCop::AST::SuperNode + #first_argument with multiple mixed arguments - is expected to be splat type + is expected to be sym type with multiple literal arguments is expected to be sym type with a single splat argument @@ -1992,2861 +2085,3457 @@ is expected to be sym type with no arguments is expected to be nil - #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 - #macro? - with a receiver - when parent is a class - is expected not to be macro - when parent is a module - is expected not to be macro - without a receiver - when parent is a class constructor - is expected to be macro - when parent is a keyword begin inside of an class - is expected to be macro - when parent is a method definition - is expected not to be macro - without a parent - is expected to be macro - when the condition of an if - is expected not to be macro - when parent is a class - is expected to be macro - when parent is a begin without a parent - is expected to be macro - when parent is a struct constructor - 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 - when parent is a singleton class - is expected to be macro - when in the global scope - is expected 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 module - is expected to be macro - when parent is a block in a macro scope - is expected to be macro - #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 + .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 + #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 :super + when argument is a string + is expected to be method "super" + #receiver + is expected to be nil + #dot? + is expected not to be dot + #block_node with no block - is expected not to be block literal + is expected to be nil + with a block argument + is expected to be nil with a block literal - is expected to be block literal - #access_modifier? - when node is a non-bare `module_function` - is expected to be access modifier - when node is a bare `module_function` - is expected to be access modifier - when node is not an access modifier - is expected not to be bare access modifier - #splat_argument? - with regular arguments - is expected not to be splat argument + is expected to be block type + #double_colon? + is expected not to be double colon + #block_argument? with no arguments - is expected not to be splat argument - with a splat argument - is expected to be splat argument + is expected not to be block argument + with a block argument + is expected to be block argument with mixed arguments - is expected to be splat argument - #def_modifier - with a block containing a method definition - is expected to be nil - with a prefixed def modifier - is expected to eq :bar - with call with no argument + is expected to be block argument + with regular arguments + is expected not to be block argument + #last_argument + with multiple mixed arguments + is expected to be splat type + with a single splat argument + 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 several prefixed def modifiers - is expected to eq :qux - #loop_keyword? - is expected not to be loop keyword - #def_modifier? - with a block containing a method definition - is expected not to be def modifier - with a prefixed def modifier - is expected to be def modifier - with several prefixed def modifiers - is expected to be def modifier - #arguments with a single literal argument + is expected to be sym type + #macro? + is expected not to be macro + #arguments + with a single splat 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 multiple literal arguments + is expected to eq 2 with no arguments is expected to be empty - with a single splat argument + with a single literal argument is expected to eq 1 + #predicate_method? + is expected not to be predicate method + #setter_method? + is expected not to be setter method + #comparison_method? + is expected not to be comparison method + #implicit_call? + is expected not to be implicit call #operator_method? - with a unary 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 binary operator method - is expected to be operator method - #attribute_accessor? - with an accessor - returns the accessor method and Array] - with a call without arguments - is expected to be nil + is expected not to be operator method + #bang_method? + is expected not to be bang method + #block_literal? + with a block literal + is expected to be block literal + with no block + is expected not to be block literal + with a block argument + is expected not to be block literal + #camel_case_method? + is expected not to be camel case method + #splat_argument? + with regular arguments + is expected not to be splat argument + with no arguments + is expected not to be splat argument + with mixed arguments + is expected to be splat argument + with a splat argument + is expected to be splat argument #parenthesized? with no arguments - when using parentheses - is expected to be parenthesized 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 - #prefix_bang? - with a non-negated method - is expected not to be prefix bang - with keyword `not` - is expected not to be prefix bang - with a bang method - is expected to be prefix bang - #enumerable_method? - with a regular method - is expected not to be enumerable method - with an enumerable method - is expected to be enumerable method - #nonmutating_unary_operator_method? - with a regular method - is expected not to be nonmutating unary operator method - with a nonmutating unary operator method - is expected to be nonmutating unary operator method - #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 a regular method - is expected not to be assignment method - with an assignment method - is expected to be assignment method - #receiver - with no receiver - is expected to be nil - with a variable receiver - is expected to be send type - with a literal receiver - is expected to be str type - #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_string_method? - with a mutating String method - is expected not to be nonmutating string method - with a regular method - is expected not to be nonmutating string method - with a nonmutating String method - is expected to be nonmutating string method + #const_receiver? + is expected not to be const receiver #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 - #predicate_method? - with a bang method - is expected not to be predicate method - with a regular method - is expected not to be predicate method - with a predicate method - is expected to be predicate method - #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 - #dot? - with a unary method - is expected not to be dot - with a dot - is expected to be dot - with a double colon - is expected not to be dot - without a dot - is expected not to be dot - #nonmutating_binary_operator_method? - with a mutating binary operator method - is expected not to be 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 - #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 - #implicit_call? - with an implicit call method - is expected to be implicit call - with a regular method - is expected not to be implicit call - with an explicit call method - is expected not to be implicit call - #comparison_method? - with a regular method - is expected not to be comparison method - with a comparison method - is expected to be comparison method - with a negation method - is expected not to be comparison method + is expected not to be self receiver #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" - #setter_method? - with an operator method - is expected not to be setter method - with a regular method - is expected not to be setter method - with a setter method - is expected to be setter method - with an indexed setter method - is expected to be setter method + is expected to be command "super" + when argument is a symbol + is expected to be command :super #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 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 - #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 - #negation_method? - with suffix `not` - is expected not to be negation method - with prefix `not` - is expected 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 - #post_condition_loop? - is expected not to be post condition loop - #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 - 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 - #block_argument? - with mixed arguments - is expected to be 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 - #block_node - with a block literal - is expected to be block type - with no block - is expected to be nil - with Ruby >= 2.7 - with a numblock literal - is expected to be numblock type - with a block argument - is expected to be nil - #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 #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 - #first_argument - with no arguments - is expected to be nil - 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 - #nonmutating_hash_method? - with a nonmutating Hash method - is expected to be 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 - #lambda_literal? - with `a.() {}` style method - is expected not to be lambda - with a stabby lambda - is expected to be lambda literal - with a non-lambda method - is expected not to be lambda - with a lambda method - is expected not to be lambda literal - .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 - #double_colon? - with a dot - is expected not to be double colon - without a dot - is expected not to be double colon - with a double colon - is expected to be double colon - with a unary method - is expected not to be double colon - #arithmetic_operation? - with a binary arithmetic operation - is expected to be arithmetic operation - with a unary numeric operation - is expected not to be arithmetic operation - with a regular method call - is expected not to be arithmetic operation - #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 - with a binary operation - is expected not to be unary operation + is expected to eq :super + #assignment_method? + is expected not to be assignment method -RuboCop::AST::WhenNode - #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 - #branch_index - is expected to eq 1 - is expected to eq 0 - is expected to eq 2 - #conditions - with a single condition - is expected to eq 1 - is expected to all be literal - with a multiple conditions - is expected to eq 3 - is expected to all be literal - #each_condition - when not passed a block - is expected to be a kind of Enumerator - when passed a block - yields all the conditions - #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 + .new + with arguments + is expected to be a kind of RuboCop::AST::BreakNode + without arguments + is expected to be a kind of RuboCop::AST::BreakNode + #arguments + with a single argument and braces + is expected to eq 1 + with no arguments + is expected to be empty + 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 and braces + is expected to be empty -RuboCop::AST::CasgnNode +RuboCop::AST::AsgnNode #name - is expected to eq :VAR + with a `ivasgn` node + is expected to eq :@var + with a `cvasgn` node + is expected to eq :@@var + with a `gvasgn` node + is expected to eq :$var + with a `lvasgn` node + is expected to eq :var .new - with a `casgn` node - is expected to be a kind of RuboCop::AST::CasgnNode + 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 #expression - is expected to eq s(:send, nil, :value) - #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 `gvasgn` node + is expected to eq s(:send, nil, :value) + with a `ivasgn` node + is expected to eq s(:send, nil, :value) + with a `cvasgn` node + is expected to eq s(:send, nil, :value) + with a `lvasgn` node + is expected to eq s(:send, nil, :value) -RuboCop::AST::ClassNode +RuboCop::AST::Procarg0Node + #name + is expected to eq :x .new - is expected to be a kind of RuboCop::AST::ClassNode - #identifier - is expected to be const type - #body - with a multi-expression body - is expected to be begin type - with a single expression body - is expected to be send 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 + with a block + is expected to be a kind of RuboCop::AST::ArgNode -RuboCop::AST::OrAsgnNode - #expression - is expected to eq s(:send, nil, :value) - #assignment_node - is expected to be a kind of RuboCop::AST::AsgnNode - .new - is expected to be a kind of RuboCop::AST::OrAsgnNode - #operator - is expected to eq :"||" - #name - is expected to eq :var +RuboCop::AST::ConstNode + #absolute? + is expected to be absolute + with a constant not starting with :: + is expected not to be absolute + with a non-namespaced constant + is expected not to be absolute + #each_path + yields all parts of the namespace + #short_name + is expected to eq :BAZ + #namespace + is expected to eq "::Foo::Bar" + #relative? + with a non-namespaced constant + is expected to be relative + #module_name? + is expected not to be module name + with a constant with a lowercase letter + is expected to be module name RuboCop::AST::IfNode - #else_branch + #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 int type + is expected to be sym type + #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 to be int type + is expected not to be unless + #elsif_conditional? + with one elsif conditional + 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 nested conditionals in else clause + is expected not to be elsif conditional + with multiple elsif conditionals + is expected to be elsif conditional + .new + with a regular if statement + is expected to be a kind of RuboCop::AST::IfNode + with a modifier 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 + #if? + with an unless statement + is expected not to be if + with a ternary operator + is expected not to be if with an if statement - is expected to be int type + is expected to be if #nested_conditional? - with nested conditionals in if clause + 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 + when nested in the falsey branch + is expected to be nested conditional + with nested conditionals in if clause + is expected to be nested conditional with no nested conditionals is expected not 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 + #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 + #elsif? + with an if statement comtaining an elsif + is expected not to be elsif + without an elsif statement + is expected not to be elsif + with an elsif statement + is expected to be elsif + #branches + with a ternary operator + is expected to eq 2 + is expected to all be literal + with an unless statement + is expected to eq 1 + is expected to all be literal + with an if statement + is expected to eq 1 + is expected to all be literal + with an elsif statement + is expected to eq 3 + is expected to all be literal + 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 + #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 non-modifier unless statement - is expected not 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 if statement + is expected not to be modifier form with a ternary operator is expected not to be modifier form with a modifier if statement is expected to be modifier form - #keyword + with a non-modifier unless statement + is expected not to be modifier form + #inverse_keyword? with an unless statement - is expected to eq "unless" + is expected to eq "if" with a ternary operator is expected to eq "" with an if statement - is expected to eq "if" - #inverse_keyword? - with an if statement is expected to eq "unless" + #keyword with an unless statement - is expected to eq "if" + is expected to eq "unless" with a ternary operator is expected to eq "" + with an if statement + is expected to eq "if" #else? with an elsif statement is expected to be else without an else statement is expected not to be elsif + +RuboCop::AST::ClassNode + #body + with an empty body + is expected to be nil + with a single expression body + is expected to be send type + with a multi-expression body + is expected to be begin type .new - with a ternary operator - 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 modifier statement - is expected to be a kind of RuboCop::AST::IfNode - #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 if statement - is expected not to be ternary - with a ternary operator - is expected to be ternary - with an unless statement - is expected not to be ternary - #each_branch - when passed a block - yields all the branches - when not passed a block - is expected to be a kind of Enumerator - #branches - with an else statement - is expected to all be literal + is expected to be a kind of 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 + +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 string + is expected not to be method "foo" + when argument is a symbol + is expected not to be method :foo + #arguments? + with multiple regular arguments + is expected to be arguments + with a single regular argument + is expected to be arguments + with a single rest argument + is expected to be arguments + with no arguments + is expected not to be arguments + with a single keyword argument + is expected to be arguments + with multiple mixed arguments + is expected to be arguments + .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 + #block_argument? + with a block argument + is expected to be block argument + with mixed arguments + is expected to be block argument + with regular arguments + is expected not to be block argument + with no arguments + is expected not to be block argument + #void_context? + with a comparison method + is expected not to be void context + with an initializer method + is expected to be void context + with a regular assignment method + is expected to be void context + with a bracket assignment method + is expected to be void context + with a regular method + is expected not to be void context + #rest_argument? + with a rest argument + is expected to be rest argument + with mixed arguments + is expected to be rest argument + with regular arguments + is expected not to be rest argument + with no arguments + is expected not to be rest argument + when using Ruby 2.7 or newer + #argument_forwarding? + is expected to be argument forwarding + #arguments + with a single rest argument + is expected to eq 1 + with a single regular argument + is expected to eq 1 + with multiple regular arguments is expected to eq 2 - with an elsif statement - is expected to eq 3 - is expected to all be literal - with an if statement + with multiple mixed arguments + is expected to eq 2 + with no arguments + is expected to be empty + with argument forwarding is expected to eq 1 - is expected to all be literal - with a ternary operator - is expected to all be literal + #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 + #receiver + with a singleton method definition + is expected to be const type + with an instance method definition + is expected to be nil + with a class method definition + is expected to be self type + #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 + #comparison_method? + with a regular method + is expected not to be comparison method + with a comparison method + is expected to be comparison method + #endless? + with standard method definition + is expected not to be endless + with endless method definition + is expected to be endless + #last_argument + with multiple regular arguments + is expected to be arg type + with no arguments + is expected to be nil + with multiple mixed arguments + is expected to be restarg 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 + #self_receiver? + with a class method definition + is expected to be 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 + #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 + #method_name + with a unary method + is expected to eq :-@ + with a plain method + is expected to eq :foo + with a setter method + is expected to eq :foo= + with an operator method + is expected to eq :== + #predicate_method? + with a predicate method + is expected to be predicate method + with a bang method + is expected not to be predicate method + with a regular method + is expected not to be predicate method + #first_argument + with a single keyword argument + is expected to be kwoptarg type + with a single regular argument + is expected to be arg type + with a single rest argument + is expected to be restarg type + with multiple mixed arguments + is expected to be arg type + with no arguments + is expected to be nil + with multiple regular arguments + is expected to be arg type + #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 + with a binary operator method + is expected to be operator method + #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 + with a bracket assignment method + is expected to be assignment method + #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 + +RuboCop::AST::ResbodyNode + #exception_variable + when an exception variable is not given + is expected to be nil + for an implicit rescue + is expected to eq "ex" + for an explicit rescue + is expected to eq "ex" + #body + is expected to be sym type + #exceptions + without exception + is expected to eq 0 + with multiple exceptions is expected to eq 2 - with an unless statement + is expected to all be const type + with a single exception + is expected to all be const type is expected to eq 1 - is expected to all be literal - #if_branch - with an unless statement - is expected to be sym type - with an if statement - is expected to be sym type - with a ternary operator - is expected to be sym type - #unless? - with an unless statement - is expected to be unless - with a ternary operator - is expected not to be unless - with an if statement - is expected not to be unless - #if? - with an unless statement - is expected not to be if - with a ternary operator - is expected not to be if - with an if statement - is expected to be if - #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 multiple elsif conditionals - is expected to be elsif conditional - with one elsif conditional - is expected to be elsif conditional - with nested conditionals in else clause - is expected not to be elsif conditional + .new + is expected to be a kind of RuboCop::AST::ResbodyNode + #branch_index + is expected to eq 2 + is expected to eq 1 + is expected to eq 0 + +RuboCop::AST::BlockNode + #delimiters + when enclosed in braces + is expected to eq ["{", "}"] + when enclosed in do-end keywords + is expected to eq ["do", "end"] + #arguments + with no arguments + is expected to be empty + >= Ruby 2.7 + using numbered parameters + is expected to be empty + with destructured 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 a single literal argument + is expected to eq 1 + #argument_list + all argument types + is expected to eq [:a, :b, :c, :d, :e, :f, :g, :h, :i] + >= Ruby 2.7 + using numbered parameters + with sequential params + is expected to eq [:_1, :_2] + with skipped params + is expected to eq [:_1, :_2, :_3, :_4, :_5, :_6, :_7] + with no arguments + is expected to be empty + #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 + #braces? + when enclosed in braces + is expected to be braces + when enclosed in do-end keywords + is expected not to be braces + #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 + when block belongs to a method lambda + is expected to be lambda + #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 + #void_context? + when block method is tap + is expected to be 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 + #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 + #arguments? + with destructuring arguments + is expected to be arguments + with a single argument + is expected 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 multiple mixed arguments + is expected to be arguments + with no arguments + is expected not to be arguments + #receiver + with safe navigation operator call + is expected to eq "foo" + with dot operator call + is expected to eq "foo" + #opening_delimiter + when enclosed in do-end keywords + is expected to eq "do" + when enclosed in braces + is expected to eq "{" + #keywords? + when enclosed in braces + is expected not to be keywords + when enclosed in do-end keywords + is expected to be keywords + +RuboCop::AST::EnsureNode + .new + is expected to be a kind of RuboCop::AST::EnsureNode + #body + is expected to be sym type + +RuboCop::AST::Token + #line + returns line of token + type predicates + #regexp_dots? + returns true for regexp tokens + returns false for non comma tokens + #left_bracket? + returns true for all left_bracket tokens + returns false for non left_bracket tokens + #right_bracket? + returns false for non right_bracket tokens + returns true for all right_bracket tokens + #left_ref_bracket? + returns false for non left_ref_bracket tokens + returns true for left_ref_bracket tokens + #semicolon? + returns false for non semicolon tokens + returns true for semicolon tokens + #new_line? + returns false for non new line tokens + returns true for new line tokens + #comma? + returns false for non comma tokens + returns true for comma tokens + #end? + returns true for end tokens + returns false for non end tokens + #rescue_modifier? + returns false for non rescue modifier tokens + returns true for rescue modifier tokens + with braces & parens + #left_brace? + returns true for left hash brace tokens + returns false for non left hash brace tokens + #left_parens? + returns false for non left parens tokens + returns true for left parens tokens + #right_curly_brace? + returns true for all right brace tokens + returns false for non right brace tokens + #right_parens? + returns true for right parens tokens + returns false for non right parens tokens + #left_curly_brace? + returns false for non left block brace tokens + returns true for left block brace tokens + #comment? + returns true for comment tokens + returns false for non comment tokens + #left_brace? + returns true for right_bracket tokens + returns false for non right_bracket tokens + #left_array_bracket? + returns true for left_array_bracket tokens + returns false for non left_array_bracket tokens + #equals_sign? + returns false for non equals sign tokens + returns true for equals sign tokens + #dot? + returns true for dot tokens + returns false for non dot tokens + #space_after + returns truthy MatchData when there is a space after token + returns nil when there is not a space after token + #to_s + returns string of token data + #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 + #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 + .from_parser_token + sets parser token's type to rubocop token's type + sets parser token's range to rubocop token's pos + sets parser token's text to rubocop token's text + returns a #to_s useful for debugging + #column + returns index of first char in token range on that line + +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 argument + is expected to eq 1 + 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 RuboCop::AST::Traversal knows all current node types - for example { 'foo': 2, 'bar': {}} - traverses all nodes - for example class Foo < a:b; end - traverses all nodes - for example Bar::Foo = 10 + for example %s{a\ +b} traverses all nodes - for example a&.b + for example meth 1 do end.fun bar do end traverses all nodes - for example foo != 1 + for example p <<~E + x + +y +E traverses all nodes - for example %I[#@@1] + for example { 1 => 2 } traverses all nodes - for example %Q{#@@1} + for example meth 1 do end.fun(bar) {} traverses all nodes - for example foo[1, 2] = 3 + for example def self.foo; end traverses all nodes - for example m1 :k => m2 do; m3() do end; end + for example f{ |*s, &b| } traverses all nodes - for example %I[#@1] + for example def f ((a, a1)); end traverses all nodes - for example f{ |a, *, &b| } + for example m a + b do end traverses all nodes - for example foo += meth rescue bar + for example case foo; in "#{ %q{a} }": 1 then true; end traverses all nodes for example p <<~E - x - - y + x + \ y E traverses all nodes - for example %r{a\ -b} + for example /source/im traverses all nodes - for example case foo; - in {Foo: 42 - } - false - ; end + for example return() traverses all nodes - for example [/()\1/, ?#] + for example def String::foo; end traverses all nodes - for example /#@@1/ + for example m ->(a = ->{_1}) {a} traverses all nodes - for example meth 1 do end.fun bar do end + for example if (bar; a, b = foo); end traverses all nodes - for example def (foo).foo; end + for example foo::fun traverses all nodes - for example def foo() a:b end + for example if foo; bar; elsif baz; 1; else 2; end traverses all nodes - for example f{ |a| } + for example foo::m += raise(bar) rescue nil traverses all nodes - for example meth 1 do end::fun(bar) + for example p <<~E +E traverses all nodes - for example meth (-1.3).abs + for example case foo; in A(x:) then true; end traverses all nodes - for example m def x(); end; 1.tap do end + for example bar def foo; self.each do end end traverses all nodes - for example foo and bar + for example foo <= 1 traverses all nodes - for example /(?bar)/ =~ 'bar'; match + for example case foo; in [x, y] then true; end traverses all nodes - for example f{ |a, *| } + for example def f *r, &b; end traverses all nodes - for example ...100 + for example for a, b in foo; p a, b; end traverses all nodes - for example m { |(foo, bar)| } + for example Bar::Foo = 10 traverses all nodes - for example meth[] {} + for example /#@1/ traverses all nodes - for example def f (foo: 1, bar: 2, **baz, &b); end + for example -2.0 ** 10 traverses all nodes - for example %W[foo #{bar}foo#@baz] + for example break traverses all nodes - for example until foo do meth end + for example case foo; in x, y, then nil; end traverses all nodes - for example ->(a) { } + when a class defines `on_block_pass` + calls it for all block-pass arguments + for example def f &b; end traverses all nodes - for example %q{a\ -b} + for example p :foo, {a: proc do end, b: proc do end} traverses all nodes - for example -foo + for example def f a, o=1, *r, p, &b; end traverses all nodes - for example :'#@1' + for example f{ |a, c| } traverses all nodes - for example case foo; in [x, y, *] then true; end + for example case foo; in ...2 then true; end traverses all nodes - for example <<-'HERE' -#@@1 -HERE + for example p :foo, {:a => proc do end, b: proc do end} traverses all nodes - for example foo && bar + for example case foo; in "a": 1 then true; end traverses all nodes - for example _1 + for example f{ |a, o=1, p, &b| } traverses all nodes - for example while class Foo; tap do end; end; break; end + for example a b(c d), :e do end traverses all nodes - for example ?a + for example -> a: { } traverses all nodes - for example return fun foo do end + for example def x; self::A ||= 1; end traverses all nodes - for example !(foo..bar) + for example 1.. traverses all nodes - for example f{ |a, &b| } + for example fun () {} traverses all nodes - for example def f a, o=1, p, &b; end + for example /foo#{bar}baz/ traverses all nodes - for example foo.A += m foo + for example retry traverses all nodes - for example p <<~E - x - y -E + for example { foo: 2 } traverses all nodes - for example case 1; in 2; 3; else; 4; end + for example *b = bar traverses all nodes - for example case foo; - in {a: - 2} - false - ; end + for example fun(foo, :foo => 1) traverses all nodes - for example def f(*foo); end + for example {a: if true then 42 end} traverses all nodes - for example def f *r, &b; end + for example a, *, c = bar traverses all nodes - for example for a in foo; p a; end + for example A += 1 traverses all nodes - for example case foo; when 'bar', 'baz'; bar; end + for example m [], 1 do end traverses all nodes - for example a b(c(d)), :e do end + for example foo::Fun() traverses all nodes - for example self::a, foo = foo + for example a b{c d}, 1.0r do end traverses all nodes - for example < 2, :foo => "bar" } traverses all nodes - for example f{ |a, *r, p, &b| } + for example f{ |foo:| } traverses all nodes - for example case foo; in x, *y, z then nil; end + for example def foo raise; raise A::B, ''; end traverses all nodes - for example def foo(...); bar(...); end + for example not(foo) traverses all nodes - for example case foo; in a: 1, b: 2 then true; end + for example __FILE__ traverses all nodes - for example if foo...bar; end + for example <<-`HERE` +#@1 +HERE traverses all nodes - for example B::A += 1 + for example f{ |a, *, &b| } traverses all nodes - for example *, c, d = bar + for example meth[] {} traverses all nodes - for example f { || a:b } + for example if foo...bar; end traverses all nodes - for example foo += m foo + for example if foo; bar; else baz; end traverses all nodes - for example if foo; bar; end + for example begin; meth; rescue => ex; bar; end traverses all nodes - for example foo = raise bar rescue nil + for example f{ |o=1, *r, p, &b| } traverses all nodes - for example true + for example a, (b, c) = foo traverses all nodes - for example !foo + for example false ? raise do end : tap do end traverses all nodes - for example case foo; in x if true; nil; end + for example def END; end traverses all nodes - for example 1...2 + for example p <<~E + x + y +E traverses all nodes - for example /#@1/ + for example f(a ? "a":1) traverses all nodes - for example for a, b in foo; p a, b; end + for example !m foo traverses all nodes - for example def self.m; _1; end + for example begin; meth; rescue; foo; end traverses all nodes - for example fun (1) + for example foo += meth rescue bar traverses all nodes - for example foo <= 1 + for example case 1; in 2; 3; else; end traverses all nodes - for example while class << self; tap do end; end; break; end + for example begin ensure end traverses all nodes - for example foo[0, 1] &&= 2 + for example class Foo; end traverses all nodes - for example :'#@@1' + for example 42i traverses all nodes - for example foo =~ 1 + for example f{ |foo: 1, bar: 2, **baz, &b| } traverses all nodes - for example fun(1) { } + for example module Bar::Foo; end traverses all nodes - for example fun(foo, *bar, &baz) + for example p ->() do a() do end end traverses all nodes - for example _2 = 1 + for example 42.1r traverses all nodes - for example a = b = raise :x + for example foo.A = 1 traverses all nodes - for example foo.fun + for example case 1; in 2; 3; else; 4; end traverses all nodes - for example case foo; in ..2 then true; end + for example case foo; in 1...2 then true; end traverses all nodes - for example a @b do |c|;end + for example %{a\ +b} traverses all nodes - for example -> do end + for example begin; meth; rescue Exception, foo; bar; end traverses all nodes - for example %W[#@@1] + for example case foo; in "#{ 'a' }": 1 then true; end traverses all nodes - for example foo::Fun bar + for example def f o=1, &b; end traverses all nodes - for example foo::a += 1 + for example %w[] traverses all nodes - for example def f a, o=1, *r, &b; end + for example m def x(); end; 1.tap do end traverses all nodes - for example meth rescue bar + for example <<'HERE' +foo +bar +HERE traverses all nodes - for example case foo; in 1..2 then true; end + for example foo || bar traverses all nodes - for example ->(**nil) {} + 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(**nil); end + for example 1..2 traverses all nodes - for example def f ((*r, p)); end + when given an unexpected AST + with too few children + raises debugging error + with too many children + raises debugging error + for example foo::A += m foo traverses all nodes - for example foo[1, 2] + for example case foo; in ^foo then nil; end traverses all nodes - for example break + for example fun(:foo => 1, &baz) traverses all nodes - for example case foo; in [x, *, y] then true; end + for example !(foo...bar) traverses all nodes - for example %i{a\ -b} + for example module ::Foo; end traverses all nodes - for example %x{#@@1} + for example %s{#@@1} traverses all nodes - for example nil + for example meth 1 do end.fun(bar) traverses all nodes - for example a b{c d}, 1 do end + for example %W[foo #{bar}foo#@baz] traverses all nodes - for example /source/im + for example begin; meth; rescue; baz; ensure; bar; end traverses all nodes - for example p ->() do a() do end end + for example m { |foo| } traverses all nodes - for example /foo#{bar}baz/ + for example o = { +a: +1 +} traverses all nodes - for example f{ |o=1, *r, &b| } + for example ~foo traverses all nodes - for example foo == 1 + for example self::a, foo = foo traverses all nodes - for example foo !~ 1 + for example foo::a += m foo traverses all nodes - for example foo::m += raise bar rescue nil + for example case foo; in [x] then nil; end traverses all nodes - for example case foo; in A[x:] then true; end + for example %W() traverses all nodes - for example :'foo' + for example assert dogs traverses all nodes - for example p <<~E - x - \ y -E + for example foo.A += m foo traverses all nodes - for example foo | 1 + for example let (:a) { m do; end } traverses all nodes - for example case foo; in a: then true; end + for example def f a, *r, &b; end traverses all nodes - for example case foo; - in a: {b:}, c: - p c - ; end + for example defined?(foo) traverses all nodes - for example foo += raise bar rescue nil + for example fun(f bar) traverses all nodes - for example a += b += raise :x + for example a b{c(d)}, /x/m do end traverses all nodes - for example foo.fun bar + for example :foo traverses all nodes - for example next(foo) + for example !/wat/ traverses all nodes - for example "a\ -b" + for example def f a, o=1, *r, &b; end traverses all nodes - for example p <<~E - x - -y -E + for example case foo; when 'bar'; bar; else baz; end traverses all nodes - for example @@var = 10 + for example '#@@1' traverses all nodes - for example case foo; in [x, y] then true; end + for example f{ |o=1, p, &b| } traverses all nodes - for example (foo, bar) = 1, 2 + for example class Foo end traverses all nodes - for example case foo; in "#{ 'a' }": 1 then true; end + for example class A; _1; end traverses all nodes - for example case foo; in A(1, 2) then true; end + for example p :foo, {** proc do end, b: proc do end} traverses all nodes - for example [*foo] + for example a # +# +&.foo traverses all nodes - for example case foo; in { a: 1, } then true; end + for example -> (arg={}) {} traverses all nodes - for example foo === 1 + for example foo.m += raise bar rescue nil traverses all nodes - for example a b(c d), "x" do end + for example case foo; in A[1, 2] then true; end traverses all nodes - for example ((b, )) = foo + for example ::Foo = 10 traverses all nodes - for example %I{a\ -b} + for example %w[ #@1 ] traverses all nodes - for example %i[ #@@1 ] + for example not foo traverses all nodes - for example f{ |a, o=1, *r, p, &b| } + for example *, c, d = bar traverses all nodes - for example "#{-> foo {}}" + for example next() traverses all nodes - for example begin; meth; rescue Exception, foo; bar; end + for example -> do _1 + _9 end traverses all nodes - for example 1..2 + for example %q{#@1} traverses all nodes - for example meth 1 do end.fun(bar) + for example desc "foo" do end traverses all nodes - for example alias :foo bar + for example if /wat/; end traverses all nodes - for example f{ |a, *s| } + for example if (a, b = foo); end traverses all nodes - for example foo.a &&= 1 + for example case foo; in a: 1, b: 2 then true; end traverses all nodes - for example %i[ #@1 ] + for example def f a, &b; end traverses all nodes - for example desc "foo" do end + for example case foo; in ->{ 42 } then true; end traverses all nodes - for example * = bar + for example foo, bar = 1, 2 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 begin foo!; bar! end traverses all nodes - for example case foo; in "a": 1 then true; end + for example fun(foo, :foo => 1, &baz) traverses all nodes - for example a b{c d}, /x/ do end + for example (foo, bar) = 1, 2 traverses all nodes - for example foo::fun bar + for example yield(foo) traverses all nodes - for example case foo; when 1, *baz; bar; when *foo; end + for example _1 traverses all nodes - for example foo = bar = m foo + for example def f o=1, *r, &b; end traverses all nodes - for example foo ** 1 + for example yield foo traverses all nodes - for example %w{a\ -b} + for example f{ |a, *s| } traverses all nodes - for example p begin 1.times do 1 end end + for example B::A += 1 traverses all nodes - for example a = 1; a b: 1 + for example case foo; in * then nil; end traverses all nodes - for example @a |= 1 + for example f{ |&b| } traverses all nodes - for example case foo; in x then x; end + for example foo.a ||= 1 traverses all nodes - for example meth until foo + for example a b(c(d)), :e do end traverses all nodes - for example super do end + for example foo = *bar traverses all nodes - for example f (g rescue nil) + for example foo.C += raise bar rescue nil traverses all nodes - for example f{ |*s| } + for example :'#@@1' traverses all nodes - for example break fun foo do end + for example def f ((a, *r, p)); end traverses all nodes - for example def f o=1, &b; end + for example -2 ** 10 traverses all nodes - for example `foobar` + for example %w[foo bar] traverses all nodes - for example p <<~"E" - x - #{" y"} -E + for example f{ |a, *r, p, &b| } traverses all nodes - for example self + for example foo = raise(bar) rescue nil traverses all nodes - for example %q(foobar) + for example m "#{[]}" traverses all nodes - for example fun (f bar) + for example !(a, b = foo) traverses all nodes - for example -> { _1 + _9} + for example def self._6; end traverses all nodes - for example next + for example yield() traverses all nodes - for example @@foo + for example f{ |a, *| } traverses all nodes - for example case foo; in A[] then true; end + for example def foo +=begin +=end +end traverses all nodes - for example a b(c(d)), 1 do end + for example %x{#@@1} traverses all nodes - for example %q{#@@1} + for example foo::Fun bar traverses all nodes - for example def f o=1, *r, &b; end + for example %r{a\ +b} traverses all nodes - for example %w[foo bar] + for example 42 traverses all nodes - for example return() + for example f{ |a, b,| } traverses all nodes - for example *b = bar + for example a b{c d}, /x/m do end traverses all nodes - for example { 1 => 2 } + for example true traverses all nodes - for example while foo; meth end + for example { 'foo': 2 } traverses all nodes - for example <<`HERE` -foo -bar + for example case foo; in a: then true; end + traverses all nodes + for example <<-"HERE" +#@@1 HERE traverses all nodes - for example case foo; in x, then nil; end + for example foo[0] += raise(bar) rescue nil traverses all nodes - for example fun (1).to_i + for example f{ |*| } traverses all nodes - for example tap (proc do end) + for example :'#@1' traverses all nodes - for example ::Foo + for example a b{c(d)}, :e do end traverses all nodes - for example @var = 10 + for example begin; meth; rescue; baz; else foo; ensure; bar end traverses all nodes - for example def m; class << self; A = nil; end; end + for example case foo; in ** then true; end traverses all nodes - for example case foo; in {} then true; end + for example %i[] traverses all nodes - for example if foo then bar; else baz; end + for example +foo traverses all nodes - for example a += 1 + for example bar unless foo traverses all nodes - for example a b(c(d)), /x/ do end + for example @foo traverses all nodes - for example case foo; in A then true; end + for example a b(c d), 1 do end traverses all nodes - for example @foo, @@bar = *foo + for example { foo: 2, **bar } traverses all nodes - for example def foo; end + for example foo =~ 1 traverses all nodes - for example a b{c d}, "x" do end + for example @@foo traverses all nodes - for example case foo; - in {a: 1 - } - false - ; end + for example %I[foo #{bar}] traverses all nodes - for example foo.C += raise bar rescue nil + for example case foo; in A then true; end traverses all nodes - for example p <<~E - x -E + for example foo[bar,] traverses all nodes - for example fun + for example END { 1 } traverses all nodes - for example a, * = bar + for example ((b, )) = foo traverses all nodes - for example let (:a) { m do; end } + for example <<-"HERE" +#@1 +HERE traverses all nodes - for example false + for example $foo traverses all nodes - for example a b(c d), 1 do end + for example %i[foo bar] traverses all nodes - for example fun(:foo => 1) + for example case foo; in x then x; end traverses all nodes - for example f{ |*| } + for example ::A += 1 traverses all nodes - for example foo ^ 1 + for example m "#{}#{()}" traverses all nodes - for example foo::fun (1) {} + for example foo or bar traverses all nodes - for example def foo(_a, _a); end + for example fun(*bar) traverses all nodes - for example meth 1 do end.fun bar + for example foo.fun bar traverses all nodes - for example class Foo end + for example a += b = raise :x traverses all nodes - for example case foo; in a: 1 then true; end + for example def (foo).foo; end traverses all nodes - for example <<~E - 1 \ - 2 - 3 -E + for example fun(&bar) traverses all nodes - for example bar def foo; self.each do end end + for example foo += raise bar rescue nil traverses all nodes - when a class defines `on_block_pass` - calls it for all block-pass arguments - for example @@var |= 10 + for example begin end traverses all nodes - for example foo::a = 1 + for example a b{c d}, "x" do end traverses all nodes - for example a &&= 1 + for example p <<~E + x + y +E traverses all nodes - for example f{ |a| } + for example until foo; meth end traverses all nodes - for example case foo; in [x, y,] then true; end + for example %x{#@1} traverses all nodes - for example t=1;(foo)?t:T + for example foo / 1 traverses all nodes - for example fun (1 -) + for example !foo traverses all nodes - for example %W"#{1}" + for example foo[bar, :baz => 1,] traverses all nodes - for example def f *r, p, &b; end + for example case foo; in x unless true; nil; end traverses all nodes - for example foo::(1) + for example case foo; in a:, b: then true; end traverses all nodes - for example f{ |a,| } + for example module Foo; end traverses all nodes - for example case foo; in self then true; end + for example while def self.foo; tap do end; end; break; end traverses all nodes - for example begin foo!; bar! end + for example def f(foo:); end traverses all nodes - for example case foo; in *x, y, z then nil; end + for example def until; end traverses all nodes - for example def f ((*r)); end + for example foo == 1 traverses all nodes for example :"#@1" traverses all nodes - for example f{ |a, o=1, p, &b| } + for example case foo; in A::B then true; end traverses all nodes - for example while foo do meth end + for example while not (true) do end traverses all nodes - for example case foo; in [x,] then nil; end + for example meth rescue bar traverses all nodes - for example case foo; in (1) then true; end + for example foo += raise(bar) rescue nil traverses all nodes - for example def foo(...); super(...); end + for example if foo then bar; else baz; end traverses all nodes - for example Bar::Foo + for example ->(a; foo, bar) { } traverses all nodes - for example f{ |o=1, *r, p, &b| } + for example f{ |a, o=1, *r, p, &b| } traverses all nodes - for example until foo; meth end + for example %q{#@@1} traverses all nodes - for example /#)/x + for example def f(*foo); end traverses all nodes - for example foo.(1) + for example def foo(_a, _a); end traverses all nodes - when a class defines on_arg - calls it for all arguments - for example { } + for example case foo; in x, then nil; end traverses all nodes - for example foo[m bar] + for example def self.m; _1; end traverses all nodes - for example <<'HERE' -foo -bar -HERE + for example foo, bar = m foo traverses all nodes - for example $10 + for example foo < 1 traverses all nodes - for example [ 1 => 2 ] + for example ::A, foo = foo + traverses all nodes + for example a b(c d), /x/m do end traverses all nodes for example `#@@1` traverses all nodes - for example a&.b = 1 + for example *b, c = bar traverses all nodes - for example foo = meth rescue bar + for example foo.a += m foo traverses all nodes - for example def f foo: -; end + for example var = 10; var traverses all nodes - for example foo >> 1 + for example f{ } traverses all nodes - for example break(foo) + for example defined? @foo traverses all nodes - for example 42.1i + for example %i{a\ +b} traverses all nodes - for example def f ((*)); end + for example next fun foo do end traverses all nodes - for example foo - 1 + for example %i[ #@1 ] traverses all nodes - for example %s{#@@1} + for example def f(**); end traverses all nodes - for example case foo; in "a": then true; end + for example unless foo; bar; else baz; end traverses all nodes - for example -42 + for example -> do end traverses all nodes - for example def f a, &b; end + for example a&.b traverses all nodes - for example a b(c(d)), 1.0i do end + for example +2.0 ** 10 traverses all nodes - for example def self.foo; end + for example %W[#@1] traverses all nodes - for example fun (1) {} + for example while foo; meth end traverses all nodes - for example "#@1" + for example foo.C += raise(bar) rescue nil traverses all nodes - for example meth while foo + for example m1 :k => m2 do; m3() do end; end traverses all nodes - for example begin meth end until foo + for example %I{a\ +b} traverses all nodes - for example f{ |foo:| } + for example foo::C ||= raise(bar) rescue nil traverses all nodes - for example fun(&bar) + for example foo&.bar {} traverses all nodes - for example [1, *foo, 2] + for example super foo traverses all nodes - for example class Foo; end + for example foo.a &&= 1 traverses all nodes - for example if foo; bar; elsif baz; 1; else 2; end + for example f{ |a, &b| } traverses all nodes - for example f{ |a, b,| } + for example p <<~E + x +E traverses all nodes - for example foo.m += raise(bar) rescue nil + for example def f ((*r, p)); end traverses all nodes - for example defined? @foo + for example traverses all nodes - for example a b(c d), 1.0i do end + for example while def foo; tap do end; end; break; end traverses all nodes - for example bar if foo + for example fun (1) traverses all nodes - for example f{ |&b| } + for example def f a, *r, p, &b; end traverses all nodes - for example %W{a\ -b} + for example case foo; when 'bar' then bar; end traverses all nodes - for example case foo; in "#{ 'a' }": then true; end + for example m = -> *args do end traverses all nodes - for example while def foo a = tap do end; end; break; end + for example %W[#@@1] traverses all nodes - for example a = b += raise :x + for example m { |(foo, bar)| } traverses all nodes - for example -> * { } + for example f{ |a| } traverses all nodes - for example class << foo; _1; end + for example foo::(1) traverses all nodes - for example def f(foo:); end + for example { 'foo': 2, 'bar': {}} traverses all nodes - for example __ENCODING__ + for example a b(c(d)), /x/ do end traverses all nodes - for example unless foo; bar; else baz; end + for example self.A, foo = foo traverses all nodes - for example a b(c(d)), /x/m do end + when a class defines on_arg + calls it for all arguments + for example begin; meth; rescue foo => ex; bar; end traverses all nodes - for example begin; meth; rescue; foo; else; bar; end + for example def f o=1, p, &b; end traverses all nodes - for example p :foo, {:a => proc do end, b: proc do end} + for example def foo(_, _); end traverses all nodes - for example def a; @@var |= 10; end + for example f{ |; +a +| } traverses all nodes - for example break() + for example %W[foo #{bar}] traverses all nodes - for example case foo; in "#{ %q{a} }": then true; end + for example p <<~E + x + y +E traverses all nodes - for example foo[:baz => 1,] + for example fun (1).to_i traverses all nodes - for example :'a\ -b' + for example class << foo; _1; end traverses all nodes - for example m do _1 + _9 end + for example fun traverses all nodes - for example unless foo then bar; else baz; end + for example f{ |*r, p, &b| } traverses all nodes - for example def String::foo; end + for example <<~E + 1 \ + 2 + 3 +E traverses all nodes - for example foo = *bar + for example foo && bar traverses all nodes - for example !m foo + for example yield traverses all nodes - for example foo + 1 + for example foo::C ||= raise bar rescue nil traverses all nodes - for example a b{c(d)}, :e do end + for example lambda{|;a|a} traverses all nodes - for example A += 1 + for example foo >= 1 traverses all nodes - for example m { |foo| } + for example f{ |*, &b| } traverses all nodes - for example def f ; end + for example case foo; when 'bar'; bar; end traverses all nodes - for example -> a: { } + for example a b(c d), "x" do end traverses all nodes - for example +foo + for example "foo#@a" "bar" traverses all nodes - for example foo::C ||= raise(bar) rescue nil + for example return(foo) traverses all nodes - for example :foo + for example foo + 1 traverses all nodes - for example foo.a = 1 + for example foo[0] += raise bar rescue nil traverses all nodes - for example foo >= 1 + for example [ 1 => 2 ] traverses all nodes - for example [1, 2] + for example <<`HERE` +foo +bar +HERE traverses all nodes - for example case foo; when 'bar'; bar; end + for example def m; class << self; module M; end; end; end traverses all nodes - for example fun(foo, *bar) + for example f{ || } traverses all nodes - for example def f a, o=1, &b; end + for example "#{-> foo {}}" traverses all nodes - for example %w[] + for example m ->(a: ->{_1}) {a} traverses all nodes - for example var = 10; var + for example super do end traverses all nodes - for example p :foo, {"a": proc do end, b: proc do end} + for example tap (proc do end) traverses all nodes - for example END { 1 } + for example foo.fun (1) {} traverses all nodes - for example a # -# -.foo + for example m [] do end traverses all nodes - for example def f &b; end + for example f{ |a, o=1, &b| } traverses all nodes - for example self.A, foo = foo + for example meth (-1.3).abs traverses all nodes - for example case foo; in * then nil; end + for example a b(c(d)), "x" do end traverses all nodes - when given an unexpected AST - with too few children - raises debugging error - with too many children - raises debugging error - for example foo::Fun() + for example foo = m foo traverses all nodes - for example super foo, bar do end + for example a, *b, c = bar traverses all nodes - for example def String.foo; end + for example @a |= 1 traverses all nodes - for example %Q{a\ -b} + for example a, *b = bar traverses all nodes - for example not(foo) + for example foo and bar traverses all nodes - for example f{ |*s, &b| } + for example case foo; in 1 | 2 then true; end traverses all nodes for example while class Foo a = tap do end; end; break; end traverses all nodes - for example case foo; in "#{ %Q{a} }": 1 then true; end - traverses all nodes - for example if /wat/; end + for example while foo do meth end traverses all nodes - for example foo % 1 + for example case foo; in 1; end traverses all nodes - for example case foo; in ...2 then true; end + for example /#{1}(?bar)/ =~ 'bar' traverses all nodes - for example ..100 + for example :'foo' traverses all nodes - for example begin meth end while foo + for example fun(:foo => 1) traverses all nodes - for example class A; _1; end + for example a @b do |c|;end traverses all nodes - for example a ? b & '': nil + for example def f (((a))); end traverses all nodes - for example <<-'HERE' -#@1 -HERE + for example :"foo#{bar}baz" traverses all nodes - for example foo += raise(bar) rescue nil + for example f { || a:b } traverses all nodes - for example super foo + for example self.a, self[1, 2] = foo traverses all nodes - for example case foo; in [x, y, *z] then true; end + for example fun(*bar, &baz) traverses all nodes - for example f{ || } + for example proc {_1 = nil} traverses all nodes - for example f{ } + for example next traverses all nodes - for example return(foo) + for example Foo = 10 traverses all nodes - for example case foo; in A[1, 2] then true; end + for example not m foo traverses all nodes - for example fun(*bar, &baz) + for example a b{c(d)}, /x/ do end traverses all nodes - for example !(a, b = foo) + for example a += 1 traverses all nodes - for example f{ | | } + for example a b{c d}, 1.0i do end traverses all nodes - for example super + for example until foo do meth end traverses all nodes - for example a&.b &&= 1 + for example a, b = *foo, bar traverses all nodes - for example %Q{#@1} + for example case foo; in A[] then true; end traverses all nodes - for example case foo; in **nil then true; end + for example def f **baz, &b; end traverses all nodes - for example foo.a ||= 1 + for example p <<~E + x + y +E traverses all nodes - for example a # - # -&.foo + for example %x{a\ +b} traverses all nodes - for example td (1_500).toString(); td.num do; end + for example def f *r, p, &b; end traverses all nodes - for example %W() + for example -> * { } traverses all nodes - for example def f **baz, &b; end + for example true ? 1.tap do |n| p n end : 0 traverses all nodes - for example foo[1, 2] + for example begin; meth; rescue => @ex; bar; end traverses all nodes - for example /a\ -b/ + for example foo % 1 traverses all nodes - for example <<-`HERE` -#@1 -HERE + for example def f (foo: 1, &b); end traverses all nodes - for example fun () {} + for example foo = raise bar rescue nil traverses all nodes - for example p p{p(p);p p}, tap do end + for example case foo; in x if true; nil; end traverses all nodes - for example foo.fun (1) {} + for example %{#@@1} traverses all nodes - for example case foo; in *x then nil; end + for example case foo; in A() then true; end traverses all nodes for example p <<~E - x - \ y + x + + y E traverses all nodes - for example a b(c(d)), "x" do end + for example foo << 1 traverses all nodes - for example :"#@@1" + for example foo::fun (1) {} traverses all nodes - for example %r{#@@1} + for example a b{c(d)}, "x" do end traverses all nodes - for example 42.1r + for example foo, bar = meth rescue [1, 2] traverses all nodes - for example -> (a) { } + for example defined? foo traverses all nodes - for example def m; class << self; class C; end; end; end + for example def foo; end traverses all nodes - for example foo[0] += raise(bar) rescue nil + for example a ||= 1 traverses all nodes - for example "#@a #@@a #$a" + for example proc {|_3|} traverses all nodes - for example not() + for example def f ((a, *, p)); end traverses all nodes - for example case foo; in [*x, y] then true; end + for example meth 1 do end::fun bar traverses all nodes - for example /#{1}(?bar)/ =~ 'bar' + for example foo[1, 2] = 3 traverses all nodes - for example %{#@@1} + for example def f (foo: 1, bar: 2, **baz, &b); end traverses all nodes - for example `a\ -b` + for example foo = bar = m foo traverses all nodes - for example def a b: -return -end + for example a b{c(d)}, 1.0i do end traverses all nodes - for example case; when foo; 'foo'; else 'bar'; end + 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 false ? raise do end : tap do end + for example p <<~"E" + x\n y +E traverses all nodes - for example def foo(...); end + for example foo & 1 traverses all nodes - for example def f ((a, *r, p)); end + for example %s{#@1} traverses all nodes - for example %I() + for example /(?bar)/ =~ 'bar'; match traverses all nodes - for example :"foo#{bar}baz" + for example while def self.foo a = tap do end; end; break; end traverses all nodes - for example a b{c(d)}, 1 do end + for example class << foo; nil; end traverses all nodes - for example def BEGIN; end + for example case; when foo; 'foo'; end traverses all nodes - for example $var = 10 + for example case foo; in { a: 1, } then true; end traverses all nodes - for example case foo; in "#{ %Q{a} }": then true; end + for example foo === 1 traverses all nodes - for example def f ((a, *r)); end + for example 1 in [a]; a traverses all nodes - for example case foo; when 'bar' then bar; end + for example m { _1 + _9 } traverses all nodes - for example while not (true) do end + for example __ENCODING__ traverses all nodes - for example p <<~E " y" - x -E + for example fun (1) {} traverses all nodes - for example foo = bar, 1 + for example a b(c d), 1.0r do end traverses all nodes - for example m ->(a: ->{_1}) {a} + for example %Q{a\ +b} traverses all nodes - for example if (bar; a, b = foo); end + for example a # + # +&.foo traverses all nodes - for example def f(*); end + for example ::Foo traverses all nodes - for example f{ |a| } + for example [1, *foo] traverses all nodes - for example m { _1 + _9 } + for example case foo; in a: 1 then true; end traverses all nodes - for example <<-"HERE" -#@1 -HERE + for example case foo; in 1..2 then true; end traverses all nodes - for example Foo + for example def f(foo: 1); end traverses all nodes - for example a, *, c = bar + for example case foo; in 1, "a", [], {} then nil; end traverses all nodes - for example def f(foo, bar); end + for example f x: -> do meth do end end traverses all nodes - for example foo.C += raise(bar) rescue nil + for example foo ? 1 : 2 traverses all nodes - for example %x{#@1} + for example a += b += raise :x traverses all nodes - for example def self::foo; end + for example -1.33 traverses all nodes - for example m a + b do end + for example foo[0, 1] &&= 2 traverses all nodes - for example f <<-TABLE do -TABLE -end + for example a b{c(d)}, 1.0 do end traverses all nodes - for example %{a\ -b} + for example case foo; in **a then true; end traverses all nodes - for example begin; meth; rescue; baz; ensure; bar; end + for example a b(c d), 1.0i do end traverses all nodes - for example foo or bar + for example while class << self; a = tap do end; end; break; end traverses all nodes - for example fun { } + for example "foo#{bar}baz" traverses all nodes - for example foo::a += m foo + for example %r{#@1} traverses all nodes - for example proc {_1 = nil} + for example () traverses all nodes - for example *b, c = bar + for example def f ((*r)); end traverses all nodes - for example while def foo; tap do end; end; break; end + for example foo > 1 traverses all nodes - for example %i[] + for example class Foo < a:b; end traverses all nodes - for example case 1; in 2; 3; else; end + for example def f(&block); end traverses all nodes - for example case foo; in "#{ %q{a} }": 1 then true; end + for example `foo#{bar}baz` traverses all nodes - for example -> a: 1 { } + for example fun(1) { } traverses all nodes - for example <<-`HERE` -a\ -b -HERE + for example foo[:baz => 1,] traverses all nodes - for example m { |**nil| } + for example "#@1" traverses all nodes - for example ::A, foo = foo + for example a # +# +.foo traverses all nodes - for example "#@@1" + for example foo * 1 + traverses all nodes + for example foo::fun bar traverses all nodes for example case foo; in 1 => a then true; end traverses all nodes - for example case foo; in a:, b: then true; end + for example foo traverses all nodes - for example f(a ? "a":1) + for example %I[#@@1] traverses all nodes - for example not m foo + for example Bar::Foo traverses all nodes - for example -> do rescue; end + for example f{ |*s| } traverses all nodes - for example class A < B -end + for example break() traverses all nodes - for example foo[1, 2] = 3 + for example false traverses all nodes - for example %i[foo bar] + for example [1, *foo, 2] traverses all nodes - for example case foo; - in {a: - } - true - ; end + for example foo ** 1 traverses all nodes - for example f{ |a, o=1, &b| } + for example module A; _1; end traverses all nodes - for example foo <=> 1 + for example -> { _1 + _9} traverses all nodes - for example a # -# -&.foo + for example false ? raise {} : tap {} traverses all nodes - for example [ 1, 2 => 3 ] + for example case foo; in a: 1, _a:, ** then true; end traverses all nodes - for example a b{c(d)}, 1.0r do end + for example begin meth end until foo traverses all nodes - for example %r{#@1} + for example def self::foo; end traverses all nodes - for example a b(c d), /x/m do end + for example def f a, o=1, p, &b; end traverses all nodes - for example not foo + for example a # + # +.foo traverses all nodes - for example case foo; in ::A then true; end + for example return foo traverses all nodes - for example a ||= 1 + for example unless foo then bar; end traverses all nodes - for example f{ |o=1, &b| } + for example def foo() a:b end traverses all nodes - for example foo = baz, *bar + for example if (bar); foo; end traverses all nodes - for example meth do; foo; rescue; bar; end + for example ..100 traverses all nodes - for example class << foo; nil; end + for example while def foo a = tap do end; end; break; end traverses all nodes - for example def foo(_, _); end + for example begin; meth; rescue Exception; bar; end traverses all nodes - for example m "#{[]}" + for example next foo traverses all nodes - for example a, (b, c) = foo + for example f{ |o=1, &b| } traverses all nodes - for example 42r + for example def f foo = 1; end traverses all nodes - for example if foo -then bar end + for example _2 = 1 traverses all nodes - for example p <<~E - x - y -E + for example a b(c(d)), /x/m do end traverses all nodes - for example '#@1' + for example def f foo: +; end traverses all nodes - for example ->{ } + for example <<-E + 1 \ + 2 + 3 +E traverses all nodes - for example foo "#{(1+1).to_i}" do; end + for example f{ |a, *s, &b| } traverses all nodes - for example "#{1}" + for example def f *, **; end traverses all nodes - for example m ->(a = ->{_1}) {a} + for example f{ |o=1, *r, &b| } traverses all nodes - for example begin; meth; rescue; baz; else foo; ensure; bar end + for example foo::a = 1 traverses all nodes - for example f{ |*, &b| } + for example proc {_1 = nil} traverses all nodes - for example foo::A += m foo + for example case foo; in [x, *, y] then true; end traverses all nodes - for example def String=; end + for example m { |**nil| } traverses all nodes - for example begin; meth; rescue => ex; bar; end + for example 1...2 traverses all nodes - for example p <<~`E` - x - #{foo} -E + for example foo !~ 1 traverses all nodes - for example __ENCODING__ + for example f{ |**baz, &b| } traverses all nodes - for example case foo; in 1... then true; end + for example fun (f bar) traverses all nodes - for example 1.. + for example foo += m foo traverses all nodes - for example if (a, b = foo); end + for example p <<~E + x + y +E traverses all nodes - for example p :foo, {a: proc do end, b: proc do end} + for example case foo; in {} then true; end traverses all nodes - for example def _5; end + for example 1... traverses all nodes - for example !(foo...bar) + for example def String; end traverses all nodes - for example "foo#@a" "bar" + for example def foo + a:b end traverses all nodes - for example foo = raise(bar) rescue nil + for example return traverses all nodes - for example %x{a\ -b} + for example if foo..bar; end traverses all nodes - for example def f foo: -1 -; end + for example __ENCODING__ traverses all nodes - for example for a in foo do p a; end + for example case foo; in A(1, 2) then true; end traverses all nodes - for example p -> { :hello }, a: 1 do end + for example def foo(...); super(...); end traverses all nodes - for example begin; meth; rescue => @ex; bar; end + for example def f ; 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 begin end + for example if foo; bar; end traverses all nodes - for example -2.0 ** 10 + for example p p{p(p);p p}, tap do end traverses all nodes - for example 1.33 + for example foo "#{(1+1).to_i}" do; end traverses all nodes - for example case foo; in 1.. then true; end + for example -42 traverses all nodes - for example redo + for example self traverses all nodes - for example next foo + for example alias :foo bar traverses all nodes - for example a b{c(d)}, /x/ do end + for example foo[0, 1] ||= 2 traverses all nodes - for example p <<~"E" - x\n y -E + for example a b(c(d)), 1.0i do end traverses all nodes - for example foo, bar = m foo + for example a b(c d), /x/ do end traverses all nodes - for example lambda{|;a|a} + for example case foo; in (1) then true; end traverses all nodes - for example def x; ::A ||= 1; end + for example for a in foo do p a; end traverses all nodes - for example next fun foo do end + for example meth while foo traverses all nodes - for example f{ |**baz, &b| } + for example let () { m(a) do; end } traverses all nodes - for example if foo; bar; else baz; end + for example break(foo) traverses all nodes - for example +2.0 ** 10 + for example foo[1, 2] traverses all nodes - for example f{ |foo: 1, &b| } + for example foo - 1 traverses all nodes - for example def f(foo); end + for example class A < B +end traverses all nodes - for example case foo; in A::B then true; end + for example "#@a #@@a #$a" traverses all nodes - for example p <<~E -E + for example <<-"HERE" +a\ +b +HERE traverses all nodes - for example f{ |*r, p, &b| } + for example a &&= 1 traverses all nodes - for example fun(foo, :foo => 1, &baz) + for example foo[0, 1] += m foo traverses all nodes - for example foo.a += m foo + for example [*foo] traverses all nodes - for example while def self.foo; tap do end; end; break; end + for example foo.m += raise(bar) rescue nil traverses all nodes - for example def String; end + for example def a; @@var |= 10; end traverses all nodes - for example 'a\ -b' + for example while class << self; tap do end; end; break; end traverses all nodes - for example <<~FOO - baz\ - qux -FOO + for example p :foo, {"a": proc do end, b: proc do end} traverses all nodes - for example foo::m += raise(bar) rescue nil + for example next(foo) traverses all nodes - for example case foo; in a: 1, _a:, ** then true; end + for example ->{ } traverses all nodes - for example -2 ** 10 + for example !(foo..bar) traverses all nodes - for example def self._6; end + for example def f foo: -1 +; end traverses all nodes - for example %s{a\ -b} + for example class Foo < Bar; end traverses all nodes - for example __FILE__ + for example @var = 10 traverses all nodes - for example a b(c d), 1.0r do end + for example p <<~`E` + x + #{foo} +E traverses all nodes - for example foo, bar = meth rescue [1, 2] + for example p :foo, {proc do end => proc do end, b: proc do end} traverses all nodes - for example $+ + for example a = b += raise :x traverses all nodes - for example <<-E - 1 \ - 2 - 3 -E + for example foo, bar, baz = 1, 2 traverses all nodes - for example `foo#{bar}baz` + for example begin; meth; ensure; bar; end traverses all nodes - for example %I[foo #{bar}] + for example %I[#@1] traverses all nodes - for example foo[0, 1] += m foo + for example break fun foo do end traverses all nodes - for example -> (arg={}) {} + for example ?a traverses all nodes - for example a # - # -.foo + for example case [__FILE__, __LINE__ + 1, __ENCODING__] + in [__FILE__, __LINE__, __ENCODING__] + end traverses all nodes - for example case foo; in A() then true; end + for example ->(**nil) {} traverses all nodes - for example case foo; in ^foo then nil; end + for example * = bar traverses all nodes - for example begin; meth; rescue; foo; end + for example foo = bar, 1 traverses all nodes - for example yield foo + for example foo::a += 1 traverses all nodes - for example ::Foo = 10 + for example def f(foo); end traverses all nodes - for example def f(foo=1, bar=2); end + for example foo[m bar] traverses all nodes - for example m "#{}#{()}" + for example :"a\ +b" traverses all nodes - for example '#@@1' + for example [1, 2] traverses all nodes - for example def foo -=begin -=end -end + for example %I() traverses all nodes - for example if foo then bar; end + for example fun { } traverses all nodes - for example { 'foo': 2 } + for example fun(foo, *bar, &baz) traverses all nodes - for example %W[foo #{bar}] + for example case foo; in *x then nil; end traverses all nodes - for example yield() + for example `a\ +b` traverses all nodes - for example m [] do end + for example if foo then bar; end traverses all nodes - for example foo || bar + for example a b{c d}, 1 do end traverses all nodes - for example foo[0, 1] ||= 2 + for example foo && (a, b = bar) traverses all nodes - for example self.a, self[1, 2] = foo + for example foo.a = 1 traverses all nodes - for example defined? foo + for example 42.1i traverses all nodes - for example { 1 => 2, :foo => "bar" } + for example p <<~"E" + x + #{" y"} +E traverses all nodes - for example 42.1ri + for example "#{1}" traverses all nodes - for example def m; class << self; module M; end; end; end + for example def f ((*)); end traverses all nodes - for example if foo..bar; end + for example not() traverses all nodes - for example 42i + for example case foo; in **nil then true; end traverses all nodes - for example foo > 1 + for example [ 1, 2 => 3 ] traverses all nodes - for example case foo; in 1, "a", [], {} then nil; end + for example BEGIN { 1 } traverses all nodes - for example a b(c d), :e do end + for example __LINE__ traverses all nodes for example case foo; in x, y then nil; end traverses all nodes - for example p :foo, {** proc do end, b: proc do end} - traverses all nodes - for example m = -> *args do end + for example a b{c(d)}, 1.0r do end traverses all nodes - for example yield(foo) + for example case foo; in "#{ %Q{a} }": then true; end traverses all nodes - for example __LINE__ + for example foo::m += raise bar rescue nil traverses all nodes - for example ~foo + for example @@var = 10 traverses all nodes - for example case foo; in [x, *y, z] then true; end + for example def f ((a, *r)); end traverses all nodes - for example a b(c d), /x/ do end + for example f (g rescue nil) traverses all nodes - for example f{ |a, o=1, o1=2, *r, &b| } + for example /#)/x traverses all nodes - for example 42 + for example undef foo, :bar, :"foo#{1}" traverses all nodes - for example case foo; in **a then true; end + for example bar if foo traverses all nodes for example %w[ #@@1 ] traverses all nodes - for example def f a, *r, p, &b; end + for example [/()\1/, ?#] traverses all nodes - for example a b(c d), 1.0 do end + for example super() traverses all nodes - for example def f ((*, p)); end + for example -> (a) { } traverses all nodes - for example %I[foo#{bar}] + for example ->{ } traverses all nodes - for example return + for example a b(c d), 1.0 do end traverses all nodes - for example unless foo; bar; end + for example def foo(...); end traverses all nodes - for example a b{c d}, /x/m do end + for example "a\ +b" traverses all nodes - for example retry + for example meth until foo traverses all nodes - for example def f(**); end + for example <<-'HERE' +#@@1 +HERE traverses all nodes - for example self::A, foo = foo + for example a b{c(d)}, 1 do end traverses all nodes - for example assert dogs + for example def f(**foo); end traverses all nodes - for example @foo + for example %Q{#@@1} traverses all nodes - for example super(foo) + for example f{ |;a| } traverses all nodes - for example begin; meth; rescue Exception; bar; end + for example case foo; in { a: 1 } then true; end traverses all nodes - for example %s{#@1} + for example case foo; in A[x:] then true; end traverses all nodes - for example case foo; in ** then true; end + for example foo[0, 1] += 2 traverses all nodes - for example [1, *foo] + for example super(foo) traverses all nodes - for example p <<~E - x - y -E + for example foo.(1) traverses all nodes - for example def f foo = 1; end + for example super foo, bar do end 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 + for example <<-`HERE` +#@@1 +HERE traverses all nodes - for example foo * 1 + for example :'a\ +b' traverses all nodes - for example foo + for example case foo; in [x, y,] then true; end traverses all nodes - for example begin; meth; rescue foo => ex; bar; end + for example foo = baz, *bar traverses all nodes - for example def x; self::A ||= 1; end + for example %Q{#@1} traverses all nodes - for example break foo + for example case foo; + in {a: 1 + } + false + ; end traverses all nodes - for example "foo#{bar}baz" + for example begin meth end while foo traverses all nodes - for example meth 1 do end.fun(bar) {} + for example f{ |foo: 1, &b| } traverses all nodes - for example +42 + for example fun! traverses all nodes - for example false ? raise {} : tap {} + for example "#@@1" traverses all nodes - for example f x: -> do meth do end end + for example -> do rescue; end traverses all nodes - for example case foo; in { a: 1 } then true; end + for example foo.a += 1 traverses all nodes - for example BEGIN { 1 } + for example $var = 10 traverses all nodes - for example f{ |foo: 1, bar: 2, **baz, &b| } + for example <<-'HERE' +#@1 +HERE traverses all nodes - for example def until; end + for example f{ |a| } traverses all nodes - for example foo[0, 1] += 2 + for example { } traverses all nodes - for example def f o=1, p, &b; end + for example m do _1 + _9 end traverses all nodes - for example <<-`HERE` -#@@1 -HERE + for example foo[1, 2] = 3 traverses all nodes - for example a b{c d}, 1.0 do end + for example '#@1' traverses all nodes - for example f{ |a, c| } + for example %I[foo#{bar}] traverses all nodes - for example p <<~E - x - y -E + for example super traverses all nodes - for example foo, bar, baz = 1, 2 + for example %r{#@@1} traverses all nodes - for example foo = m foo + for example a&.b = 1 traverses all nodes - for example a b{c d}, :e do end + for example def BEGIN; end traverses all nodes - for example super() + for example case foo; when 1, *baz; bar; when *foo; end traverses all nodes - for example meth 1 do end.fun {} + for example 'foobar' traverses all nodes - for example def x(_4) end + for example +42 traverses all nodes - for example f{ |o=1, p, &b| } + for example def f o=1, *r, p, &b; end traverses all nodes - for example {a: if true then 42 end} + for example 1.33 traverses all nodes - for example a b{c(d)}, "x" do end + for example t=1;(foo)?t:T traverses all nodes - for example foo & 1 + for example case foo; in self then true; end traverses all nodes - for example foo (-1.3).abs + for example case foo; in [x,] then nil; end traverses all nodes - for example alias $a $+ + for example case foo; in "#{ 'a' }": then true; end traverses all nodes - for example while def self.foo a = tap do end; end; break; end + for example case foo; in [x, y, *z] then true; end traverses all nodes - for example proc {|_3|} + for example foo | 1 traverses all nodes - for example ->(scope) {}; scope + for example def String=; end traverses all nodes - for example case [__FILE__, __LINE__ + 1, __ENCODING__] - in [__FILE__, __LINE__, __ENCODING__] - end + for example a = b = raise :x traverses all nodes - for example case foo; in ->{ 42 } then true; end + for example %W"#{1}" traverses all nodes - for example def END; end + for example for a in foo; p a; end traverses all nodes - for example /\xa8/n =~ "" + for example p begin 1.times do 1 end end traverses all nodes - for example 'foobar' + for example case foo; + in {Foo: 42 + } + false + ; end traverses all nodes - for example a b(c(d)), 1.0 do end + for example def f ((*, p)); end traverses all nodes - for example case foo; in x, y, then nil; end + for example /#@@1/ traverses all nodes - for example o = { -a: -1 -} + for example %W{a\ +b} traverses all nodes - for example <<-"HERE" -a\ -b -HERE + for example case foo; in [x, y, *] then true; end traverses all nodes - for example def f (foo: 1, &b); end + for example foo <=> 1 traverses all nodes - for example let () { m(a) do; end } + for example %i[ #@@1 ] traverses all nodes - for example $foo + for example fun (1 +) traverses all nodes - for example def f ((a, *, p)); end + for example p -> { :hello }, a: 1 do end traverses all nodes - for example a b{c(d)}, 1.0 do end + for example p <<~E + x + \ y +E traverses all nodes - for example a, *b, c = bar + for example case foo; in [*, x] then true; end traverses all nodes - for example m [], 1 do end + for example fun(1) traverses all nodes - for example fun! + for example def m; class << self; A = nil; end; end traverses all nodes - for example foo.a += 1 + for example fun do end traverses all nodes - for example Foo = 10 + for example a b(c(d)), 1.0 do end traverses all nodes - for example undef foo, :bar, :"foo#{1}" + for example meth 1 do end.fun {} traverses all nodes - for example %q{#@1} + for example foo.fun traverses all nodes - for example { foo: 2, **bar } + for example 42.1ri traverses all nodes - for example true ? 1.tap do |n| p n end : 0 + for example %q{a\ +b} traverses all nodes - for example def f *, **; end + for example 42ri traverses all nodes - for example def f(foo: 1); end + for example p <<~"E" + x + #{foo} +E traverses all nodes - for example module A; _1; end + for example meth do; foo; rescue; bar; end traverses all nodes - for example begin; meth; ensure; bar; end + for example `#@1` traverses all nodes - for example def f a, o=1, *r, p, &b; end + for example 42r traverses all nodes - for example fun(foo, :foo => 1) + for example case foo; in x, *y, z then nil; end traverses all nodes - for example p <<~"E" - x - #{foo} + for example p <<~E " y" + x E traverses all nodes - for example unless foo then bar; end + for example def f(foo, bar); end traverses all nodes - for example fun(f bar) + for example def _5; end traverses all nodes - for example foo < 1 + for example case foo; in [*x, y] then true; end traverses all nodes - for example fun() { } + for example foo ^ 1 traverses all nodes - for example while class << self; a = tap do end; end; break; end + for example ...100 traverses all nodes - for example if (bar); foo; end + for example def foo(...); bar(...); end traverses all nodes - for example `#@1` + for example nil traverses all nodes - for example next() + for example /\xa8/n =~ "" traverses all nodes - for example def f(**foo); end + for example case foo; in [x, *y, z] then true; end traverses all nodes - for example begin ensure end + for example case foo; in 1.. then true; end traverses all nodes - for example class Foo < Bar; end + for example fun(foo, *bar) traverses all nodes - for example fun(:foo => 1, &baz) + for example a = 1; a b: 1 traverses all nodes - for example a b{c d}, 1.0i do end + for example 'a\ +b' traverses all nodes - for example p <<~E - x - y -E + for example f{ |a, o=1, o1=2, *r, &b| } traverses all nodes - for example a b{c(d)}, 1.0i do end + for example a b(c(d)), 1.0r do end traverses all nodes - for example { foo: 2 } + for example case foo; in ::A then true; end traverses all nodes - for example case foo; in 1; end + for example redo traverses all nodes - for example yield + for example def x; ::A ||= 1; end traverses all nodes - for example <<-"HERE" -#@@1 -HERE + for example %{#@1} traverses all nodes - for example foo::A = 1 + for example foo != 1 traverses all nodes - for example 42ri + for example Foo traverses all nodes - for example + for example ->(scope) {}; scope traverses all nodes - for example %w[ #@1 ] + for example f{ |a| } traverses all nodes - for example case foo; in [x] then nil; end + for example def foo(...); bar(...); end traverses all nodes - for example case foo; in [*, x] then true; end + for example unless foo; bar; end traverses all nodes - for example def f (((a))); end + for example break foo traverses all nodes - for example <<-'HERE' -a\ -b -HERE + for example -> a: 1 { } traverses all nodes - for example foo::fun + for example foo::A = 1 traverses all nodes - for example def foo raise; raise A::B, ''; end + for example def f(foo=1, bar=2); end traverses all nodes - for example a += b = raise :x + for example begin; rescue LoadError; else; end traverses all nodes - for example a b{c d}, 1.0r do end + for example a b{c d}, /x/ do end traverses all nodes - for example fun(*bar) + for example a b(c(d)), 1 do end traverses all nodes - for example %{#@1} + for example td (1_500).toString(); td.num do; end traverses all nodes - for example ->(a; foo, bar) { } + for example fun() { } traverses all nodes - for example foo && (a, b = bar) + for example case foo; in 1... then true; end traverses all nodes - for example foo.m += raise bar rescue nil + for example def f ((a, *)); end traverses all nodes - for example case foo; in 1...2 then true; end + for example def f(*); end traverses all nodes - for example () + for example a&.b &&= 1 traverses all nodes - for example a b{c(d)}, /x/m do end + for example case foo; in ..2 then true; end traverses all nodes - for example 1... + for example case foo; + in {a: + } + true + ; end traverses all nodes - for example p :foo, {proc do end => proc do end, b: proc do end} + for example @foo, @@bar = *foo traverses all nodes - for example module Foo; end + for example a ? b & '': nil traverses all nodes - for example fun(1) + for example foo = meth rescue bar traverses all nodes - for example foo, bar = 1, 2 + for example <<-`HERE` +a\ +b +HERE traverses all nodes - for example def f ((a, *)); end + for example f{ |a,| } traverses all nodes - for example foo / 1 + for example foo || (a, b = bar) traverses all nodes - for example !/wat/ + for example :"#@@1" traverses all nodes - for example a, b = *foo, bar + for example a b{c d}, :e do end traverses all nodes - for example def foo - a:b end + for example self::A, foo = foo traverses all nodes - for example defined?(foo) + for example def m; class << self; class C; end; end; end traverses all nodes - for example module Bar::Foo; end + for example case foo; + in {a: + 2} + false + ; end traverses all nodes - for example a, *b = bar + for example return fun foo do end traverses all nodes - for example fun do end + for example case foo; in *x, y, z then nil; end traverses all nodes - for example foo.A += 1 + for example def f a, o=1, &b; end traverses all nodes - for example ->{ } + for example if foo +then bar end traverses all nodes - for example foo ? 1 : 2 + for example def f(**nil); end traverses all nodes - for example foo || (a, b = bar) + for example foo.A += 1 traverses all nodes - for example case; when foo; 'foo'; end + for example a, * = bar traverses all nodes - for example foo[bar, :baz => 1,] + for example f{ | | } traverses all nodes - for example f{ |;a| } + for example <<~FOO + baz\ + qux +FOO traverses all nodes - for example a b(c(d)), 1.0r do end + for example def x(_4) end traverses all nodes - for example foo&.bar {} + for example $10 traverses all nodes - for example meth 1 do end::fun bar + for example f <<-TABLE do +TABLE +end traverses all nodes - for example foo[bar,] + for example p <<~E + E traverses all nodes - for example case foo; in x unless true; nil; end + for example unless foo then bar; else baz; end traverses all nodes - for example def f a, *r, &b; end + for example assert do: true traverses all nodes - for example foo[0] += raise bar rescue nil + for example < do _1 + _9 end + for example %w{a\ +b} traverses all nodes - for example foo.A = 1 + for example a b{c d}, 1.0 do end traverses all nodes - for example foo::C ||= raise bar rescue nil + for example case foo; in "#{ %q{a} }": then true; end traverses all nodes - for example def f(&block); end + for example case foo; in "a": then true; end traverses all nodes - for example module ::Foo; end + for example def a b: +return +end traverses all nodes - for example def f o=1, *r, p, &b; end + for example foo >> 1 traverses all nodes - for example proc {_1 = nil} + for example %q(foobar) traverses all nodes - for example :"a\ -b" + for example case; when foo; 'foo'; else 'bar'; end traverses all nodes - for example f{ |; -a -| } + for example def String.foo; end traverses all nodes - for example p <<~E - E + for example alias $a $+ traverses all nodes - for example -1.33 + for example `foobar` traverses all nodes - for example case foo; in 1 | 2 then true; end + for example meth 1 do end::fun(bar) traverses all nodes - for example begin; rescue LoadError; else; end + for example /a\ +b/ traverses all nodes - for example f{ |a, *s, &b| } + for example <<-'HERE' +a\ +b +HERE traverses all nodes - for example def f ((a, a1)); end + for example meth 1 do end.fun bar traverses all nodes - for example foo << 1 + for example ->(a) { } traverses all nodes - for example return foo + for example case foo; + in a: {b:}, c: + p c + ; end traverses all nodes - for example %W[#@1] + for example $+ traverses all nodes - for example 1 in [a]; a + for example -foo traverses all nodes - for example def foo(...); bar(...); end + for example case foo; in "#{ %Q{a} }": 1 then true; end traverses all nodes - for example assert do: true + for example foo[1, 2] + traverses all nodes + for example begin; meth; rescue; foo; else; bar; end traverses all nodes -RuboCop::AST::StrNode - #character_literal? - with a normal string literal - is expected not to be character literal - with a character literal - is expected to be character literal - with a heredoc - is expected not to be character literal +RuboCop::AST::Node + #class_definition? + with inheritance + matches + with object singleton class + matches + namespaced class + matches + without inheritance + matches + constant defined as Struct without block + does not match + with self singleton class + matches + with Struct + matches + when using numbered parameter + matches + with Class.new + matches + when using numbered parameter + matches + with ::ClassName + matches + #value_used? + within an if...else..end node + nested in a method call + is always true + at the top level + is true only for the condition + within a method call node + is always true + within a singleton class node + is always true + at the top level + is false + within an array literal + assigned to an ivar + is always true + at the top level + is always false + within a while node + is true only for the condition + within a class definition node + is always true + within a module definition node + is always true + at the end of a block + is always true + #class_constructor? + class definition + does not match + class definition with a block + matches + class definition on outer scope + matches + module definition with a block + matches + #struct_constructor? + ::Struct + matches + struct definition without block + does not match + struct definition with a block + matches + #numeric_type? + when float literal + is true + when integer literal + is true + when string literal + is true + when rational literal + is true + when complex literal whose imaginary part is a rational + is true + when complex literal + is true + #conditional? + when post condition loop node + is false + when `case` node + is true + when `if` node + is true + when `while` node + is true + when `until` node + is true + when `case_match` node + is true + #parent_module_name + 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 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" + #pure? + for a cvar assignment + returns false + for a method call + 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 a regexp + with interpolated segments + returns false + with no interpolation + returns true + with options + returns true + for an lvar assignment + returns false + for an ivar assignment + returns false + for a class definition + returns false + for a module definition + returns false + for an array literal + with only literal children + returns true + which contains a method call + returns false + for an integer literal + returns true + for a gvar assignment + returns false + for a hash literal + which contains a method call + returns false + with only literal children + returns true + #recursive_basic_literal? + behaves like literal + returns true for `false` + behaves like non literal + returns false for `some_method_call` + behaves like literal + returns true for `"#{2}"` + behaves like non literal + returns false for `some_method_call(x, y)` + 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 non literal + returns false for `%r{abx#{foo}}ixo` + behaves like literal + returns true for `(1)` + behaves like non literal + returns false for `/.#{some_method_call}/` + behaves like non literal + returns false for `(x == false)` + behaves like literal + returns true for `(false or true)` + behaves like literal + returns true for `!true` + behaves like non literal + returns false for `(x && false)` + behaves like non literal + returns false for `{ :sym => some_method_call }` + behaves like literal + returns true for `{ a: 1, b: 2 }` + behaves like literal + returns true for `[1, 2, 3]` + behaves like literal + returns true for `%r{abx}ixo` + behaves like literal + returns true for `(false && true)` + behaves like literal + returns true for `nil` + behaves like non literal + returns false for `(x or false)` + behaves like literal + returns true for `/./` + behaves like literal + returns true for `'str'` + behaves like literal + returns true for `1.0` + behaves like literal + returns true for `{ :a => 1, :b => 2 }` + behaves like non literal + returns false for `{ some_method_call => :sym }` + #module_definition? + nested modules + matches + using module keyword + matches + included module definition + matches + prepend Module.new + matches + with Module.new + matches + when using numbered parameter + matches + namespaced modules + matches + with ::ModuleName + matches + #argument_type? + method arguments + returns true for all argument types + block arguments + returns true for all argument types + sibling_access + returns trivial values for a root node + for a single child + returns the expected values + for a node with siblings + returns the expected values + +RuboCop::AST::UntilNode + #do? + with a do keyword + is expected to be do + without a do keyword + is expected not to be do + #inverse_keyword + is expected to eq "while" + #loop_keyword? + with a statement until + is expected to be loop keyword + with a modifier until + is expected to be loop keyword + #keyword + is expected to eq "until" .new - with a normal string - 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 - with a heredoc - is expected to be a kind of RuboCop::AST::StrNode - #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 + 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 + #post_condition_loop? + with a modifier until + is expected to be post condition loop + with a statement until + is expected not to be post condition loop -RuboCop::AST::Ext::Range - #line_span - accepts an `exclude_end` keyword argument - returns the range of lines a range occupies +RuboCop::AST::AndNode + #rhs + with a semantic and node + is expected to be int type + with a logical and node + is expected to be int type + #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 + .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 + #inverse_operator + with a semantic and node + is expected to eq "or" + with a logical and node + is expected to eq "||" + #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 + #alternate_operator + with a logical and node + is expected to eq "and" + with a semantic and node + is expected to eq "&&" + #lhs + with a logical and node + is expected to be sym type + with a semantic and node + is expected to be sym type + #operator + with a semantic and node + is expected to eq "and" + with a logical and node + is expected to eq "&&" -RuboCop::AST::ArrayNode - #values - with an array of literals +RuboCop::AST::OpAsgnNode + #expression + is expected to eq s(:send, nil, :value) + #name + is expected to eq :var + #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 + #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::PairNode + #value_delta + when using hash rocket delimiters + when both pairs are on the same line + is expected to eq 0 + when receiver value is ahead + 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 behind + is expected to eq -2 + when using colon delimiters + 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 both pairs are on the same line + is expected to eq 0 + #value + is expected to be int type + #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 + #same_line? + when pairs are on separate lines + when last pair is a keyword splat + is expected not to be same line s(:kwsplat, + s(:send, nil, :foo)) + when both pairs are explicit pairs + is expected not to be same line s(:pair, + s(:sym, :b), + s(:int, 2)) + when both pairs are on the same line + when both pair is a keyword splat + 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, :b), + s(:int, 2)) + when a multiline pair shares the same line + 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 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)) + #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 ": " + #colon? + when using a colon delimiter + is expected to be colon + when using a hash rocket delimiter + is expected not to be colon + .new + is expected to be a kind of RuboCop::AST::PairNode + #key + when using a symbol key + is expected to be sym type + when using a string key + is expected to be str type + #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 "=>" + #key_delta + with alignment set to :left + 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 -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 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 using hash rocket delimiters + when keys are aligned + when both keys are explicit keys + is expected to eq 0 + when second key 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 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 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 + with alignment set to :right + when using hash rocket delimiters + 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 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 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 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 second pair is a keyword splat + is expected to eq 0 + when both pairs are reail pairs + is expected to eq -2 + 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 + #value_on_new_line? + when pair is on a single line + 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 value spans multiple lines + is expected not to be value on new line + #hash_rocket? + when using a hash rocket delimiter + is expected to be hash rocket + when using a colon delimiter + is expected not to be hash rocket + +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" + #do? + without a do keyword + is expected not to be do + with a do keyword + is expected to be do + .new + with a modifier while + is expected to be a kind of RuboCop::AST::WhileNode + with a statement while + is expected to be a kind of RuboCop::AST::WhileNode + #keyword + is expected to eq "while" + #loop_keyword? + with a statement while + is expected to be loop keyword + with a modifier while + is expected to be loop keyword + +RuboCop::AST::RangeNode + .new + with an inclusive 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 a kind of RuboCop::AST::RangeNode + is expected to be range type + with a beignless range + is expected to be a kind of RuboCop::AST::RangeNode + is expected to be range type + with an infinite range + is expected to be range type + is expected to be a kind of RuboCop::AST::RangeNode + +RuboCop::AST::RegexpNode + #no_encoding? + with only n option + is expected to be no encoding + with other options + is expected not to be no encoding + with n and other options + is expected to be no encoding + with no options + is expected not to be no encoding + #extended? + with x and other options + is expected to be extended + with other options + is expected not to be extended + with only x option + is expected to be extended + with no options + is expected not to be extended + #delimiters + with multi-line %r{-delimiters + is expected to eq ["{", "}"] + with /-delimiters + is expected to eq ["/", "/"] + with %r/-delimiters + is expected to eq ["/", "/"] + with %r<-delimiters + is expected to eq ["<", ">"] + with %r{-delimiters + is expected to eq ["{", "}"] + .new + is expected to be a kind of RuboCop::AST::RegexpNode + #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 + with multi-line %r{-delimiters + is expected to be percent r literal + #content + with a regexp without option + is expected to eq ".+" + with an empty regexp with option + is expected to eq "" + with a multi-line regexp with option + is expected to eq "\n.+\n" + with an empty regexp + is expected to eq "" + with a regexp with option + is expected to eq ".+" + with a multi-line regexp without option + is expected to eq "\n.+\n" + #options + with an empty regexp + 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 "o" option + is expected to eq 0 + with a regexp with multiple options is expected to eq 3 - is expected to all be literal - with an empty array + #single_interpolation? + with only o option + is expected 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 + with no options + is expected not to be single interpolation + #multiline_mode? + with no options + is expected not to be multiline mode + with m and other options + is expected to be multiline mode + with other options + is expected not to be multiline mode + with only m option + is expected to be multiline mode + #interpolation? + with direct variable interpoation + is expected to be interpolation + with regexp quote + is expected to be interpolation + with no interpolation returns false + is expected not to be interpolation + #regopt + with a multi-line regexp with option + is expected to eq [:i, :m, :x] + is expected to be regopt type + with an empty regexp is expected to be empty - with an array of variables - is expected to all be send type - is expected to eq 2 + 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 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 + #ignore_case? + with no options + is expected not to be 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 + #to_regexp + with a multi-line regexp with option + is expected to eq / +.+ +/ix + with a regexp with an "o" option + is expected to eq "/abc/i" + 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 a multi-line regexp without option + is expected to eq / +.+ +/ + with a regexp with option + is expected to eq /.+/mix + with a regexp without option + is expected to eq /.+/ + with an empty regexp with option + is expected to eq //ix + with an empty regexp + is expected to eq // + #delimiter? + with /-delimiters + is expected to be delimiter "/" + is expected not to be delimiter "{" + with %r<-delimiters + 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 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 to be delimiter ">" + is expected not to be delimiter "r" + is expected not to be delimiter "%" + with multi-line %r{-delimiters + is expected not to be delimiter "/" + 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 "%" + is expected not to be delimiter "r" + is expected to be delimiter "{" + is expected not to be delimiter "%r" + 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 to be delimiter "/" + is expected not 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 "%r" + 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 "%" + is expected not to be delimiter "/" + is expected to be delimiter "{" + #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 + with u and other options + is expected to be fixed encoding + #slash_literal? + with %r{-delimiters + is expected not 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 /-delimiters + is expected to be slash literal + with %r<-delimiters + is expected not to be slash literal + +RuboCop::AST::ArrayNode .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)"] + is expected to be a kind of RuboCop::AST::ArrayNode #percent_literal? - with a symbol percent literal - is expected to be percent literal + with square brackets is expected not to be percent literal :string - is expected to be percent literal :symbol + is expected not to be percent literal :symbol + is expected not to be 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 is expected to be percent literal :string - with square brackets - is expected not to be percent literal :symbol + with a symbol percent literal + is expected to be percent literal is expected not to be percent literal :string - is expected not to be percent literal + is expected to be percent literal :symbol #bracketed? - unbracketed - is expected to be nil with square brackets is expected to be bracketed with a percent literal is expected to be bracketed + unbracketed + is expected to be nil + #values + with an empty array + is expected to be empty + with an array of literals + is expected to all be literal + is expected to eq 3 + with an array of variables + is expected to eq 2 + is expected to all be send type #square_brackets? - with a percent literal - is expected not to be square brackets with square brackets is expected to be square brackets + with a percent literal + is expected not to be square brackets -RuboCop::AST::YieldNode - #dot? - is expected not to be dot - #predicate_method? - is expected not to be predicate method +RuboCop::AST::OrAsgnNode + #name + is expected to eq :var + #assignment_node + is expected to be a kind of RuboCop::AST::AsgnNode .new - is expected to be a kind of RuboCop::AST::YieldNode - #const_receiver? - is expected not to be const receiver + is expected to be a kind of RuboCop::AST::OrAsgnNode + #operator + is expected to eq :"||" + #expression + is expected to eq s(:send, nil, :value) + +RuboCop::AST::LambdaNode + #method_name + is expected to eq :lambda + #arguments + is expected to eq 2 + #receiver + is expected to be nil + +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 + #identifier + is expected to be self type + .new + is expected to be a kind of RuboCop::AST::SelfClassNode + +RuboCop::AST::YieldNode + #block_node + is expected to be nil #camel_case_method? is expected not to be camel case method - #splat_argument? - with no arguments - is expected not to be splat argument - with mixed arguments - is expected to be splat argument - with a splat argument - is expected to be splat argument - with regular arguments - is expected not to be splat argument - #double_colon? - is expected not to be double colon - #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 - #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" - #assignment_method? - is expected not to be assignment method + #dot? + is expected not to be dot + #operator_method? + is expected not to be operator method #setter_method? is expected not to be setter method - #block_node - is expected to be nil - #command? - when argument is a string - is expected to be command "yield" - when argument is a symbol - is expected to be command :yield - #self_receiver? - is expected not to be self receiver #first_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 sym type - #implicit_call? - is expected not to be implicit call - #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 no arguments - is expected to be nil - with a single splat argument - is expected to be splat type - #bang_method? - is expected not to be bang method - #comparison_method? - is expected not to be comparison method - #block_argument? - is expected not to be block argument - #arguments? - with multiple literal 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 multiple mixed arguments - is expected to be arguments - with no arguments - is expected not to be arguments - #operator_method? - is expected not to be operator method - #macro? - is expected not to be macro - #block_literal? - is expected not to be block literal - #receiver - is expected to be nil - #method_name - is expected to eq :yield + is expected to be sym type #arguments - with a single splat argument - is expected to eq 1 with no arguments is expected to be empty 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 a single literal argument is expected to eq 1 - -RuboCop::AST::ArgNode - #name - with a regular argument - is expected to eq :x - with a block argument - is expected to eq :x - with a double splatted argument - is expected to eq :x - with argument forwarding - with Ruby >= 3.0 - is expected to be nil - with Ruby >= 2.7 - is expected to be nil - with a nameless double splatted argument - is expected to be nil - with a shadow argument - is expected to eq :x - with a keyword argument - is expected to eq :x - with an optional argument - is expected to eq :x - with a splatted argument - is expected to eq :x - with a nameless splatted argument - is expected to be nil - with a block - is expected to eq :x - with an optional keyword argument - is expected to eq :x - #default? - with a shadow 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 an optional keyword argument - is expected to equal true - with a regular argument - is expected to equal false - with a block - is expected to equal false - with a block argument - is expected to equal false - with an optional 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 - .new - 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 lambda literal - 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 shadow argument - 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 a double 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 block 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 an optional argument - is expected to be a kind of RuboCop::AST::ArgNode - with a keyword argument - is expected to be a kind of RuboCop::AST::ArgNode - #default_value - with a double splatted argument - is expected to be nil - with a shadow 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 splatted argument - 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 an optional keyword argument - is expected to eq s(:int, 42) - with a block argument - is expected to be nil - with a regular argument - is expected to be nil - -RuboCop::AST::DefinedNode - #arguments - is expected to all be sym type - is expected to eq 1 - .new - with a defined? node - is expected to be a kind of RuboCop::AST::DefinedNode - #method_name - is expected to eq :defined? - #receiver - is expected to be nil - -RuboCop::AST::ArgsNode - #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 lambda literal - is expected to be a kind of RuboCop::AST::ArgsNode - 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 - #empty_and_without_delimiters? - with arguments - with a method definition - is expected to equal false - with a lambda literal - is expected to equal false - with delimiters - with a block - is expected to equal false - with a method definition - is expected to equal false - with a lambda literal - 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 - -RuboCop::AST::DefNode - #body - with no 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 - #block_argument? - with mixed arguments - is expected to be block argument - with regular arguments - is expected not 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 mixed arguments is expected to eq 2 - with argument forwarding - is expected to eq 1 - with multiple regular arguments - is expected to eq 2 - with a single rest argument - is expected to eq 1 - with a single regular argument - is expected to eq 1 - with no arguments - is expected to be empty - #method_name - with a unary method - is expected to eq :-@ - with a setter method - is expected to eq :foo= - 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 - #bang_method? - with a regular method - is expected not to be bang method - with a predicate method - is expected not to be bang method - with a bang method - is expected to be bang 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 - #first_argument - with multiple mixed arguments - is expected to be arg type - with a single regular argument - is expected to be arg type - with no arguments - is expected to be nil - with a single keyword argument - is expected to be kwoptarg type - with multiple regular arguments - is expected to be arg type - with a single rest argument - is expected to be restarg type - #rest_argument? - with mixed arguments - is expected to be rest argument + #implicit_call? + is expected not to be implicit call + #parenthesized? + with arguments + when not using parentheses + is expected not to be parenthesized + when using parentheses + is expected to be parenthesized with no arguments - is expected not to be rest argument - with a rest argument - is expected to be rest argument - with regular arguments - is expected not to be rest argument - .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 - #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 - with a class method definition - is expected not to be const receiver - #predicate_method? - with a predicate method - is expected to be predicate method - with a bang method - is expected not to be predicate method - with a regular method - is expected not to be predicate method - #receiver - with a singleton method definition - is expected to be const type - with a class method definition - is expected to be self type - with an instance method definition - is expected to be nil - #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 a comparison method - is expected not to be assignment method - with an assignment method - is expected to be assignment method - #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 - with an instance method definition - is expected not to be self receiver - #operator_method? - with a setter 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 regular method - is expected not to be operator 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 + when not using parentheses + is expected not to be parenthesized + when using parentheses + is expected to be parenthesized #arguments? - with multiple mixed arguments - is expected to be arguments - with a single rest argument + with a single splat argument is expected to be arguments - with a single keyword argument + with a single literal argument is expected to be arguments with no arguments is expected not to be arguments - with multiple regular arguments + with multiple literal arguments is expected to be arguments - with a single regular argument + with multiple mixed arguments is expected to be arguments + #macro? + is expected not to be macro + .new + is expected to be a kind of RuboCop::AST::YieldNode + #command? + when argument is a symbol + is expected to be command :yield + when argument is a string + is expected to be command "yield" + #last_argument + with multiple mixed arguments + is expected to be splat type + with a single splat argument + 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 #method? when message matches when argument is a string - is expected to be method "bar" + is expected to be method "yield" when argument is a symbol - is expected to be method :bar + 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" - #last_argument - with a single keyword argument - is expected to be kwoptarg type - with multiple mixed arguments - is expected to be restarg type - with multiple regular arguments - is expected to be arg type - with a single rest argument - is expected to be restarg type - with a single regular argument - is expected to be arg type + when argument is a symbol + is expected not to be method :foo + #block_argument? + is expected not to be block argument + #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 to be nil + is expected not to be splat argument + #receiver + is expected to be nil + #method_name + is expected to eq :yield + #const_receiver? + is expected not to be const receiver + #bang_method? + is expected not to be bang method #comparison_method? - with a regular method - is expected not to be comparison method - with a comparison method - is expected to be comparison method - #endless? - with standard method definition - is expected not to be endless - with endless method definition - is expected to be endless + is expected not to be comparison method + #assignment_method? + is expected not to be assignment method + #double_colon? + is expected not to be double colon + #predicate_method? + is expected not to be predicate method + #self_receiver? + is expected not to be self receiver + #block_literal? + is expected not to be block literal -RuboCop::AST::RangeNode +RuboCop::AST::CasgnNode + #name + is expected to eq :VAR .new - with an infinite range - is expected to be a kind of RuboCop::AST::RangeNode - is expected to be range type - with an exclusive range - is expected to be a kind of RuboCop::AST::RangeNode - is expected to be range type - 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 + with a `casgn` node + is expected to be a kind of RuboCop::AST::CasgnNode + #expression + is expected to eq s(:send, nil, :value) + #namespace + when the parent is a `cbase` + is expected to eq s(:cbase) + when there is no parent + is expected to be nil + when the parent is a `const` + is expected to eq s(:const, nil, :FOO) + +RuboCop::AST::NextNode + behaves like wrapped arguments node + .new + without arguments + is expected to be a kind of RuboCop::AST::NextNode + with arguments + is expected to be a kind of RuboCop::AST::NextNode + #arguments + with no arguments + 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 + with a single splat argument + is expected to eq 1 + with a single argument + is expected to eq 1 + with no arguments and braces + is expected to be empty + +RuboCop::AST::DefinedNode + #method_name + is expected to eq :defined? + #receiver + is expected to be nil + #arguments + is expected to all be sym type + is expected to eq 1 + .new + with a defined? node + is expected to be a kind of RuboCop::AST::DefinedNode RuboCop::AST::AliasNode - #old_identifier + #new_identifier + is expected to eq :foo is expected to be sym type + #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::NodePattern - nil - against a node pattern (bug #5470) - behaves like nonmatching - doesn't match - nil value in AST, use nil? method - is expected to match code nil and :foo - nil value in AST - behaves like nonmatching - doesn't match - nil literals - is expected to match code - caret (ascend) - inside an intersection - is expected to match code 1 - inside a union - is expected to match code "abc" - 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 - repeated twice - is expected to match code 1 - using unification to match self within parent - with self in the right position - is expected to match code 2 - with self in the wrong position - behaves like nonmatching - doesn't match - used with a node type - which doesn't match - behaves like nonmatching - doesn't match - which matches - is expected to match code 1 - simple sequence - 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 - on a node with the same type and non-matching children - with non-matching receiver type + repeated + using + + 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 + 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 + with zero match behaves like nonmatching doesn't match - with non-matching selector + using ? + with too many matching children 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 - repeated - using * - without capture - is expected to match code s(:sym, :hello), s(:int, 1), s(:int, 2), and s(:int, 3) - nested with multiple subcaptures - 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 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 behaves like repeated pattern with one match behaves like single capture @@ -4859,407 +5548,463 @@ is expected to match code "[:hello, 1, 2, 3]" 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 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 * with no match behaves like nonmatching doesn't match - using ? - with zero match + 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 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 - 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]" + returns captured values if there is no block at beginning of sequence behaves like invalid is invalid - with too many matching children - behaves like nonmatching - doesn't match - using + + 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 + returns captured values if there is no block + yields captured value(s) and returns true if there is a 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 - 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 - .descend - yields all children depth first - yields the given argument if it is not a Node - 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 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 - at the top level - containing string literals - is expected to match code s(:str, "a") and :upcase - containing integer literals - is expected to match code s(:int, 10) and :abs - containing mixed node and literals - is expected to match code nil and :obj - containing multiple [] - 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 - 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 variadic 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 fixed arity before and after union works for cases with variadic terms after union with variadic terms - works for cases with variadic terms before and after union 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 multiple works for complex cases - captures on ... - with a remaining capture at the end - behaves like multiple capture + nested inside a sequence + is expected to match code s(:const, nil, :Const) and :method + with a nested sequence + is expected to match code s(:const, nil, :Const) and :method + at the top level + 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 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 first [] + is expected to match code 3 + on a node which meets all requirements of the second [] + is expected to match code 2.4 + 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 string literals + is expected to match code s(:str, "a") and :upcase + captures which also perform a match + 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 - with a remaining wildcard at the end + 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 - with a remaining set at the end + on [] 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 + 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 - at the very beginning of a sequence + 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 + 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 - with a remaining literal at the end + nil + nil literals + is expected to match code + nil value in AST, use nil? method + is expected to match code nil and :foo + nil value in AST + behaves like nonmatching + doesn't match + against a node pattern (bug #5470) + behaves like nonmatching + doesn't match + captures within union + on simple subpatterns 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 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 - with no remaining pattern at the end - behaves like single capture + 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 remaining [] at the end + 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 + 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 wildcard 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 + after a child + behaves like single capture returns captured values if there is no block - with remaining patterns at the end + 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 + with a remaining set at the end + behaves like single capture returns captured values if there is no block - with a remaining node type at the end + yields captured value(s) and returns true if there is a 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 - after a child + 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 - captures on a wildcard - at the root level + 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 - nested in any child + 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 - in head position in a sequence against literal (bug #5470) + 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 + 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 + 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 + .descend + yields the given argument if it is not a Node + yields all children depth first + macros + with a pattern without captures + def_node_search + returns the method name + without a predicate name + when called on matching code + returns an enumerator yielding the matches + when called on non-matching code + returns an enumerator yielding nothing + when it errors + raises an error with the right location + with a predicate name + when it errors + raises an error with the right location + 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 + def_node_matcher + returns the method name + when it errors + raises an error with the right location + when called on matching code + is expected to match code :hello + when called on non-matching code + 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 + 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 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 + 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 + 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 + caret (ascend) + repeated twice + 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 + using unification to match self within parent + with self in the right position + is expected to match code 2 + with self in the wrong position + behaves like nonmatching + doesn't match + within sequence + in head + is expected to match code 1 + of a sequence + is expected to match code 1 + 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 + inside a union + is expected to match code "abc" + inside an intersection + is expected to match code 1 + sequence with trailing ... + on a node with the same type and fewer children behaves like nonmatching doesn't match - in head position in a sequence against nil (bug #5470) + on a node with a different type behaves like nonmatching doesn't match - in head position in a sequence + 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 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 + descend + without match + behaves like nonmatching + doesn't match + with an immediate 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 a match multiple levels, depth first + behaves like single capture yields captured value(s) and returns true if there is a block - in a nested sequence + returns captured values if there is no block + 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 - in non-head position in a sequence + 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)) + simple sequence + 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 + on a node with a different type + behaves like nonmatching + doesn't match + 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 head position + behaves like invalid + is invalid + bare node type + on a node with a different type + behaves like nonmatching + doesn't match + on a node with the same type + is expected to match code s(:send, nil, :obj) and :method + marshal compatibility + is expected to match code s(:send, nil, :obj) and :method + #dup + is expected to match code s(:send, nil, :obj) and :method + yaml compatibility + is expected to match code s(:send, nil, :obj) and :method + #== + returns true iff the patterns are similar + #pattern + returns the pattern + #to_s + is instructive + on a node with a matching, hyphenated type + is expected to match code s(:lvasgn, :a), :+, and s(:int, 1) + ellipsis + at the very beginning of a sequence + is expected to match code s(:int, 10), :*, and s(:int, 1) + 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 nested sequence at the end, but no remaining child + behaves like nonmatching + doesn't match + preceding a capture 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 [] 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 + with a wildcard at the end, but no remaining child to match it + behaves like nonmatching + doesn't match + with a nodetype at the end, but no remaining child to match it + behaves like nonmatching + doesn't match node type for a child on a child litteral 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 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 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 - negation - on a string - with a non-matching symbol - is expected to match code s(:str, "bar") and :upcase - with a matching string - behaves like nonmatching - doesn't match - on a sequence - with a node with non-matching children - is expected to match code :@b and s(:int, 1) - with a matching node - behaves like nonmatching - doesn't match - with a node of different type - is expected to match code :@@a 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 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) - when nested in complex ways - with (send int :- int) - is expected to match code s(:int, 1), :-, and s(:int, 1) - 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 - on a symbol - with a non-matching symbol - is expected to match code s(:send, nil, :obj) and :xyz - with a non-matching symbol, but too many children - behaves like nonmatching - doesn't match - with a matching symbol - behaves like nonmatching - doesn't match - predicates - 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" - with a named argument - when not given - raises an error - 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} - with extra arguments - raises an error - with a constant 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, 1), :+, and s(:int, 2) - applied to an integer for which the predicate is false + commas + with commas randomly strewn around + behaves like invalid + is invalid + captures on a wildcard + in head position in a sequence against nil (bug #5470) behaves like nonmatching doesn't match - at head position of a sequence - is expected to match code s(:int, 1) and :inc - applied to an integer for which the predicate is true - is expected to match code s(:int, 1) and :inc - 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 - when captured + 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 - when negated - 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 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 - 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 - literals - single quoted string literals - is expected to match code "foo" - negative integer literals - is expected to match code -100 - positive float literals - is expected to match code 1.0 - negative float literals - is expected to match code -2.5 - double quoted string literals - is expected to match code "foo" - symbol 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 - captures within union - with complex nesting - behaves like multiple capture + 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 - with a different number of captures in each branch - behaves like invalid - is invalid - on simple subpatterns + in a nested 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 - within nested sequences - behaves like multiple capture + yields captured value(s) and returns true if there is a 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 - funcalls - 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" - without extra arguments - is expected to match code :a and s(:int, 1) - bad syntax - with unmatched opening paren - behaves like invalid - is invalid - with unsupported subsequence in seq head within union - behaves like invalid - is invalid - with variadic unions where not supported - behaves like invalid - is invalid - with unmatched opening curly - behaves like invalid - is invalid - with unmatched closing paren - behaves like invalid - is invalid - with empty union subsequence in seq head - behaves like invalid - is invalid - with empty intersection - behaves like invalid - is invalid - with negated ellipsis - behaves like invalid - is invalid - with negated closing paren - behaves like invalid - is invalid - with unmatched closing curly - behaves like invalid - is invalid - with leading comma in arg list - behaves like invalid - is invalid - with negated closing curly - behaves like invalid - is invalid - with empty union - behaves like invalid - is invalid - with unmatched opening paren and `...` - behaves like invalid - is invalid - with doubled ellipsis - is expected to match code "foo" - with doubled comma in arg list - behaves like invalid - is invalid - with empty parentheses - behaves like invalid - is invalid - 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 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 fewer children, with a wildcard preceding + in head position in a sequence against literal (bug #5470) 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) + 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 wildcards named wildcards in head position of a sequence is expected to match code s(:int, 1), :+, and s(:send, nil, :a) within a union + confined to the union + with partial unification + 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) + that can not be unified + behaves like nonmatching + doesn't match + without unification + 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 @@ -5269,52 +6014,41 @@ s(:int, 2), s(:int, 1)) with a succeeding unifying constraint + with branches without the wildcard + encountered first + behaves like invalid + is invalid + encountered after + behaves like invalid + is invalid 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) + that can not be unified + behaves like nonmatching + doesn't match 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 after - behaves like invalid - is invalid - encountered first - behaves like invalid - is invalid - 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) - within a sequence - unifying the node type with an argument - is expected to match code s(:send, nil, :obj) and :send - 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 + within a sequence with other patterns intervening + is expected to match code :@abc and s(:int, 22) at the root level is expected to match code s(:sclass, s(:self), s(:def, :something, s(:args), s(:int, 1))) and :freeze - within a sequence with other patterns intervening - is expected to match code :@abc and s(:int, 22) + within a sequence + 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 + with values which can be unified + is expected to match code s(:int, 5), :+, and s(:int, 5) unnamed wildcards negated behaves like nonmatching @@ -5325,953 +6059,423 @@ s(:def, :something, s(:args), s(:int, 1))) and :freeze - within a sequence with other patterns intervening - is expected to match code :@abc and s(:int, 22) - in head position of a sequence - is expected to match code s(:int, 1), :+, and s(:send, nil, :a) within a sequence is expected to match code nil and :Const - ellipsis - at the very beginning of a sequence - is expected to match code s(:int, 10), :*, and s(:int, 1) - with [] 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 - returns captured values if there is no block - yields captured value(s) and returns true if there is a block - with a wildcard at the end, but no remaining child to match it - behaves like nonmatching - doesn't match - with a nodetype at the end, but no remaining child to match it - 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 nested sequence at the end, but no remaining child + 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) + negation + 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 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 string + with a non-matching symbol + is expected to match code s(:str, "bar") and :upcase + with a matching string + 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) + 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 + when nested in complex ways + with (send int :- int) + is expected to match code s(:int, 1), :-, and s(:int, 1) + 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 + regexp + matches symbols or strings + params + when inside a union, with a nonmatching value behaves like nonmatching doesn't match - bare node type - #dup - is expected to match code s(:send, nil, :obj) and :method - #to_s - is instructive - yaml compatibility - is expected to match code s(:send, nil, :obj) and :method - marshal compatibility - 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) - #pattern - returns the pattern - #== - returns true iff the patterns are similar - on a node with a different type + when negated, with a matching value behaves like nonmatching doesn't match - on a node with the same type - is expected to match code s(:send, nil, :obj) and :method - params + when preceded by ... + is expected to match code s(:send, + s(:int, 1), :+, + s(:int, 10)) and s(:int, 10) + when inside an intersection + is expected to match code s(:int, 20), 10, and 20 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 preceded by $... - 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 - 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 # + without explicit number + is expected to match code s(:const, + s(:const, nil, :Namespace), :A), :A, and s(:const, nil, :Namespace) + 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 + in a nested sequence + is expected to match code s(:send, + s(:send, + s(:int, 5), :dec), :inc), :inc, and :dec as named parameters when extra are provided raises an ArgumentError when provided as argument to match - is expected to match code s(:int, 10) and {:foo=>#} + is expected to match code s(:int, 10) and {:foo=>#} when not provided raises an ArgumentError - when inside a union, with a nonmatching 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 - param number zero - in a position which does not match original target node + when preceded by $... + 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 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 inside a union, with a matching value + is expected to match code s(:int, 10) and 10 + literals + single quoted string literals + is expected to match code "foo" + negative integer literals + is expected to match code -100 + positive float literals + is expected to match code 1.0 + negative float literals + is expected to match code -2.5 + bare literal + on a matching literal + is expected to match code :bar + on a node behaves like nonmatching doesn't match - in a position which matches original target node - is expected to match code 1 - when preceded by ... - is expected to match code s(:send, + symbol literals + is expected to match code :foo + double quoted string literals + is expected to match code "foo" + predicates + when in last-child position, but all children have already been matched + 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, 10)) and s(:int, 10) - without explicit number - is expected to match code s(:const, - s(:const, nil, :Namespace), :A), :A, and s(:const, nil, :Namespace) - when negated, with a matching value + s(:int, 2)) and 1 + for which the predicate is false + behaves like nonmatching + doesn't match + with a constant 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, 1), :+, and s(:int, 2) + applied to an integer for which the predicate is true + is expected to match code s(:int, 1) and :inc + 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 + 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 + with multiple arguments + for which the predicate is true + is expected to match code s(:str, "c"), "a", and "d" + for which the predicate is false + behaves like nonmatching + doesn't match + 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} + for which the predicate is false + behaves like nonmatching + doesn't match + with extra arguments + raises an error + when not given + raises an error + at head position of a sequence + 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 - in a nested sequence - is expected to match code s(:send, - s(:send, - s(:int, 5), :dec), :inc), :inc, and :dec - when inside an intersection - is expected to match code s(:int, 20), 10, and 20 in any order 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 - yields captured value(s) and returns true if there is a block returns captured values if there is no block - with a captured ellipsis - nested + 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 - 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 - 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 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 + returns captured values if there is no block + yields captured value(s) and returns true if there is a block + with a captured ellipsis + 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 - with too few children - behaves like nonmatching - doesn't match - 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 - captured - without ellipsis + 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 + 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 invalid - doubled with ellipsis in wrong order - behaves like nonmatching - doesn't match - doubled with ellipsis + 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 at the beginning of a sequence behaves like invalid is invalid + doubled with 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 nested behaves like invalid is invalid + doubled with ellipsis in wrong order + behaves like nonmatching + doesn't match 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 - 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 non-matching code - behaves like nonmatching - doesn't match - when called on matching code - is expected to match code :hello - when it errors - raises an error with the right location - def_node_search - returns the method name - with a predicate name - when it errors - raises an error with the right location - when called on non-matching code - behaves like nonmatching - doesn't match - when called on matching code - is expected to match code nil, :foo, s(:sym, :hello), and s(:sym, :world) - 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 captures - def_node_matcher - when called on matching code - is expected to eq :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 - 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 - 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 - with a predicate name - when it errors - raises an error with the right location - 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 - 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 - commas - with commas randomly strewn around - behaves like invalid - is invalid - captures which also perform a match - 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 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 - 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 - 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 - 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 - 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 - 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)) - nested + 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 - -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::SelfClassNode - .new - is expected to be a kind of RuboCop::AST::SelfClassNode - #identifier - is expected to be self type - #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::PairNode - #value_delta - when using hash rocket delimiters - 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 both pairs are on the same line - 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 using colon delimiters - when receiver value is ahead - 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 behind - is expected to eq -2 - when both pairs are on the same line - is expected to eq 0 - #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 ":" - #hash_rocket? - when using a hash rocket delimiter - is expected to be hash rocket - when using a colon delimiter - is expected not to be hash rocket - #key - when using a string key - is expected to be str type - when using a symbol key - is expected to be sym type - .new - is expected to be a kind of RuboCop::AST::PairNode - #same_line? - when both pairs are on the same line - when both pair is a keyword splat - 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, :b), - s(:int, 2)) - when pairs are on separate lines - when last pair is a keyword splat - is expected not to be same line s(:kwsplat, - s(:send, nil, :foo)) - when both pairs are explicit pairs - is expected not to be same line s(:pair, - s(:sym, :b), - s(:int, 2)) - 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)) - #key_delta - with alignment set to :right - 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 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 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 keys are aligned - when both keys are explicit keys - is expected to eq 0 - when second key is a keyword splat - 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 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 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 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 - with alignment set to :left - 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 -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 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 using hash rocket delimiters - 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 explicit pairs - is expected to eq -2 - 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 key is a keyword splat - is expected to eq 0 - when both keys are explicit keys - is expected to eq 0 - #value_on_new_line? - when pair is on a single line - 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 value spans multiple lines - 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 " => " - #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 - #colon? - when using a hash rocket delimiter - is expected not to be colon - when using a colon delimiter - is expected to be colon - #value - is expected to be int type - -RuboCop::AST::Node - #class_constructor? - module definition with a block - matches - class definition on outer scope - matches - class definition with a block - matches - class definition - does not match - #module_definition? - namespaced modules - matches - included module definition - matches - with ::ModuleName - matches - using module keyword - matches - with Module.new - matches - when using numbered parameter - matches - nested modules - matches - prepend Module.new - matches - #struct_constructor? - struct definition with a block - matches - struct definition without block - does not match - ::Struct - matches - #recursive_basic_literal? - behaves like literal - returns true for `1.0` - behaves like literal - returns true for `/./` - behaves like non literal - returns false for `{ :sym => some_method_call }` - behaves like literal - returns true for `{ a: 1, b: 2 }` - behaves like non literal - returns false for `{ some_method_call => :sym }` - behaves like non literal - returns false for `some_method_call(x, y)` - behaves like literal - returns true for `[1, 2, 3]` - behaves like non literal - returns false for `[some_method_call]` - behaves like literal - returns true for `"#{2}"` - behaves like literal - returns true for `(false <=> true)` - behaves like literal - returns true for `(1)` - behaves like literal - returns true for `{ :a => 1, :b => 2 }` - behaves like literal - returns true for `1` - behaves like literal - returns true for `false` - behaves like literal - returns true for `(false or true)` - behaves like non literal - returns false for `some_method_call` - behaves like non literal - returns false for `/.#{some_method_call}/` - behaves like non literal - returns false for `(x == false)` - behaves like literal - returns true for `(false && true)` - behaves like non literal - returns false for `%r{abx#{foo}}ixo` - behaves like literal - returns true for `%r{abx}ixo` - 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 `'str'` - behaves like literal - returns true for `nil` - behaves like literal - returns true for `!true` - #pure? - for an array literal - with only literal children - returns true - which contains a method call - returns false - for a method call - returns false - for a class definition - returns false - for a cvar assignment - returns false - for a module definition - returns false - for an lvar assignment - returns false - for an ivar assignment - returns false - for a hash literal - which contains a method call - returns false - with only literal children - returns true - for a gvar assignment - returns false - for an integer literal - returns true - for a regexp - with interpolated segments - returns false - with options - returns true - with no interpolation - returns true - for a nested if - where one branch contains an assignment statement - returns false - where one branch contains a method call - returns false - where the innermost descendants are local vars and literals - returns true - #argument_type? - method arguments - returns true for all argument types - block arguments - returns true for all argument types - #parent_module_name - when node on top level - is expected to eq "Object" - when node on singleton class - is expected to eq "Foo::#" - when node on module - is expected to eq "Foo" - when node on class in singleton class - is expected to eq "Foo::#::Bar" - when node nested in an unknown block - is expected to be nil - when node nested in a class << exp - is expected to be nil - #conditional? - when `until` node - is true - when `while` node - is true - when `case` node - is true - when `if` node - is true - when `case_match` node - is true - when post condition loop node - is false - #value_used? - 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 end of a block - is always true - at the top level - is false - within a method call node - is always true - within a module definition node - is always true - within a while node - is true only for the condition - within a class definition node - is always true - within a singleton class node - is always true - within an array literal - assigned to an ivar - is always true - at the top level - is always false - sibling_access - returns trivial values for a root node - for a single child - returns the expected values - for a node with siblings - returns the expected values - #numeric_type? - when complex literal whose imaginary part is a rational - is true - when complex literal - is true - when string literal - is true - when integer literal - is true - when rational literal - is true - when float literal - is true - #class_definition? - with Struct - matches - when using numbered parameter - matches - with inheritance - matches - with object singleton class - matches - with ::ClassName - matches - with Class.new - matches - when using numbered parameter - matches - namespaced class - matches - constant defined as Struct without block - does not match - with self singleton class - matches - without inheritance - matches - -RuboCop::AST::ForwardArgsNode - when using Ruby 2.7 or newer - #to_a - is expected to contain exactly (be forward arg type) - -RuboCop::AST::BreakNode - behaves like wrapped arguments node - .new - with arguments - is expected to be a kind of RuboCop::AST::BreakNode - without arguments - is expected to be a kind of RuboCop::AST::BreakNode - #arguments - with a single argument - is expected to eq 1 - 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 multiple literal arguments - is expected to eq 2 - with no arguments and braces - is expected to be empty - -RuboCop::AST::NodePattern::Lexer - provides tokens via next_token - when given a regexp ending with a backslash - does not lexes it properly - when given node types and constants - distinguishes them - when given a regexp /test/ - round trips - when given a regexp /[abc]+\/()?/x - round trips - when given arithmetic symbols - is parsed as `:&` - with $type+ - is parsed as `$ int + x` - when given a regexp /back\\slash/ - round trips + 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 + bad syntax + with negated ellipsis + behaves like invalid + is invalid + with empty parentheses + behaves like invalid + is invalid + with unmatched closing paren + behaves like invalid + is invalid + with leading comma in arg list + behaves like invalid + is invalid + with empty union subsequence in seq head + behaves like invalid + is invalid + with variadic unions where not supported + behaves like invalid + is invalid + with unmatched opening paren + behaves like invalid + is invalid + with negated closing curly + behaves like invalid + is invalid + with empty union + behaves like invalid + is invalid + with unsupported subsequence in seq head within union + behaves like invalid + is invalid + with negated closing paren + behaves like invalid + is invalid + with unmatched opening curly + behaves like invalid + is invalid + with unmatched closing curly + behaves like invalid + is invalid + with empty intersection + behaves like invalid + is invalid + with doubled comma in arg list + behaves like invalid + is invalid + with unmatched opening paren and `...` + behaves like invalid + is invalid + with doubled ellipsis + is expected to match code "foo" RuboCop::AST::InPatternNode when using Ruby 2.7 or newer - #body - without a then keyword - is expected to be array type - with a then keyword - is expected to be sym 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 + #branch_index + is expected to eq 1 + is expected to eq 0 + is expected to eq 2 #pattern with an array pattern is expected to be array pattern type - with a value pattern - is expected to be int type - with an alternative pattern - is expected to be match alt type - with a pin operator - is expected to be pin type - with an as pattern - is expected to be match as type with a variable pattern is expected to be match var type with a hash pattern is expected to be hash pattern type - #branch_index - is expected to eq 1 - is expected to eq 2 - is expected to eq 0 - -RuboCop::AST::Procarg0Node - .new - with a block - is expected to be a kind of RuboCop::AST::ArgNode - #name - is expected to eq :x - -RuboCop::AST::ForNode - #variable - is expected to be lvasgn type - #body - is expected to be sym type - #loop_keyword? - is expected to be loop keyword - #keyword - is expected to eq "for" - .new - is expected to be a kind of RuboCop::AST::ForNode - #post_condition_loop? - is expected not to be post condition loop - #collection - is expected to be sym type - #do? - without a do keyword - is expected not to be do - with a do keyword - is expected to be do - #void_context? - without a do keyword - is expected to be void context - with a do keyword - is expected to be void context - -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 argument - is expected to eq 1 - with a single argument and braces - is expected to eq 1 - with multiple literal arguments - is expected to eq 2 - with no arguments - is expected to be empty - with no arguments and braces - is expected to be empty - with a single splat argument - is expected to eq 1 - -RuboCop::AST::EnsureNode - #body - is expected to be sym type - .new - is expected to be a kind of RuboCop::AST::EnsureNode - -RuboCop::AST::CaseMatchNode - when using Ruby 2.7 or newer - #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 - #in_pattern_branches - is expected to eq 3 - is expected to all be in pattern type - #keyword - is expected to eq "case" - #each_in_pattern - when passed a block - yields all the conditions - when not passed a block - is expected to be a kind of Enumerator - .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::NextNode - behaves like wrapped arguments node - #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 a single argument - is expected to eq 1 - with no arguments and braces - is expected to be empty - with a single splat argument - is expected to eq 1 - .new - without arguments - is expected to be a kind of RuboCop::AST::NextNode - with arguments - is expected to be a kind of RuboCop::AST::NextNode + with a pin operator + is expected to be pin type + with an as pattern + is expected to be match as type + with an alternative pattern + is expected to be match alt type + with a value pattern + is expected to be int type + #body + without a then keyword + is expected to be array type + with a then keyword + is expected to be sym type + #then? + without a then keyword + is expected not to be then + with a then keyword + is expected to be then -RuboCop::AST::RescueNode - #else_branch - without an else statement - is expected to be nil - with an else statement - is expected to be send type - #resbody_branches - is expected to all be resbody type - is expected to eq 2 - #body - is expected to be send type +RuboCop::AST::KeywordSplatNode + #colon? + is expected not to be colon + #hash_rocket? + is expected not to be hash rocket + #value + is expected to eq s(:kwsplat, + s(:send, nil, :foo)) .new - is expected to be a kind of RuboCop::AST::RescueNode - #else? - without an else statement - is expected not to be else - with an else statement - is expected to be else - #branches - when there is an else - returns all the bodies - with an empty else - returns all the bodies - when there is no else keyword - returns only then rescue bodies + is expected to be a kind of RuboCop::AST::KeywordSplatNode + #key_delta + with alignment set to :left + when using hash rocket 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 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 + with alignment set to :right + 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 aligned + is expected to eq 0 + when using hash rocket delimiters + when keyword splat is on the same line + is expected to eq 0 + 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 + #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(:pair, + s(:sym, :a), + s(:begin)) + is expected to be same line s(:kwsplat, + s(:send, nil, :foo)) + when both pairs are on the same line + is expected to be same line s(:kwsplat, + s(:send, nil, :foo)) + #value_delta + when using colon delimiters + 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 ahead + is expected to eq 0 + when keyword splat is on the same line + is expected to eq 0 + when using hash rocket delimiters + when keyword splat is on the same line + is expected to eq 0 + when keyword splat is behind + 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 + is expected to eq s(:kwsplat, + s(:send, nil, :foo)) RuboCop::AST::ModuleNode .new @@ -6286,252 +6490,84 @@ with an empty body is expected to be nil -RuboCop::AST::CaseNode - #each_when +RuboCop::AST::HashNode + #pairs + with a hash of literals + is expected to eq 3 + is expected to all be pair type + 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 + #each_pair + when passed a block + yields all the pairs when not passed a block is expected to be a kind of Enumerator - when passed a block - yields all the conditions - #branches - when compared to an IfNode - returns the same - when there is an else - returns all the bodies - with an empty else - returns all the bodies - when there is no else keyword - returns only then when bodies - #else? - without an else statement - is expected not to be else - with an else statement - is expected to be else - #when_branches - is expected to all be when type - is expected to eq 3 - #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 nil - .new - is expected to be a kind of RuboCop::AST::CaseNode - -RuboCop::AST::ConstNode - #short_name - is expected to eq :BAZ - #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 - #namespace - is expected to eq "::Foo::Bar" - #each_path - yields all parts of the namespace - #relative? - with a non-namespaced constant - is expected to be relative - #module_name? - is expected not to be module name - with a constant with a lowercase letter - is expected to be module name - -RuboCop::AST::NodePattern::Sets - 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" - is expected to eq "::RuboCop::AST::NodePattern::Sets::SET_1_2_3_ETC" - -RuboCop::AST::IntNode - .new - is expected to be a kind of 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 - -RuboCop::AST::FloatNode - .new - is expected to be a kind of 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 - -RuboCop::AST::LambdaNode - #method_name - is expected to eq :lambda - #arguments - is expected to eq 2 - #receiver - is expected to be nil - -RuboCop::AST::UntilNode - .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 - #loop_keyword? - with a statement until - is expected to be loop keyword - with a modifier until - 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 until - is expected to be post condition loop - with a statement until - is expected not to be post condition loop - #inverse_keyword - is expected to eq "while" - #keyword - is expected to eq "until" - -RuboCop::AST::BlockNode - #opening_delimiter - when enclosed in braces - is expected to eq "{" - when enclosed in do-end keywords - is expected to eq "do" + #keys + 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 + with an empty hash + is expected to be empty #braces? - when enclosed in braces - is expected to be braces - when enclosed in do-end keywords + as an argument with no braces is expected not to be braces - #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 - when block method is tap - is expected to be void context - #keywords? - when enclosed in do-end keywords - is expected to be keywords - when enclosed in braces - is expected not to be keywords - #closing_delimiter - when enclosed in braces - is expected to eq "}" - when enclosed in do-end keywords - is expected to eq "end" - #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 - #arguments? - with a single splat argument - is expected to be arguments - with a single argument - 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 - #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 - #arguments - with multiple mixed arguments - is expected to eq 2 - >= Ruby 2.7 - using numbered parameters - is expected to be empty - with a single splat argument - is expected to eq 1 - with no arguments + with braces + is expected to be braces + as an argument with braces + is expected to be braces + #empty? + with an empty hash is expected to be empty - with destructured arguments - is expected to eq 2 - with a single literal argument - is expected to eq 1 - .new - is expected to be a kind of RuboCop::AST::BlockNode - #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 - #delimiters - when enclosed in braces - is expected to eq ["{", "}"] - when enclosed in do-end keywords - is expected to eq ["do", "end"] - #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 + with a hash containing pairs + is expected not to be empty + with a hash containing a keyword splat + is expected not to be empty + #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 + when all pairs are using a colon delimiter + is expected not to be mixed delimiters + #each_value + when not passed a block + is expected to be a kind of Enumerator + when passed a block + yields all the pairs + #each_key + when passed a block + yields all the pairs + when not passed a block + is expected to be a kind of Enumerator + #pairs_on_same_line? + with some 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 all pairs on the same line + is expected to be pairs on same line + #values + with an empty hash is expected to be empty - all argument types - is expected to eq [:a, :b, :c, :d, :e, :f, :g, :h, :i] - #receiver - with safe navigation operator call - is expected to eq "foo" - with dot operator call - is expected to eq "foo" - -RuboCop::AST::WhileNode + with a hash with string keys + is expected to all be send type + is expected to eq 2 + with a hash with literal values + is expected to eq 3 + is expected to all be literal .new - with a modifier while - is expected to be a kind of RuboCop::AST::WhileNode - with a statement while - is expected to be a kind of 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 statement while - is expected not to be post condition loop - with a modifier while - is expected to be post condition loop - #keyword - is expected to eq "while" + is expected to be a kind of RuboCop::AST::HashNode -Finished in 10.63 seconds (files took 4.01 seconds to load) +Finished in 9.59 seconds (files took 3.92 seconds to load) 2392 examples, 0 failures -Randomized with seed 28886 +Randomized with seed 30384 ┌──────────────────────────────────────────────────────────────────────────────┐ @@ -6566,12 +6602,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/14701/tmp/hooks/B01_cleanup starting +I: user script /srv/workspace/pbuilder/14701/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/31364 and its subdirectories -I: Current time: Tue Dec 3 11:10:30 -12 2024 -I: pbuilder-time-stamp: 1733267430 +I: removing directory /srv/workspace/pbuilder/14701 and its subdirectories +I: Current time: Wed Dec 4 13:12:36 +14 2024 +I: pbuilder-time-stamp: 1733267556