Diff of the two buildlogs: -- --- b1/build.log 2024-05-20 17:43:37.625797677 +0000 +++ b2/build.log 2024-05-20 17:44:56.542438700 +0000 @@ -1,6 +1,6 @@ I: pbuilder: network access will be disabled during build -I: Current time: Mon May 20 05:42:08 -12 2024 -I: pbuilder-time-stamp: 1716226928 +I: Current time: Mon Jun 23 14:06:38 +14 2025 +I: pbuilder-time-stamp: 1750637198 I: Building the build Environment I: extracting base tarball [/var/cache/pbuilder/unstable-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/3429604/tmp/hooks/D02_print_environment starting +I: user script /srv/workspace/pbuilder/3490227/tmp/hooks/D01_modify_environment starting +debug: Running on ionos5-amd64. +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 Jun 23 00:06 /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/3490227/tmp/hooks/D01_modify_environment finished +I: user script /srv/workspace/pbuilder/3490227/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='amd64' - DEBIAN_FRONTEND='noninteractive' - DEB_BUILD_OPTIONS='buildinfo=+all reproducible=+all parallel=20 ' - DISTRIBUTION='unstable' - HOME='/root' - HOST_ARCH='amd64' + 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]="21" [3]="1" [4]="release" [5]="x86_64-pc-linux-gnu") + BASH_VERSION='5.2.21(1)-release' + BUILDDIR=/build/reproducible-path + BUILDUSERGECOS='second user,second room,second work-phone,second home-phone,second other' + BUILDUSERNAME=pbuilder2 + BUILD_ARCH=amd64 + DEBIAN_FRONTEND=noninteractive + DEB_BUILD_OPTIONS='buildinfo=+all reproducible=+all parallel=42 ' + DIRSTACK=() + DISTRIBUTION=unstable + EUID=0 + FUNCNAME=([0]="Echo" [1]="main") + GROUPS=() + HOME=/root + HOSTNAME=i-capture-the-hostname + HOSTTYPE=x86_64 + HOST_ARCH=amd64 IFS=' ' - INVOCATION_ID='7913afa00fe34b7f9f74131387bbe119' - 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='3429604' - PS1='# ' - PS2='> ' + INVOCATION_ID=5ca667b8c3294346a8a74084ca399546 + LANG=C + LANGUAGE=et_EE:et + LC_ALL=C + MACHTYPE=x86_64-pc-linux-gnu + MAIL=/var/mail/root + OPTERR=1 + OPTIND=1 + OSTYPE=linux-gnu + PATH=/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/i/capture/the/path + PBCURRENTCOMMANDLINEOPERATION=build + PBUILDER_OPERATION=build + PBUILDER_PKGDATADIR=/usr/share/pbuilder + PBUILDER_PKGLIBDIR=/usr/lib/pbuilder + PBUILDER_SYSCONFDIR=/etc + PIPESTATUS=([0]="0") + POSIXLY_CORRECT=y + PPID=3490227 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.iY6wfZh2/pbuilderrc_nS68 --distribution unstable --hookdir /etc/pbuilder/first-build-hooks --debbuildopts -b --basetgz /var/cache/pbuilder/unstable-reproducible-base.tgz --buildresult /srv/reproducible-results/rbuild-debian/r-b-build.iY6wfZh2/b1 --logfile b1/build.log ruby-rubocop-ast_1.24.0-2.dsc' - SUDO_GID='111' - SUDO_UID='106' - SUDO_USER='jenkins' - TERM='unknown' - TZ='/usr/share/zoneinfo/Etc/GMT+12' - USER='root' - _='/usr/bin/systemd-run' - http_proxy='http://46.16.76.132:3128' + PWD=/ + SHELL=/bin/bash + SHELLOPTS=braceexpand:errexit:hashall:interactive-comments:posix + SHLVL=3 + SUDO_COMMAND='/usr/bin/timeout -k 24.1h 24h /usr/bin/ionice -c 3 /usr/bin/nice -n 11 /usr/bin/unshare --uts -- /usr/sbin/pbuilder --build --configfile /srv/reproducible-results/rbuild-debian/r-b-build.iY6wfZh2/pbuilderrc_TeMp --distribution unstable --hookdir /etc/pbuilder/rebuild-hooks --debbuildopts -b --basetgz /var/cache/pbuilder/unstable-reproducible-base.tgz --buildresult /srv/reproducible-results/rbuild-debian/r-b-build.iY6wfZh2/b2 --logfile b2/build.log ruby-rubocop-ast_1.24.0-2.dsc' + SUDO_GID=110 + SUDO_UID=105 + SUDO_USER=jenkins + TERM=unknown + TZ=/usr/share/zoneinfo/Etc/GMT-14 + UID=0 + USER=root + _='I: set' + http_proxy=http://213.165.73.152:3128 I: uname -a - Linux ionos11-amd64 6.1.0-21-amd64 #1 SMP PREEMPT_DYNAMIC Debian 6.1.90-1 (2024-05-03) x86_64 GNU/Linux + Linux i-capture-the-hostname 6.6.13+bpo-amd64 #1 SMP PREEMPT_DYNAMIC Debian 6.6.13-1~bpo12+1 (2024-02-15) x86_64 GNU/Linux I: ls -l /bin - lrwxrwxrwx 1 root root 7 May 19 07:43 /bin -> usr/bin -I: user script /srv/workspace/pbuilder/3429604/tmp/hooks/D02_print_environment finished + lrwxrwxrwx 1 root root 7 Jun 21 14:05 /bin -> usr/bin +I: user script /srv/workspace/pbuilder/3490227/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 unstable/main amd64 ruby-rspec-mocks all 3.13.0c0e0m0s1-2 [81.3 kB] Get: 138 http://deb.debian.org/debian unstable/main amd64 ruby-rspec all 3.13.0c0e0m0s1-2 [5184 B] Get: 139 http://deb.debian.org/debian unstable/main amd64 ruby-whitequark-parser all 3.1.3.0-1 [424 kB] -Fetched 43.3 MB in 1s (82.2 MB/s) +Fetched 43.3 MB in 1s (73.0 MB/s) debconf: delaying package configuration, since apt-utils is not installed Selecting previously unselected package libpython3.11-minimal:amd64. (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 ... 19718 files and directories currently installed.) @@ -724,8 +756,8 @@ Setting up tzdata (2024a-4) ... Current default time zone: 'Etc/UTC' -Local time is now: Mon May 20 17:42:56 UTC 2024. -Universal Time is now: Mon May 20 17:42:56 UTC 2024. +Local time is now: Mon Jun 23 00:07:28 UTC 2025. +Universal Time is now: Mon Jun 23 00:07:28 UTC 2025. Run 'dpkg-reconfigure tzdata' if you wish to change it. Setting up autotools-dev (20220109.1) ... @@ -851,7 +883,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/3490227/tmp/hooks/A99_set_merged_usr starting +Not re-configuring usrmerge for unstable +I: user script /srv/workspace/pbuilder/3490227/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 @@ -886,7 +922,7 @@ dh_prep -O--buildsystem=ruby dh_auto_install --destdir=debian/ruby-rubocop-ast/ -O--buildsystem=ruby dh_ruby --install /build/reproducible-path/ruby-rubocop-ast-1.24.0/debian/ruby-rubocop-ast -/usr/bin/ruby3.1 -S gem build --config-file /dev/null --verbose /tmp/d20240520-3437040-exzkuh/gemspec +/usr/bin/ruby3.1 -S gem build --config-file /dev/null --verbose /tmp/d20250623-3539655-tvw41z/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: @@ -896,7 +932,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/d20240520-3437040-exzkuh/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/d20250623-3539655-tvw41z/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 @@ -1023,1803 +1059,1434 @@ 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 8497 +Randomized with seed 55165 -RuboCop::AST::FloatNode - .new - is expected to be a kind of RuboCop::AST::FloatNode - #value - is expected to eq 1.5 - #sign? - explicit negative float - is expected to be sign - explicit positive float - is expected to be sign - -RuboCop::AST::Node - #class_definition? - with Struct - matches - when using numbered parameter - matches - with object singleton class - matches - with ::ClassName - matches - namespaced class - matches - constant defined as Struct without block - does not match - without inheritance - matches - with inheritance - matches - with self singleton class - matches - with Class.new - matches - when using numbered parameter - matches - #recursive_basic_literal? - behaves like literal - returns true for `"#{2}"` - behaves like non literal - returns false for `(x && false)` - behaves like literal - returns true for `{ :a => 1, :b => 2 }` - behaves like literal - returns true for `!true` - behaves like literal - returns true for `(false && true)` - behaves like literal - returns true for `(false <=> true)` - behaves like non literal - returns false for `{ some_method_call => :sym }` - behaves like literal - returns true for `%r{abx}ixo` - behaves like literal - returns true for `'str'` - behaves like literal - returns true for `1.0` - behaves like literal - returns true for `(false or true)` - behaves like non literal - returns false for `%r{abx#{foo}}ixo` - behaves like literal - returns true for `nil` - behaves like literal - returns true for `/./` - behaves like literal - returns true for `[1, 2, 3]` - behaves like non literal - returns false for `(x or false)` - behaves like non literal - returns false for `/.#{some_method_call}/` - behaves like non literal - returns false for `{ :sym => some_method_call }` - behaves like non literal - returns false for `(x == false)` - behaves like literal - returns true for `{ a: 1, b: 2 }` - behaves like non literal - returns false for `[some_method_call]` - behaves like literal - returns true for `(1)` - behaves like literal - returns true for `false` - behaves like literal - returns true for `1` - behaves like non literal - returns false for `some_method_call(x, y)` - behaves like non literal - returns false for `some_method_call` - #class_constructor? - class definition with a block - matches - class definition - does not match - class definition on outer scope - matches - module definition with a block - matches - #conditional? - when post condition loop node - is false - when `case` node - is true - when `if` node - is true - when `until` node - is true - when `case_match` node - is true - when `while` node - is true - #struct_constructor? - ::Struct - matches - struct definition with a block - matches - struct definition without block - does not match - #argument_type? - block arguments - returns true for all argument types - method arguments - returns true for all argument types - #value_used? - within a module definition node - is always true - within a class definition node - is always true - within an if...else..end node - at the top level - is true only for the condition - nested in a method call - is always true - within a method call node - is always true - at the end of a block - is always true - within a singleton class node - is always true - within an array literal - at the top level - is always false - assigned to an ivar - is always true - at the top level - is false - within a while node - is true only for the condition - #numeric_type? - when float literal - is true - when complex literal - is true - when integer literal - is true - when rational literal - is true - when string literal - is true - when complex literal whose imaginary part is a rational - is true - #pure? - for a method call - returns false - for an array literal - with only literal children - returns true - which contains a method call - returns false - for a gvar assignment - returns false - for a regexp - with interpolated segments - returns false - with options - returns true - with no interpolation - returns true - for an lvar assignment - returns false - for a nested if - where one branch contains a method call - returns false - where one branch contains an assignment statement - returns false - where the innermost descendants are local vars and literals - returns true - for an ivar assignment - returns false - for a class definition - returns false - for a module definition - returns false - for a cvar assignment - returns false - for a hash literal - which contains a method call - returns false - with only literal children - returns true - for an integer literal - returns true - #parent_module_name - when node on class in singleton class - is expected to eq "Foo::#::Bar" - 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 module - is expected to eq "Foo" - when node on top level - is expected to eq "Object" - when node nested in a class << exp - is expected to be nil - sibling_access - returns trivial values for a root node - for a node with siblings - returns the expected values - for a single child - returns the expected values - #module_definition? - with ::ModuleName - matches - prepend Module.new - matches - using module keyword - matches - nested modules - matches - namespaced modules - matches - with Module.new - matches - when using numbered parameter - matches - included module definition - matches - -RuboCop::AST::ForwardArgsNode - when using Ruby 2.7 or newer - #to_a - is expected to contain exactly (be forward arg type) - -RuboCop::AST::ArgsNode - .new - with a block - is expected to be a kind of RuboCop::AST::ArgsNode - with a method definition - is expected to be a kind of RuboCop::AST::ArgsNode - with a lambda literal - is expected to be a kind of RuboCop::AST::ArgsNode - #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 empty arguments - with a method definition - is expected to equal true - with a block - is expected to equal true - with a lambda literal - is expected to equal true - with arguments - with a lambda literal - is expected to equal false - with a method definition - is expected to equal false - with delimiters - with a block - is expected to equal false - with a method definition - is expected to equal false - with a lambda literal - is expected to equal false - -RuboCop::AST::IfNode - .new - 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 - with a regular if statement - is expected to be a kind of RuboCop::AST::IfNode - #modifier_form? - with a ternary operator - is expected not to be modifier form - with a modifier unless statement - is expected to be modifier form - with a modifier if statement - is expected to be modifier form - with a non-modifier if statement - is expected not to be modifier form - with a non-modifier unless statement - is expected not to be modifier form - #each_branch - when not passed a block - is expected to be a kind of Enumerator - when passed a block - yields all the branches - #elsif_conditional? - with one elsif conditional - is expected to be elsif conditional - with nested conditionals in if clause - is expected not to be elsif conditional - with nested ternary operators - when nested in the truthy branch - is expected not to be elsif conditional - when nested in the falsey branch - is expected not to be elsif conditional - with nested conditionals in else clause - is expected not to be elsif conditional - with multiple elsif conditionals - is expected to be elsif conditional - #if_branch - with an unless statement - is expected to be sym type - with a ternary operator - is expected to be sym type - with an if statement - is expected to be sym type - #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 - #branches - with a ternary operator - is expected to all be literal - is expected to eq 2 - with an if statement - is expected to eq 1 - is expected to all be literal - with an unless statement - is expected to all be literal - is expected to eq 1 - with an elsif statement - is expected to all be literal - is expected to eq 3 - with an else statement - is expected to eq 2 - is expected to all be literal - #else? - without an else statement - is expected not to be elsif - with an elsif statement - is expected to be else - #elsif? - with an if statement comtaining an elsif - is expected not to be elsif - with an elsif statement - is expected to be elsif - without an elsif statement - is expected not to be elsif - #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 ternary operators - when nested in the truthy branch - is expected to be nested conditional - when nested in the falsey branch - is expected to be nested conditional - with nested conditionals in elsif clause - is expected to be nested conditional - with nested conditionals in if clause - is expected to be nested conditional - #ternary? - with a ternary operator - is expected to be ternary - with an if statement - is expected not to be ternary - with an unless statement - is expected not to be ternary - #keyword - with a ternary operator - is expected to eq "" - with an if statement - is expected to eq "if" - with an unless statement - is expected to eq "unless" - #if? - with an if statement - is expected to be if - with a ternary operator - is expected not to be if - with an unless statement - is expected not to be if - #inverse_keyword? - with an if statement - is expected to eq "unless" - with a ternary operator - is expected to eq "" - with an unless statement - is expected to eq "if" - #unless? - with a ternary operator - is expected not to be unless - with an unless statement - is expected to be unless - with an if statement - is expected not to be unless - -RuboCop::AST::SendNode - #unary_operation? - with a regular method call - is expected not to be unary operation - with an implicit call method - is expected not to be unary operation - with a binary operation - is expected not to be unary operation - with a unary operation - is expected to be unary operation - #nonmutating_operator_method? - with a nonmutating binary operator method - is expected to be nonmutating operator method - with a mutating binary operator method - is expected not to be nonmutating operator method - with a nonmutating unary operator method - is expected to be nonmutating operator method - with a regular method - is expected not to be nonmutating operator method +RuboCop::AST::SuperNode + #receiver + is expected to be nil #comparison_method? - with a negation method - is expected not to be comparison method - with a regular method - is expected not to be comparison method - with a comparison method - is expected to be comparison method + is expected not to be comparison method + #operator_method? + is expected not to be operator method + #command? + when argument is a symbol + is expected to be command :super + when argument is a string + is expected to be command "super" + #dot? + is expected not to be dot + #camel_case_method? + is expected not to be camel case method + #double_colon? + is expected not to be double colon + #implicit_call? + is expected not to be implicit call + #assignment_method? + is expected not to be assignment method + #const_receiver? + is expected not to be const receiver + #splat_argument? + with no arguments + is expected not to be splat argument + with a splat argument + is expected to be splat argument + with mixed arguments + is expected to be splat argument + with regular arguments + is expected not to be splat argument #arguments? with a single literal argument is expected to be arguments + with multiple mixed arguments + is expected to be arguments with no arguments is expected not to be arguments with a single splat argument is expected to be arguments - with multiple mixed arguments - is expected to be arguments with multiple literal arguments is expected to be arguments - #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 - with a mutating Hash method - is expected not to be nonmutating hash method - #arithmetic_operation? - with a unary numeric operation - is expected not to be arithmetic operation - with a binary arithmetic operation - is expected to be arithmetic operation - with a regular method call - is expected not to be arithmetic operation - #method_name - with a setter method - is expected to eq :bar= - with an implicit call method - is expected to eq :call - with a plain method - is expected to eq :bar - with an operator method - is expected to eq :== - .new - 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 - #receiver - with no receiver - is expected to be nil - with a literal receiver - is expected to be str type - with a variable receiver - is expected to be send type - #block_node - with no block - is expected to be nil - with a block literal - is expected to be block type - with Ruby >= 2.7 - with a numblock literal - is expected to be numblock type - with a block argument - is expected to be nil - #first_argument - with a single splat argument - is expected to be splat type - with multiple mixed arguments - is expected to be sym type - with no arguments - is expected to be nil - with multiple literal arguments - is expected to be sym type - with a single literal argument - is expected to be sym type - #const_receiver? - with a constant receiver - is expected to be const receiver - with a non-constant receiver - is expected not to be const receiver - with a self receiver - is expected not to be const receiver - #nonmutating_binary_operator_method? - with a 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 - #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 - #def_modifier - with a prefixed def modifier - is expected to eq :bar - with a block containing a method definition - is expected to be nil - with call with no argument - is expected to be nil - with several prefixed def modifiers - is expected to eq :qux - #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 - #implicit_call? - with an implicit call method - is expected to be implicit call - with an explicit call method - is expected not to be implicit call - with a regular method - is expected not to be implicit call - #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 explicit receiver - is expected not to be command "bar" - with an implicit receiver - is expected to be command "bar" - #double_colon? - with 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 - without a dot - is expected not to be double colon - #bare_access_modifier? - when node is not an access modifier - is expected not to be bare access modifier - when node is a bare `module_function` - is expected to be bare access modifier - with Ruby >= 2.7 - when node is access modifier in block - is expected to be bare access modifier - when node is access modifier in numblock - is expected to be bare access modifier - when node has an argument - is expected not to be bare access modifier - #def_modifier? - with a prefixed def modifier - is expected to be def modifier - with several prefixed def modifiers - is expected to be def modifier - with a block containing a method definition - is expected not to be def modifier - #prefix_not? - with a bang method - is expected not to be prefix not - with keyword `not` - is expected to be prefix not - with a non-negated method - is expected not to be prefix not - #non_bare_access_modifier? - when node does not have an argument - is expected not to be non bare access modifier - when node is a non-bare `module_function` - is expected to be non bare access modifier - when node is not an access modifier - is expected not to be non bare access modifier - #post_condition_loop? - is expected not to be post condition loop - #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 + #setter_method? + is expected not to be setter method #block_literal? with no block is expected not to be block literal with a block literal is expected to be block literal - with Ruby >= 2.7 - with a numblock literal - is expected to be block literal with a block argument is expected not to be block literal - #nonmutating_array_method? - with a regular method - is expected not to be nonmutating array method - with a mutating Array method - is expected not to be nonmutating array method - with a nonmutating Array method - is expected to be nonmutating array method - #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 - #last_argument - with a single splat argument - is expected to be splat type - with multiple literal arguments - is expected to be sym type - with a single literal argument - is expected to be sym type + .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 + #self_receiver? + is expected not to be self receiver + #arguments with multiple mixed arguments - is expected to be splat type - with no arguments - is expected to be nil - #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 - #negation_method? - with prefix bang - is expected to be negation method - with a non-negated method - is expected not to be negation method - with prefix `not` - is expected to be negation method - with suffix `not` - is expected not to be negation 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 a regular method call - is expected not to be binary operation - with an implicit call method - is expected not to be binary operation - #block_argument? + is expected to eq 2 + with a single literal argument + is expected to eq 1 + with multiple literal arguments + is expected to eq 2 with no arguments - is expected not to be block argument - with regular arguments - is expected not to be block argument - with mixed arguments - is expected to be block argument - with a block argument - is expected to be block argument - #self_receiver? - with a non-self receiver - is expected not to be self receiver - with a self receiver - is expected to be self receiver - with an implicit receiver - is expected not to be self receiver - #prefix_bang? - with a bang method - is expected to be prefix bang - with keyword `not` - is expected not to be prefix bang - with a non-negated method - is expected not to be prefix bang + is expected to be empty + with a single splat argument + is expected to eq 1 #method? when message matches - when argument is a string - is expected to be method "bar" when argument is a symbol - is expected to be method :bar + is expected to be method :super + when argument is a string + is expected to be method "super" 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" - #loop_keyword? - is expected not to be loop keyword + when argument is a symbol + is expected not to be method :foo + #predicate_method? + is expected not to be predicate method + #bang_method? + is expected not to be bang 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 keyword begin inside of an class - is expected to be macro - when the condition of an if - is expected not to be macro - when parent is a block in a macro scope - is expected to be macro - when in an if - is expected to be macro - when parent is a class - is expected to be macro - when parent is a block not in a macro scope - is expected not to be macro - when parent is a singleton class - is expected to be macro - when parent is a method definition - is expected not to be macro - when in the global scope - 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 module - is expected to be macro - with Ruby >= 2.7 - when parent is a numblock in a macro scope - is expected to be macro - without a parent - is expected to be macro - when parent is a class constructor - is expected to be macro - #splat_argument? - with mixed arguments - is expected to be splat argument + is expected not to be macro + #block_argument? + with a block argument + is expected to be 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 mixed arguments + is expected to be block argument with regular arguments - is expected not to be splat argument - #attribute_accessor? - with an accessor - returns the accessor method and Array] - with a call without arguments - is expected to be nil - #dot? - with a unary method - is expected not to be dot - with a double colon - is expected not to be dot - without a dot - is expected not to be dot - with a dot - is expected to be dot - #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 - with a mutating String method - is expected not to be nonmutating string method - #arguments - with multiple mixed arguments - is expected to eq 2 + is expected not to be block argument + #first_argument + with no arguments + is expected to be nil with a single literal argument - is expected to eq 1 + is expected to be sym type + with multiple mixed arguments + is expected to be sym type with a single splat argument - is expected to eq 1 + is expected to be splat type with multiple literal arguments - is expected to eq 2 + is expected to be sym type + #block_node + with a block argument + is expected to be nil + with no block + is expected to be nil + with a block literal + is expected to be block type + #last_argument + with multiple mixed arguments + is expected to be splat type with no arguments - is expected to be empty - #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 nonmutating unary operator method - is expected to be nonmutating unary operator method - with a regular method - is expected not to be nonmutating unary operator method - #lambda? - with a non-lambda method - is expected not to be lambda - with a lambda method - is expected to be lambda - with a stabby lambda method - is expected to be lambda - with a method named lambda in a class - is expected not to be lambda - #bang_method? - with a bang method - is expected to be bang method - with a regular method - is expected not to be bang method - with a predicate method - is expected not to be bang method + is expected to be nil + with a single literal argument + is expected to be sym type + with a single splat argument + is expected to be splat type + with multiple literal arguments + is expected to be sym type + #method_name + is expected to eq :super #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 not using parentheses is expected not to be parenthesized when using parentheses is expected to be parenthesized - #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 - #setter_method? - with a setter method - is expected to be setter method - with an operator method - is expected not to be setter method - with an indexed setter method - is expected to be setter method - with a regular method - is expected not to be setter method -RuboCop::AST::UntilNode - #post_condition_loop? - with a statement until - is expected not to be post condition loop - with a modifier until - is expected to be post condition loop - .new - with a statement until - is expected to be a kind of RuboCop::AST::UntilNode - with a modifier until - is expected to be a kind of RuboCop::AST::UntilNode - #loop_keyword? - with a modifier until - is expected to be loop keyword - with a statement until - is expected to be loop keyword +RuboCop::AST::WhileNode #do? with a do keyword is expected to be do without a do keyword is expected not to be do #keyword - is expected to eq "until" - #inverse_keyword is expected to eq "while" - -RuboCop::AST::LambdaNode - #method_name - is expected to eq :lambda - #arguments - is expected to eq 2 - #receiver - is expected to be nil - -RuboCop::AST::CasgnNode - #namespace - when there is no parent - is expected to be nil - 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) - #name - is expected to eq :VAR + #inverse_keyword + is expected to eq "until" .new - with a `casgn` node - is expected to be a kind of RuboCop::AST::CasgnNode - #expression - is expected to eq s(:send, nil, :value) + with a statement while + is expected to be a kind of RuboCop::AST::WhileNode + with a modifier while + is expected to be a kind of RuboCop::AST::WhileNode + #loop_keyword? + with a statement while + is expected to be loop keyword + with a modifier while + is expected to be loop keyword + #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 -RuboCop::AST::SuperNode - .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 +RuboCop::AST::YieldNode #bang_method? is expected not to be bang method - #block_node - with a block argument - is expected to be nil - with a block literal - is expected to be block type - with no block - is expected to be nil #receiver is expected to be nil - #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 - with no arguments - is expected not to be splat argument - #assignment_method? - is expected not to be assignment method + #double_colon? + is expected not to be double colon #arguments + with multiple literal arguments + is expected to eq 2 + with a single splat argument + is expected to eq 1 with no arguments is expected to be empty - with multiple mixed arguments - is expected to eq 2 with a single literal argument is expected to eq 1 - with a single splat argument - is expected to eq 1 - with multiple literal arguments - is expected to eq 2 - #arguments? with multiple mixed arguments - is expected to be arguments - with a single splat argument - is expected to be arguments - with a single literal argument - is expected to be arguments - with multiple literal arguments - is expected to be arguments - with no arguments - is expected not to be arguments - #command? - when argument is a string - is expected to be command "super" - when argument is a symbol - is expected to be command :super + is expected to eq 2 + #method_name + is expected to eq :yield #macro? is expected not to be macro - #method_name - is expected to eq :super + #comparison_method? + is expected not to be comparison method + #predicate_method? + is expected not to be predicate method + #assignment_method? + is expected not to be assignment method + #self_receiver? + is expected not to be self receiver #camel_case_method? is expected not to be camel case method + #block_node + is expected to be nil + #block_argument? + is expected not to be block argument + #parenthesized? + with no arguments + when using parentheses + is expected to be parenthesized + when not using parentheses + is expected not to be parenthesized + with arguments + when not using parentheses + is expected not to be parenthesized + when using parentheses + is expected to be parenthesized + #command? + when argument is a string + is expected to be command "yield" + when argument is a symbol + is expected to be command :yield + #const_receiver? + is expected not to be const receiver + #first_argument + with multiple literal arguments + is expected to be sym type + with no arguments + is expected to be nil + with multiple mixed arguments + is expected to be sym type + with a single splat argument + is expected to be splat type + with a single literal argument + is expected to be sym type + #block_literal? + is expected not to be block literal + #operator_method? + is expected not to be operator method #method? when message matches when argument is a symbol - is expected to be method :super + is expected to be method :yield when argument is a string - is expected to be method "super" + is expected to be method "yield" 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 - #double_colon? - is expected not to be double colon - #last_argument + #setter_method? + is expected not to be setter method + #dot? + is expected not to be dot + #splat_argument? + with mixed arguments + is expected to be splat argument + with a splat argument + is expected to be splat argument + with no arguments + is expected not to be splat argument + with regular arguments + is expected not to be splat argument + #arguments? with multiple literal arguments - is expected to be sym type + is expected to be arguments with no arguments - is expected to be nil + is expected not to be arguments with a single splat argument - is expected to be splat type + is expected to be arguments with a single literal argument - is expected to be sym type + is expected to be arguments with multiple mixed arguments - is expected to be splat type - #block_argument? - with no arguments - is expected not to be block argument - with a block argument - is expected to be block argument - with mixed arguments - is expected to be block argument - with regular arguments - is expected not to be block argument - #parenthesized? - with arguments - when not using parentheses - is expected not to be parenthesized - when using parentheses - is expected to be parenthesized - with no arguments - when not using parentheses - is expected not to be parenthesized - when using parentheses - is expected to be parenthesized - #first_argument + is expected to be arguments + #last_argument with multiple mixed arguments - is expected to be sym type + 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 - #comparison_method? - is expected not to be comparison method - #self_receiver? - is expected not to be self receiver + with a single literal argument + is expected to be sym type + with no arguments + is expected to be nil #implicit_call? is expected not to be implicit call - #predicate_method? - is expected not to be predicate method - #setter_method? - is expected not to be setter 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 - #dot? - is expected not to be dot - #const_receiver? - is expected not to be const receiver - #operator_method? - is expected not to be operator method + .new + is expected to be a kind of RuboCop::AST::YieldNode -RuboCop::AST::ForNode - #loop_keyword? - is expected to be loop keyword - #body - is expected to be sym type - #void_context? - with a do keyword - is expected to be void context - without a do keyword - is expected to be void context - #post_condition_loop? - is expected not to be post condition loop +RuboCop::AST::DefinedNode + #method_name + is expected to eq :defined? .new - is expected to be a kind of RuboCop::AST::ForNode - #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 - #keyword - is expected to eq "for" - #variable - is expected to be lvasgn type + with a defined? node + is expected to be a kind of RuboCop::AST::DefinedNode + #receiver + is expected to be nil + #arguments + is expected to eq 1 + is expected to all be sym type -RuboCop::AST::HashNode - #each_key - when passed a block - yields all the pairs - when not passed a block - is expected to be a kind of Enumerator - #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_pair - when not passed a block - is expected to be a kind of Enumerator - when passed a block - yields all the pairs - #each_value +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 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 + #empty_and_without_delimiters? + with delimiters + with a method definition + is expected to equal false + with a block + 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 + with arguments + with a method definition + is expected to equal false + with a lambda literal + is expected to equal false + +Changelog + merges correctly + parses correctly + Changelog::Entry + generates correct content + +RuboCop::AST::OrAsgnNode + .new + is expected to be a kind of RuboCop::AST::OrAsgnNode + #name + is expected to eq :var + #assignment_node + is expected to be a kind of RuboCop::AST::AsgnNode + #expression + is expected to eq s(:send, nil, :value) + #operator + is expected to eq :"||" + +RuboCop::AST::CasgnNode + #namespace + when there is no parent + is expected to be nil + 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) + #expression + is expected to eq s(:send, nil, :value) + #name + is expected to eq :VAR + .new + with a `casgn` node + is expected to be a kind of RuboCop::AST::CasgnNode + +RuboCop::AST::WhenNode + .new + is expected to be a kind of RuboCop::AST::WhenNode + #then? + without a then keyword + is expected not to be then + with a then keyword + is expected to be then + #each_condition when passed a block - yields all the pairs + yields all the conditions when not passed a block is expected to be a kind of Enumerator - #pairs_on_same_line? - with all pairs on the same line - is expected to be 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 - .new - is expected to be a kind of RuboCop::AST::HashNode - #braces? - as an argument with no braces - is expected not to be braces - with braces - is expected to be braces - as an argument with braces - is expected to be braces - #pairs - with a hash of variables - is expected to eq 2 - is expected to all be pair type - with a hash of literals + #conditions + with a single condition + is expected to all be literal + is expected to eq 1 + with a multiple conditions is expected to eq 3 - is expected to all be pair type - with an empty hash - is expected to be empty - #keys - with a hash with string keys - is expected to all be str type + is expected to all be literal + #branch_index + is expected to eq 1 + is expected to eq 0 + is expected to eq 2 + #body + without a then keyword + is expected to be array type + with a then keyword + is expected to be sym type + +RuboCop::AST::NextNode + behaves like wrapped arguments node + #arguments + with a single splat argument + 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 multiple literal arguments + is expected to eq 2 + with a single argument and braces + is expected to eq 1 + .new + with arguments + is expected to be a kind of RuboCop::AST::NextNode + without arguments + is expected to be a kind of RuboCop::AST::NextNode + +RuboCop::AST::NodePattern::Sets + is expected not to eq "::RuboCop::AST::NodePattern::Sets::SET_1_2_3_ETC_2" + creates a constant with the right value + is expected to eq "::RuboCop::AST::NodePattern::Sets::SET_1_2_3_ETC" + is expected to eq "::RuboCop::AST::NodePattern::Sets::SET_1_2_3_ETC" + +RuboCop::AST::BlockNode + #keywords? + when enclosed in braces + is expected not to be keywords + when enclosed in do-end keywords + is expected to be keywords + #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 + #delimiters + when enclosed in do-end keywords + is expected to eq ["do", "end"] + when enclosed in braces + is expected to eq ["{", "}"] + #arguments? + with multiple mixed arguments + is expected to be arguments + with no arguments + is expected not to be arguments + with a single splat argument + is expected to be arguments + >= Ruby 2.7 + using numbered parameters + is expected not to be arguments + with a single argument + is expected to be arguments + with destructuring arguments + is expected to be arguments + #arguments + with destructured arguments 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 - #empty? - with a hash containing a keyword splat - is expected not to be empty - with a hash containing pairs - is expected not to be empty - with an empty hash - is expected to be empty - #values - with a hash with string keys - is expected to all be send type + with multiple mixed arguments is expected to eq 2 - with a hash with literal values - is expected to all be literal - is expected to eq 3 - with an empty hash + with a single literal argument + is expected to eq 1 + with a single splat argument + is expected to eq 1 + >= Ruby 2.7 + using numbered parameters + is expected to be empty + with no arguments is expected to be empty + #closing_delimiter + when enclosed in braces + is expected to eq "}" + when enclosed in do-end keywords + is expected to eq "end" + #argument_list + with no arguments + is expected to be empty + >= 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] + all argument types + is expected to eq [:a, :b, :c, :d, :e, :f, :g, :h, :i] + #opening_delimiter + when enclosed in do-end keywords + is expected to eq "do" + when enclosed in braces + is expected to eq "{" + #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 + #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 + .new + is expected to be a kind of RuboCop::AST::BlockNode + #receiver + with safe navigation operator call + is expected to eq "foo" + with dot operator call + is expected to eq "foo" + #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 + #braces? + when enclosed in braces + is expected to be braces + when enclosed in do-end keywords + is expected not to be braces RuboCop::AST::AliasNode - #new_identifier - is expected to eq :foo - is expected to be sym type .new is expected to be a kind of RuboCop::AST::AliasNode #old_identifier is expected to eq :bar is expected to be sym type + #new_identifier + is expected to eq :foo + is expected to be sym type -RuboCop::AST::SelfClassNode +RuboCop::AST::EnsureNode #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 + is expected to be sym type .new - is expected to be a kind of RuboCop::AST::SelfClassNode - #identifier - is expected to be self type + is expected to be a kind of RuboCop::AST::EnsureNode -RuboCop::AST::BreakNode - behaves like wrapped arguments node - #arguments - with multiple literal arguments +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 " => " + #value_omission? + when using hash value omission + is expected to be value omission + when not using hash value omission + is expected not to be value omission + #delimiter + when using a colon delimiter + is expected to eq ": " + is expected to eq ":" + when using a hash rocket delimiter + is expected to eq "=>" + is expected to eq " => " + .new + is expected to be a kind of RuboCop::AST::PairNode + #colon? + when using a colon delimiter + is expected to be colon + when using a hash rocket delimiter + is expected not to be colon + #value_delta + when using hash rocket delimiters + when both pairs are on the same line + is expected to eq 0 + when receiver value is behind + is expected to eq -2 + when receiver value is ahead is expected to eq 2 - with a single splat argument - is expected to eq 1 - with no arguments and braces - is expected to be empty - with no arguments - is expected to be empty - with a single argument and braces - is expected to eq 1 - with a single argument - is expected to eq 1 - .new - with arguments - is expected to be a kind of RuboCop::AST::BreakNode - without arguments - is expected to be a kind of RuboCop::AST::BreakNode + 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 using colon delimiters + when receiver value is behind + is expected to eq -2 + 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 both pairs are explicit pairs + is expected to eq 0 + when second pair is a keyword splat + is expected to eq 0 + #value_on_new_line? + when value spans multiple lines + is expected not to be value on new line + when value starts on a new line + is expected to be value on new line + when pair is on a single line + is expected not to be value on new line + #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 + #value + is expected to be int type + #same_line? + 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, :a), + s(:begin)) + is expected to be same line s(:pair, + s(:sym, :b), + s(:int, 2)) + when both pairs are on the same line + when both 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)) + #key_delta + with alignment set to :left + when using colon 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 2 + when receiver key is behind + when second pair is a keyword splat + is expected to eq -2 + when both pairs are reail pairs + is expected to eq -2 + when keys are aligned + when second pair is a keyword splat + is expected to eq 0 + when both pairs are explicit pairs + is expected to eq 0 + when both keys are on the same line + when 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 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 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 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 + with alignment set to :right + when using hash rocket delimiters + when receiver key is behind + when both pairs are explicit pairs + is expected to eq -2 + when second pair is a keyword splat + is expected to eq 0 + when receiver key is ahead + when both pairs are explicit pairs + is expected to eq 2 + when second pair is a keyword splat + is expected to eq 0 + when keys are aligned + when second key is a keyword splat + is expected to eq 0 + when both keys are explicit keys + is expected to eq 0 + when both keys are on the same line + when second pair is a keyword splat + is expected to eq 0 + when both pairs are explicit pairs + is expected to eq 0 + when using colon delimiters + when receiver key is behind + when both pairs are reail pairs + is expected to eq -2 + when second pair is a keyword splat + is expected to eq 0 + when keys are aligned + when second pair is a keyword splat + is expected to eq 0 + when both pairs are explicit pairs + is expected to eq 0 + when both keys are on the same line + when both pairs are explicit pairs + is expected to eq 0 + when second pair is a keyword splat + is expected to eq 0 + when receiver key is ahead + when both pairs are explicit pairs + is expected to eq 2 + when second pair is a keyword splat + is expected to eq 0 -RuboCop::AST::ProcessedSource - #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 after heredoc - returns tokens for node before heredoc - returns tokens for heredoc node - #buffer - is a source buffer - #following_line - returns source of line after token - token enumerables - #find_token - yields correct token - yields nil when there is no match - #each_token - yields all tokens - #path - is the path passed to .new - #tokens - has an array of tokens - with heavily commented source - #line_with_comment? - returns false for lines without comments - returns true for lines with comments - #each_comment - yields all comments - #find_comment - yields correct comment - yields nil when there is no match - #each_comment_in_lines - yields the comments - #comments_before_line - returns comments on or before given line - #comment_at_line - returns nil if line has no comment - returns the comment at the given line number - #contains_comment? - provided a multiline source_range with at least one line with comment - is expected to equal true - provided source_range on comment line - is expected to equal true - provided source_range on line with comment - is expected to equal true - provided source_range on line without comment - is expected to equal false - #comments - is an array of comments - when the source is invalid - returns [] - .from_file - raises a Errno::ENOENT when the file does not exist - when the file exists - returns an instance of ProcessedSource - sets the file path to the instance's #path - #[] - when a range is passed - returns the array of lines - when an index is passed - returns the line - when start index and length are passed - returns the array of lines - #blank? - with source of no content - returns true - with source with content - returns false - #last_token_of - accepts Node as an argument - returns last token for node - #file_path - returns file path - #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 - #first_token_of - accepts Node as an argument - returns first token for node - #lines - has same number of elements as line count - is an array - contains lines as string without linefeed - #preceding_line - returns source of line before token - #start_with? - with blank source - returns false - with present source - returns true when passed string that starts source - returns false when passed string that does not start source - valid_syntax? - when the source is invalid - returns false - when the source is completely valid - returns true - when a line starts with an integer literal - tokenizes the source correctly - when the source could not be parsed due to encoding error - returns false - when the source is valid but has some warning diagnostics - returns true - when the source itself is valid encoding but includes strange encoding literals that are accepted by MRI - returns true +RuboCop::AST::Token + #begin_pos + returns index of first char in token range of entire source + type predicates + #left_ref_bracket? + returns true for left_ref_bracket tokens + returns false for non left_ref_bracket tokens + #regexp_dots? + returns true for regexp tokens + returns false for non comma tokens + #semicolon? + returns false for non semicolon tokens + returns true for semicolon tokens + #comma? + returns true for comma tokens + returns false for non comma tokens + #right_bracket? + returns false for non right_bracket tokens + returns true for all right_bracket tokens + with braces & parens + #right_parens? + returns false for non right parens tokens + returns true for right parens tokens + #right_curly_brace? + returns false for non right brace tokens + returns true for all right brace tokens + #left_curly_brace? + returns true for left block brace tokens + returns false for non left block brace tokens + #left_parens? + returns false for non left parens tokens + returns true for left parens tokens + #left_brace? + returns false for non left hash brace tokens + returns true for left hash brace tokens + #end? + returns true for end tokens + returns false for non end tokens + #new_line? + returns true for new line tokens + returns false for non new line tokens + #dot? + returns false for non dot tokens + returns true for dot tokens + #equals_sign? + returns true for equals sign tokens + returns false for non equals sign tokens + #rescue_modifier? + returns false for non rescue modifier tokens + returns true for rescue modifier tokens + #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 + #comment? + returns false for non comment tokens + returns true for comment tokens + #left_brace? + returns false for non right_bracket tokens + returns true for right_bracket tokens + #space_after + returns nil when there is not a space after token + returns truthy MatchData when there is a space after token + #column + returns index of first char in token range on that line + #line + returns line of token + .from_parser_token + sets parser token's range to rubocop token's pos + sets parser token's type to rubocop token's type + returns a #to_s useful for debugging + sets parser token's text to rubocop token's text + #end_pos + returns index of last char in token range of entire source + #to_s + returns string of token data + #space_before + returns truthy MatchData when there is a space before token + returns nil when it is on the first line + returns nil when there is not a space before token RuboCop::AST::CaseNode - #keyword - is expected to eq "case" - .new - is expected to be a kind of RuboCop::AST::CaseNode - #each_when - when passed a block - yields all the conditions - when not passed a block - is expected to be a kind of Enumerator + #when_branches + is expected to eq 3 + is expected to all be when type #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 - without an else statement - is expected to be nil #else? - with an else statement - is expected to be else without an else statement is expected not to be else - #when_branches - is expected to all be when type - is expected to eq 3 + with an else statement + is expected to be else + #each_when + 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 returns all the bodies with an empty else returns all the bodies + when there is no else keyword + returns only then when bodies when compared to an IfNode returns the same - -RuboCop::AST::AndAsgnNode .new - is expected to be a kind of RuboCop::AST::AndAsgnNode - #expression - is expected to eq s(:send, nil, :value) - #assignment_node - is expected to be a kind of RuboCop::AST::AsgnNode - #operator - is expected to eq :"&&" - #name - is expected to eq :var + is expected to be a kind of RuboCop::AST::CaseNode + #keyword + is expected to eq "case" -RuboCop::AST::EnsureNode - #body - is expected to be sym type +RuboCop::AST::StrNode + #heredoc? + with a string with interpolation + is expected not to be heredoc + with a heredoc + is expected to be heredoc + with a normal string + is expected not to be heredoc + #character_literal? + with a character literal + is expected to be character literal + with a normal string literal + is expected not to be character literal + with a heredoc + is expected not to be character literal .new - is expected to be a kind of RuboCop::AST::EnsureNode + 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 RuboCop::AST::ArgNode - #default_value - with a regular argument - is expected to be nil - with a splatted argument - is expected to be nil - with a block argument - is expected to be nil - with a block - is expected to be nil + #name + with a double splatted argument + is expected to eq :x with an optional argument - is expected to eq s(:int, 42) - with a shadow argument - is expected to be nil + is expected to eq :x + with a block + 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 double splatted argument - is expected to be nil - with an optional keyword argument - is expected to eq s(:int, 42) - #default? - with argument forwarding with Ruby >= 3.0 - is expected to equal false - with Ruby >= 2.7 - is expected to equal false - with a splatted argument - is expected to equal false - with a block argument - is expected to equal false + is expected to be nil with an optional keyword argument - is expected to equal true + 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 a shadow argument - is expected to equal false - with a double splatted argument - is expected to equal false - with a block - is expected to equal false - with an optional argument - is expected to equal true + is expected to eq :x with a regular argument - is expected to equal false - #name - with a shadow argument is expected to eq :x - with an optional argument + with a splatted argument is expected to eq :x - with an optional keyword argument + with a keyword argument is expected to eq :x with a block argument is expected to eq :x + #default_value + with argument forwarding + with Ruby >= 3.0 + is expected to be nil + with Ruby >= 2.7 + is expected to be nil + with a double splatted argument + is expected to be nil with a splatted argument - is expected to eq :x - with a nameless splatted argument is expected to be nil - with a nameless double splatted argument + with a block is expected to be nil - with a double splatted argument - is expected to eq :x with a regular argument - is expected to eq :x + 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 an optional argument + is expected to eq s(:int, 42) + with a shadow argument + is expected to be nil + .new with argument forwarding with Ruby >= 2.7 - is expected to be nil + is expected to be a kind of RuboCop::AST::ArgNode with Ruby >= 3.0 - is expected to be nil - with a keyword argument - is expected to eq :x - with a block - is expected to eq :x - .new + is expected to be a kind of RuboCop::AST::ArgNode with a method definition is expected to be a kind of RuboCop::AST::ArgNode - with a shadow argument + with a splatted argument is expected to be a kind of RuboCop::AST::ArgNode - with a keyword argument + with a lambda literal is expected to be a kind of RuboCop::AST::ArgNode - with a block argument + with an optional argument is expected to be a kind of RuboCop::AST::ArgNode - with a double splatted argument + with a keyword argument is expected to be a kind of RuboCop::AST::ArgNode - with a splatted argument + with an optional keyword argument is expected to be a kind of RuboCop::AST::ArgNode - with a lambda literal + with a shadow argument + is expected to be a kind of RuboCop::AST::ArgNode + with a block argument is expected to be a kind of RuboCop::AST::ArgNode with a block is expected to be a kind of RuboCop::AST::ArgNode - with an optional argument + with a double splatted argument is expected to be a kind of RuboCop::AST::ArgNode + #default? with an optional keyword argument - is expected to be a kind of RuboCop::AST::ArgNode + is expected to equal true + with a splatted argument + is expected to equal false + with a double splatted argument + is expected to equal false + with a shadow argument + is expected to equal false + with a block argument + is expected to equal false with argument forwarding with Ruby >= 3.0 - is expected to be a kind of RuboCop::AST::ArgNode + is expected to equal false with Ruby >= 2.7 - is expected to be a kind of RuboCop::AST::ArgNode + is expected to equal false + with a regular argument + is expected to equal false + with an optional argument + is expected to equal true + with a block + is expected to equal false -RuboCop::AST::YieldNode - #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 - with no arguments - is expected not to be splat argument - #block_argument? - is expected not to be block argument - #self_receiver? - is expected not to be self receiver - #double_colon? - is expected not to be double colon - #dot? - is expected not to be dot - #arguments? - with multiple mixed arguments - is expected to be arguments - with a single literal argument - is expected to be arguments - with no arguments - is expected not to be arguments - with a single splat argument - is expected to be arguments - with multiple literal arguments - is expected to be arguments - #comparison_method? - is expected not to be comparison method - #method_name - is expected to eq :yield - #predicate_method? - is expected not to be predicate method - #setter_method? - is expected not to be setter method - #implicit_call? - is expected not to be implicit call - #block_node - is expected to be nil - #camel_case_method? - is expected not to be camel case method - #assignment_method? - is expected not to be assignment method - .new - is expected to be a kind of RuboCop::AST::YieldNode - #block_literal? - is expected not to be block literal - #first_argument - with a single literal argument - is expected to be sym type - with no arguments +RuboCop::AST::NodePattern::Lexer + provides tokens via next_token + when given a regexp /[abc]+\/()?/x + round trips + when given a regexp /test/ + round trips + when given a regexp ending with a backslash + does not lexes it properly + when given a regexp /back\\slash/ + round trips + when given node types and constants + distinguishes them + when given arithmetic symbols + is parsed as `:&` + with $type+ + is parsed as `$ int + x` + +RuboCop::AST::Node + #struct_constructor? + struct definition without block + does not match + struct definition with a block + matches + ::Struct + matches + #recursive_basic_literal? + behaves like literal + returns true for `(false <=> true)` + behaves like non literal + returns false for `some_method_call(x, y)` + behaves like literal + returns true for `nil` + behaves like literal + returns true for `!true` + behaves like literal + returns true for `%r{abx}ixo` + behaves like non literal + returns false for `(x == false)` + behaves like literal + returns true for `false` + behaves like literal + returns true for `1.0` + behaves like literal + returns true for `[1, 2, 3]` + 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 `"#{2}"` + behaves like literal + returns true for `1` + behaves like literal + returns true for `(false or true)` + behaves like non literal + returns false for `{ :sym => some_method_call }` + behaves like literal + returns true for `(1)` + behaves like non literal + returns false for `[some_method_call]` + behaves like literal + returns true for `/./` + behaves like non literal + returns false for `(x && false)` + behaves like non literal + returns false for `{ some_method_call => :sym }` + behaves like literal + returns true for `(false && true)` + behaves like non literal + returns false for `(x or false)` + behaves like literal + returns true for `{ a: 1, b: 2 }` + behaves like literal + returns true for `'str'` + behaves like non literal + returns false for `some_method_call` + behaves like literal + returns true for `{ :a => 1, :b => 2 }` + #argument_type? + block arguments + returns true for all argument types + method arguments + returns true for all argument types + #module_definition? + with ::ModuleName + matches + nested modules + matches + using module keyword + matches + prepend Module.new + matches + namespaced modules + matches + included module definition + matches + with Module.new + matches + when using numbered parameter + matches + #pure? + for a method call + returns false + for an lvar assignment + returns false + for a nested if + where one branch contains a method call + returns false + where the innermost descendants are local vars and literals + returns true + where one branch contains an assignment statement + returns false + for an ivar assignment + returns false + for an array literal + with only literal children + returns true + which contains a method call + returns false + for a cvar assignment + returns false + for a class definition + returns false + for a hash literal + which contains a method call + returns false + with only literal children + returns true + for a regexp + with options + returns true + with interpolated segments + returns false + with no interpolation + returns true + for a gvar assignment + returns false + for a module definition + returns false + for an integer literal + returns true + #class_constructor? + class definition + does not match + class definition on outer scope + matches + module definition with a block + matches + class definition with a block + matches + #value_used? + at the end of a block + is always true + within an if...else..end node + at the top level + is true only for the condition + nested in a method call + is always true + within a while node + is true only for the condition + at the top level + is false + 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 + within a module definition node + is always true + within a method call node + is always true + #conditional? + when `until` node + is true + when `case` node + is true + when `if` node + is true + when `while` node + is true + when `case_match` node + is true + when post condition loop node + is false + #parent_module_name + when node nested in an unknown block is expected to be nil - with multiple literal arguments - is expected to be sym type - with multiple mixed arguments - is expected to be sym type - with a single splat argument - is expected to be splat type - #last_argument - with a single literal argument - is expected to be sym type - with multiple literal arguments - is expected to be sym type - with a single splat argument - is expected to be splat type - with no arguments + when node nested in a class << exp is expected to be nil - with multiple mixed arguments - is expected to be splat type - #arguments - with multiple mixed arguments - is expected to eq 2 - with no arguments - is expected to be empty - with a single literal argument - is expected to eq 1 - with a single splat argument - is expected to eq 1 - with multiple literal arguments - is expected to eq 2 - #parenthesized? - with arguments - when not using parentheses - is expected not to be parenthesized - when using parentheses - is expected to be parenthesized - with no arguments - when using parentheses - is expected to be parenthesized - when not using parentheses - is expected not to be parenthesized - #operator_method? - is expected not to be operator method - #macro? - is expected not to be macro - #command? - when argument is a string - is expected to be command "yield" - when argument is a symbol - is expected to be command :yield - #const_receiver? - is expected not to be const receiver - #method? - when message does not match - when argument is a symbol - is expected not to be method :foo - when argument is a string - is expected not to be method "foo" - when message matches - when argument is a string - is expected to be method "yield" - when argument is a symbol - is expected to be method :yield - #receiver - is expected to be nil - #bang_method? - is expected not to be bang method - -Set#=== - tests for inclusion + when node on module + is expected to eq "Foo" + when node on singleton class + is expected to eq "Foo::#" + when node on class in singleton class + is expected to eq "Foo::#::Bar" + when node on top level + is expected to eq "Object" + #numeric_type? + when float literal + is true + when complex literal whose imaginary part is a rational + is true + when rational literal + is true + when string literal + is true + when integer literal + is true + when complex literal + is true + #class_definition? + with ::ClassName + matches + constant defined as Struct without block + does not match + with object singleton class + matches + with Struct + matches + when using numbered parameter + matches + namespaced class + matches + with self singleton class + matches + with Class.new + matches + when using numbered parameter + matches + without inheritance + matches + with inheritance + matches + 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::OrAsgnNode - #assignment_node - is expected to be a kind of RuboCop::AST::AsgnNode - #operator - is expected to eq :"||" - #expression - is expected to eq s(:send, nil, :value) - #name - is expected to eq :var +RuboCop::AST::RangeNode .new - is expected to be a kind of RuboCop::AST::OrAsgnNode + with an exclusive range + is expected to be a kind of RuboCop::AST::RangeNode + is expected to be range type + with an inclusive 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 + with a beignless range + is expected to be a kind of RuboCop::AST::RangeNode + is expected to be range type -RuboCop::AST::IntNode - #value - is expected to eq 10 - .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 +RuboCop::AST::Ext::Range + #line_span + accepts an `exclude_end` keyword argument + returns the range of lines a range occupies -RuboCop::AST::ResbodyNode - .new - is expected to be a kind of 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" - #branch_index - is expected to eq 1 - is expected to eq 2 - is expected to eq 0 - #body - is expected to be sym type - #exceptions - with multiple exceptions - is expected to all be const type - is expected to eq 2 - with a single exception - is expected to eq 1 - is expected to all be const type - without exception - is expected to eq 0 +RuboCop::AST::ConstNode + #absolute? + is expected to be absolute + with a non-namespaced constant + is expected not to be absolute + with a constant not starting with :: + is expected not to be absolute + #relative? + with a non-namespaced constant + is expected to be relative + #short_name + is expected to eq :BAZ + #each_path + yields all parts of the namespace + #namespace + is expected to eq "::Foo::Bar" + #module_name? + is expected not to be module name + with a constant with a lowercase letter + is expected to be module name -RuboCop::AST::NextNode +RuboCop::AST::BreakNode behaves like wrapped arguments node + .new + without arguments + is expected to be a kind of RuboCop::AST::BreakNode + with arguments + is expected to be a kind of RuboCop::AST::BreakNode #arguments - with a single argument + with a single splat argument is expected to eq 1 with multiple literal arguments is expected to eq 2 - with a single splat argument - is expected to eq 1 with no arguments and braces is expected to be empty - with a single argument and braces + with a single argument is expected to eq 1 with no arguments is expected to be empty - .new - without arguments - is expected to be a kind of RuboCop::AST::NextNode - with arguments - is expected to be a kind of RuboCop::AST::NextNode - -RuboCop::AST::WhileNode - #keyword - is expected to eq "while" - .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 - #do? - without a do keyword - is expected not to be do - with a do keyword - is expected to be do - #inverse_keyword - is expected to eq "until" - #post_condition_loop? - with a modifier while - is expected to be post condition loop - with a statement while - is expected not to be post condition loop - #loop_keyword? - with a modifier while - is expected to be loop keyword - with a statement while - is expected to be loop keyword - -RuboCop::AST::BlockNode - #void_context? - when block method is each - is expected to be void context - when block method is tap - is expected to be void context - when block method is not each - is expected not to be void context - #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 - #opening_delimiter - when enclosed in braces - is expected to eq "{" - when enclosed in do-end keywords - is expected to eq "do" - #multiline? - when block is on several lines - is expected to be multiline - when block is on a single line - is expected not to be multiline - #receiver - with dot operator call - is expected to eq "foo" - with safe navigation operator call - is expected to eq "foo" - .new - is expected to be a kind of RuboCop::AST::BlockNode - #arguments - with a single splat argument - is expected to eq 1 - with a single literal argument - is expected to eq 1 - with destructured arguments - is expected to eq 2 - >= Ruby 2.7 - using numbered parameters - is expected to be empty - with no arguments - is expected to be empty - with multiple mixed arguments - is expected to eq 2 - #delimiters - when enclosed in do-end keywords - is expected to eq ["do", "end"] - when enclosed in braces - is expected to eq ["{", "}"] - #arguments? - with destructuring arguments - 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 - >= Ruby 2.7 - using numbered parameters - is expected not to be arguments - with a single argument - is expected to be arguments - #keywords? - when enclosed in braces - is expected not to be keywords - when enclosed in do-end keywords - is expected to be keywords - #closing_delimiter - when enclosed in do-end keywords - is expected to eq "end" - when enclosed in braces - is expected to eq "}" - #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 - #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] - all argument types - is expected to eq [:a, :b, :c, :d, :e, :f, :g, :h, :i] - with no arguments - is expected to be empty - -RuboCop::AST::Ext::Range - #line_span - accepts an `exclude_end` keyword argument - returns the range of lines a range occupies - -RuboCop::AST::ModuleNode - .new - is expected to be a kind of RuboCop::AST::ModuleNode - #body - with a single expression body - is expected to be send type - with a multi-expression body - is expected to be begin type - with an empty body - is expected to be nil - #identifier - is expected to be const type + with a single argument and braces + is expected to eq 1 RuboCop::AST::NodePattern - predicates - at head position of a sequence - 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 - with an expression argument - for which the predicate is false + negation + when nested in complex ways + with (send str :<< str) 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 true - is expected to match code s(:int, 1) and :inc - applied to an integer for which the predicate is false + 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 int :- int) + is expected to match code s(:int, 1), :-, and s(:int, 1) + on a sequence + with a node of different type + is expected to match code :@@a and s(:int, 1) + 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 + 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 square brackets + with a node which meets all requirements of [] + behaves like nonmatching + doesn't match + with a node which meets only 1 requirement of [] + is expected to match code 1 + macros + with a pattern without captures + def_node_search + returns the method name + without a predicate name + when it errors + raises an error with the right location + when called on matching code + returns an enumerator yielding the matches + when called on non-matching code + returns an enumerator yielding nothing + with a predicate name + 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) + when it errors + raises an error with the right location + def_node_matcher + returns the method 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 :hello + with a pattern with captures + def_node_search + without a predicate name + when called on matching code + returns an enumerator yielding the captures + when the pattern contains keyword_params + returns an enumerator yielding the captures + when helper is called with default keyword_params + is overridden when calling the matcher + and no value is given to the matcher + uses the defaults + some defaults are not params + raises an error + when called on non-matching code + returns an enumerator yielding nothing + when it errors + raises an error with the right location + with a predicate name + when called on matching code + is expected to match code nil, :foo, s(:sym, :hello), and s(:sym, :world) + when it errors + raises an error with the right location + when called on non-matching code + behaves like nonmatching + doesn't match + def_node_matcher + when called on non-matching code + behaves like nonmatching + doesn't match + when called on matching code + is expected to eq :hello + when it errors + raises an error with the right location + 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 a constant + is expected to match code :hello + when the value is not in the set + behaves like nonmatching + doesn't match + bare node type + yaml compatibility + is expected to match code s(:send, nil, :obj) and :method + on a node with the same type + is expected to match code s(:send, nil, :obj) and :method + marshal compatibility + is expected to match code s(:send, nil, :obj) and :method + #to_s + is instructive + #dup + is expected to match code s(:send, nil, :obj) and :method + #== + returns true iff the patterns are similar + on a node with a matching, hyphenated type + is expected to match code s(:lvasgn, :a), :+, and s(:int, 1) + #pattern + returns the pattern + on a node with a different type behaves like nonmatching doesn't match - when negated - is expected to match code s(:int, 1) and :inc + predicates + 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 + when not given + raises an error + with extra arguments + raises an error with multiple arguments for which the predicate is false behaves like nonmatching @@ -2827,187 +2494,359 @@ for which the predicate is true is expected to match code s(:str, "c"), "a", and "d" with a constant argument - for which the predicate is true - is expected to match code s(:int, 1), :+, and s(:int, 2) for which the predicate is false behaves like nonmatching doesn't match - with one extra argument + for which the predicate is true + is expected to match code s(:int, 1), :+, and s(:int, 2) + applied to an integer for which the predicate is false + behaves like nonmatching + doesn't match + 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 + 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 + 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 + at head position of a sequence + is expected to match code s(:int, 1) and :inc + 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 - 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 - when captured + in root position + is expected to match code s(:int, 1) and :inc + with name containing a numeral + is expected to match code s(:int, 1) and :inc + when in last-child position, but all children have already been matched + behaves like nonmatching + doesn't match + commas + with commas randomly strewn around + behaves like invalid + is invalid + bad syntax + with unsupported subsequence in seq head within union + 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 doubled comma in arg list + behaves like invalid + is invalid + with unmatched closing paren + behaves like invalid + is invalid + with unmatched opening paren and `...` + behaves like invalid + is invalid + with negated closing paren + behaves like invalid + is invalid + with empty parentheses + behaves like invalid + is invalid + with negated closing curly + behaves like invalid + is invalid + with leading comma in arg list + behaves like invalid + is invalid + with unmatched opening paren + behaves like invalid + is invalid + with empty intersection + behaves like invalid + is invalid + with doubled ellipsis + is expected to match code "foo" + with negated ellipsis + behaves like invalid + is invalid + with empty union + behaves like invalid + is invalid + with unmatched opening curly + behaves like invalid + is invalid + with unmatched closing curly + behaves like invalid + is invalid + params + when inside a union, with a nonmatching value + behaves like nonmatching + doesn't match + when negated, with a matching value + behaves like nonmatching + doesn't match + 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 # + when preceded by $... behaves like single capture + yields captured value(s) and returns true if there is a block returns captured values if there is no block + without explicit number + is expected to match code s(:const, + s(:const, nil, :Namespace), :A), :A, and s(:const, nil, :Namespace) + when inside an intersection + is expected to match code s(:int, 20), 10, and 20 + when captured + behaves like single capture yields captured value(s) and returns true if there is a block - when in last-child position, but all children have already been matched + returns captured values if there is no block + when preceded by ... + is expected to match code s(:send, + s(:int, 1), :+, + s(:int, 10)) and s(:int, 10) + as named parameters + when extra are provided + raises an ArgumentError + when not provided + raises an ArgumentError + when provided as argument to match + is expected to match code s(:int, 10) and {:foo=>#} + in a nested sequence + is expected to match code s(:send, + s(:send, + s(:int, 5), :dec), :inc), :inc, and :dec + param number zero + in a position which matches original target node + is expected to match code 1 + in a position which does not match original target node + behaves like nonmatching + doesn't match + when negated, with a nonmatching value + is expected to match code s(:const, + s(:const, nil, :Namespace), :B) and :A + simple sequence + on a node with too many children + 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 + with a nested sequence in head position + behaves like invalid + is invalid + on a node with the same type and matching children + is expected to match code s(:int, 1), :+, and s(:int, 1) + with a nested sequence in non-head position + is expected to match code s(:send, + s(:send, nil, :obj), :a) and :b + on a node with a different type behaves like nonmatching doesn't match + regexp + matches symbols or strings + literals + double quoted string literals + is expected to match code "foo" + bare literal + on a node + behaves like nonmatching + doesn't match + on a matching literal + is expected to match code :bar + positive float literals + is expected to match code 1.0 + symbol literals + is expected to match code :foo + negative integer literals + is expected to match code -100 + negative float literals + is expected to match code -2.5 + single quoted string literals + is expected to match code "foo" in any order without ellipsis + with too few children + behaves like nonmatching + doesn't match with matching children behaves like multiple capture returns captured values if there is no block yields captured value(s) and returns true if there is a block - with too few children - behaves like nonmatching - doesn't match with too many children behaves like nonmatching doesn't match + with an ellipsis + behaves like single capture + yields captured value(s) and returns true if there is a block + returns captured values if there is no block + doubled + 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 + separated by an ellipsis + behaves like multiple capture + returns captured values if there is no block + yields captured value(s) and returns true if there is a block invalid - nested + doubled with ellipsis in wrong order + behaves like nonmatching + doesn't match + containing ellipsis not at the end + behaves like invalid + is invalid + at the beginning of a sequence behaves like invalid is invalid with an ellipsis inside and outside behaves like multiple capture returns captured values if there is no block yields captured value(s) and returns true if there is a block - containing ellipsis not at the end - behaves like invalid - is invalid doubled with ellipsis behaves like multiple capture yields captured value(s) and returns true if there is a block returns captured values if there is no block - at the beginning of a sequence + nested behaves like invalid is invalid - doubled with ellipsis in wrong order - behaves like nonmatching - doesn't match - with an ellipsis - behaves like single capture - yields captured value(s) and returns true if there is a block - returns captured values if there is no block captured without ellipsis behaves like single capture - yields captured value(s) and returns true if there is a block - returns captured values if there is no block - doubled - 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 - separated by an ellipsis - behaves like multiple capture returns captured values if there is no block yields captured value(s) and returns true if there is a block with a captured ellipsis - matching non sequential children + matching all children behaves like single capture yields captured value(s) and returns true if there is a block returns captured values if there is no block nested behaves like multiple capture - yields captured value(s) and returns true if there is a block returns captured values if there is no block - matching all children + 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 - captures on a wildcard - in head position in 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 - in head position in a sequence against literal (bug #5470) - behaves like nonmatching - doesn't match - in non-head position in 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 - in head position in a sequence against nil (bug #5470) - behaves like nonmatching - doesn't match - at the root level - behaves like single capture - returns captured values if there is no block - yields captured value(s) and returns true if there is a block - nested in any child - behaves like multiple capture - yields captured value(s) and returns true if there is a block - returns captured values if there is no block - in a nested sequence - behaves like single capture - returns captured values if there is no block - yields captured value(s) and returns true if there is a block - node type - for a child - on a child with a different type + caret (ascend) + 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 + 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 - on a child with the same type - is expected to match code s(:send, nil, :foo) and :bar - on a child litteral + inside an intersection + is expected to match code 1 + inside a union + is expected to match code "abc" + used with a node type + which doesn't match behaves like nonmatching doesn't match - in seq head - on a child with a different type + which matches + is expected to match code 1 + repeated + using ? + with too many matching children behaves like nonmatching doesn't match - on a node with the same type - is expected to match code s(:ivar, :@ivar), :+, and s(:int, 2) - unions - with a nested sequence - is expected to match code s(:const, nil, :Const) and :method - variadic - with variadic terms - works for cases with variadic terms before and after union - works for cases with variadic terms after union - works for cases with fixed arity before and after union - multiple - works for complex cases - with fixed terms - works for cases with variadic terms after union - works for cases with variadic terms before and after union - works for cases with fixed arity before and after union - at the top level - 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 symbol literals - when the AST has a matching symbol - is expected to match code s(:send, nil, :obj) and :b - when the AST does not have a matching symbol - behaves like nonmatching - doesn't match - containing 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 - containing mixed node and literals - is expected to match code nil and :obj - nested inside a sequence - is expected to match code s(:const, nil, :Const) and :method + 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 + 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 + at beginning of sequence + behaves like invalid + is invalid + with an ellipsis in the same sequence + is expected to match code "[:hello, 1, 2, 3]" + using + + behaves like repeated pattern + at beginning of sequence + behaves like invalid + is invalid + with one match + behaves like single capture + yields captured value(s) and returns true if there is a block + returns captured values if there is no block + with an ellipsis in the same sequence + is expected to match code "[:hello, 1, 2, 3]" + with zero match + behaves like nonmatching + doesn't match + with matching children + behaves like single capture + yields captured value(s) and returns true if there is a block + returns captured values if there is no block + using * + with no match + behaves like nonmatching + doesn't match + 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 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 + 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 + behaves like repeated pattern + with one match + behaves like single capture + returns captured values if there is no block + yields captured value(s) and returns true if there is a block + at beginning of sequence + behaves like invalid + is invalid + with an ellipsis in the same sequence + is expected to match code "[:hello, 1, 2, 3]" + without capture + is expected to match code s(:sym, :hello), s(:int, 1), s(:int, 2), and s(:int, 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 sequence with trailing ... - on a node with fewer children, with a wildcard preceding + on a node with the same type and fewer children behaves like nonmatching doesn't match - on a node with non-matching children + on a node with fewer children, with a wildcard preceding behaves like nonmatching doesn't match on a node with the same type and more children @@ -3015,132 +2854,54 @@ is expected to match code s(:int, 1), :blah, s(:int, 1), and s(:sym, :something) with 1 child more is expected to match code s(:int, 1), :blah, and s(:int, 1) + on a node with non-matching children + behaves like nonmatching + doesn't match on a node with a different type behaves like nonmatching doesn't match on a node with the same type and exact number of children is expected to match code s(:int, 1) and :blah - on a node with the same type and fewer children - behaves like nonmatching - doesn't match - nil - nil literals - is expected to match code - against a node pattern (bug #5470) - behaves like nonmatching - doesn't match - nil value in AST - behaves like nonmatching - doesn't match - nil value in AST, use nil? method - is expected to match code nil and :foo - negation - 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 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 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 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 sequence - 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) - with a node with non-matching children - is expected to match code :@b and s(:int, 1) - on a symbol - with a matching symbol + 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 + node type + in seq head + on a node with the same type + is expected to match code s(:ivar, :@ivar), :+, and s(:int, 2) + on a child with a different type behaves like nonmatching doesn't match - 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 + for a child + on a child litteral behaves like nonmatching doesn't match - descend - 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)) - 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 - nested - behaves like single capture - yields captured value(s) and returns true if there is a block - returns captured values if there is no block - with a match multiple levels, depth first - behaves like single capture - yields captured value(s) and returns true if there is a block - returns captured values if there is no block - literals - double quoted string literals - is expected to match code "foo" - negative float literals - is expected to match code -2.5 - single quoted string literals - is expected to match code "foo" - bare literal - on a matching literal - is expected to match code :bar - on a node + on a child with a different type behaves like nonmatching doesn't match - positive float literals - is expected to match code 1.0 - symbol literals - is expected to match code :foo - negative integer literals - is expected to match code -100 + on a child with the same type + is expected to match code s(:send, nil, :foo) and :bar wildcards - unnamed wildcards - within a sequence - is expected to match code nil and :Const + named wildcards 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 + unifying the node type with an argument + is expected to match code s(:send, nil, :obj) and :send + with values which cannot be unified + behaves like nonmatching + doesn't match + with values which can be unified + is expected to match code s(:int, 5), :+, and s(:int, 5) within a sequence with other patterns intervening is expected to match code :@abc and s(:int, 22) - negated - behaves like nonmatching - doesn't match in head position of a sequence is expected to match code s(:int, 1), :+, and s(:send, nil, :a) - named wildcards within a union confined to the union without unification @@ -3154,288 +2915,168 @@ matching the unified branch is expected to match code s(:int, 5) and s(:int, 5) 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 the first branch - is expected to match code s(:array, - s(:int, 1), - s(:int, 2)) and s(:int, 2) matching another branch is expected to match code s(:array, s(:int, 2), s(:int, 1)) and s(:int, 2) + matching the first branch + is expected to match code s(:array, + s(:int, 1), + s(:int, 2)) and s(:int, 2) + that can not be unified + behaves like nonmatching + doesn't match + with branches without the wildcard + encountered after + behaves like invalid + is invalid + encountered first + behaves like invalid + is invalid with a preceding unifying constraint - that can not be unified - behaves like nonmatching - doesn't match matching a branch is expected to match code s(:int, 2) and s(:array, s(:int, 2), s(:int, 1)) + that can not be unified + behaves like nonmatching + doesn't match + unnamed wildcards 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 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 values which can be unified - is expected to match code s(:int, 5), :+, and s(:int, 5) - unifying the node type with an argument - is expected to match code s(:send, nil, :obj) and :send - with values which cannot be unified - behaves like nonmatching - doesn't match - funcalls - without extra arguments - is expected to match code :a and s(:int, 1) - with multiple arguments - is expected to match code s(:str, "c"), "a", and "d" - with one argument - is expected to match code s(:str, "foo") and "foo" - macros - with a pattern with captures - def_node_search - without a predicate name - when called on matching code - returns an enumerator yielding the captures - when the pattern contains keyword_params - returns an enumerator yielding the captures - when helper is called with default keyword_params - is overridden when calling the matcher - some defaults are not params - raises an error - and no value is given to the matcher - uses the defaults - when it errors - raises an error with the right location - 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 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) - def_node_matcher - 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 eq :hello - with a pattern without captures - def_node_matcher - returns the method name - when called on matching code - is expected to match code :hello - when called on non-matching code - behaves like nonmatching - doesn't match - when it errors - raises an error with the right location - def_node_search - returns the method name - without a predicate name - when it errors - raises an error with the right location - when called on matching code - returns an enumerator yielding the matches - when called on non-matching code - returns an enumerator yielding nothing - with a 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 - 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 - repeated - using * - 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 - 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 - 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 no match - behaves like nonmatching - doesn't match - without capture - is expected to match code s(:sym, :hello), s(:int, 1), s(:int, 2), and s(:int, 3) - 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 - at beginning of sequence - behaves like invalid - is invalid - with zero match - behaves like single capture - returns captured values if there is no block - yields captured value(s) and returns true if there is a block - using ? - with too many matching children - behaves like nonmatching - doesn't match - behaves like repeated pattern - with an ellipsis in the same sequence - is expected to match code "[:hello, 1, 2, 3]" - with one match - behaves like single capture - yields captured value(s) and returns true if there is a block - returns captured values if there is no block - at beginning of sequence - behaves like invalid - is invalid - with zero match - behaves like single capture - returns captured values if there is no block - yields captured value(s) and returns true if there is a block - using + - behaves like repeated pattern - with one match - behaves like single capture - returns captured values if there is no block - yields captured value(s) and returns true if there is a block - with an ellipsis in the same sequence - is expected to match code "[:hello, 1, 2, 3]" - at beginning of sequence - behaves like invalid - is invalid - with 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 - with zero match + negated behaves like nonmatching doesn't match - commas - with commas randomly strewn around - behaves like invalid - is invalid captures within union - with complex nesting + within nested sequences behaves like multiple capture + returns captured values if there is no block yields captured value(s) and returns true if there is a block + on simple subpatterns + behaves like single capture returns captured values if there is no block - within nested sequences + yields captured value(s) and returns true if there is a block + with complex nesting 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 different number of captures in each branch behaves like invalid is invalid - on simple subpatterns + 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) + .descend + yields all children depth first + yields the given argument if it is not a Node + descend + with a match multiple levels, depth first 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 + 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 no remaining pattern at the end - behaves like single capture yields captured value(s) and returns true if there is a block - returns captured values if there is no block - with a remaining sequence at the end + 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)) + without match + behaves like nonmatching + doesn't match + nested behaves like single capture - yields captured value(s) and returns true if there is a block returns captured values if there is no block - with remaining patterns at the end - behaves like single capture + yields captured value(s) and returns true if there is a block + captures on a wildcard + in head position in a sequence against literal (bug #5470) + behaves like nonmatching + doesn't match + nested in any child + behaves like multiple capture yields captured value(s) and returns true if there is a block returns captured values if there is no block - with a remaining node type at the end + in head position in 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 - with a remaining capture at the end - behaves like multiple capture + in non-head position in 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 - with a remaining [] at the end + in head position in a sequence against nil (bug #5470) + behaves like nonmatching + doesn't match + at the root level behaves like single capture yields captured value(s) and returns true if there is a block returns captured values if there is no block - with a remaining set at the end + 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 - after a child + ellipsis + with a wildcard 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 - at the very beginning of a sequence - behaves like single capture yields captured value(s) and returns true if there is a block + 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 returns captured values if there is no block - with a remaining literal at the end - behaves like single capture yields captured value(s) and returns true if there is a block - returns captured values if there is no block - bare node type - #pattern - returns the pattern - marshal compatibility - is expected to match code s(:send, nil, :obj) and :method - #to_s - is instructive - #== - returns true iff the patterns are similar - yaml compatibility - is expected to match code s(:send, nil, :obj) and :method - on a node with the same type - is expected to match code s(:send, nil, :obj) and :method - on a node with a matching, hyphenated type - is expected to match code s(:lvasgn, :a), :+, and s(:int, 1) - #dup - is expected to match code s(:send, nil, :obj) and :method - on a node with a different type + with a set at the end, but no remaining child to match it + behaves like nonmatching + doesn't match + with a nested sequence at the end, but no remaining child + behaves like nonmatching + doesn't match + with [] 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 - regexp - matches symbols or strings captures which also perform a match + 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 + 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 [] 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 sequence + behaves like single capture returns captured values if there is no block yields captured value(s) and returns true if there is a block on a literal @@ -3444,3087 +3085,3482 @@ returns captured values if there is no block on a set behaves like single capture - yields captured value(s) and returns true if there is a block returns captured values if there is no block - on a sequence + yields captured value(s) and returns true if there is a block + 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 + captures on ... + 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 no remaining pattern at the end + behaves like single capture returns captured values if there is no block - on a node type + 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 yields captured value(s) and returns true if there is a block - when nested - behaves like multiple capture + 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 + at the very beginning of a sequence + behaves like single capture returns captured values if there is no block - bad syntax - with empty union subsequence in seq head - behaves like invalid - is invalid - with unmatched closing curly - behaves like invalid - is invalid - with doubled comma in arg list - behaves like invalid - is invalid - with doubled ellipsis - is expected to match code "foo" - with leading comma in arg list - behaves like invalid - is invalid - with empty parentheses - behaves like invalid - is invalid - with negated closing curly - behaves like invalid - is invalid - with unmatched closing paren - behaves like invalid - is invalid - with unmatched opening paren and `...` - behaves like invalid - is invalid - with empty intersection - behaves like invalid - is invalid - with unmatched opening paren - behaves like invalid - is invalid - with empty union - behaves like invalid - is invalid - with negated closing 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 negated ellipsis - behaves like invalid - is invalid - with unmatched opening curly - behaves like invalid - is invalid - comments - behaves like single capture - returns captured values if there is no block - yields captured value(s) and returns true if there is a block - caret (ascend) - 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 - 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 - .descend - yields all children depth first - yields the given argument if it is not a Node - params - without explicit number - is expected to match code s(:const, - s(:const, nil, :Namespace), :A), :A, and s(:const, nil, :Namespace) - 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 negated, with a matching value - behaves like nonmatching - doesn't match - when preceded by $... + yields captured value(s) and returns true if there is a block + with a remaining node type at the end behaves like single capture + yields captured value(s) and returns true if there is a block returns captured values if there is no block + with a remaining set at the end + behaves like single capture yields captured value(s) and returns true if there is a block - when preceded by ... - is expected to match code s(:send, - s(:int, 1), :+, - s(:int, 10)) and s(:int, 10) - 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=>#} - when not provided - raises an ArgumentError - when inside a union, with a nonmatching value - behaves like nonmatching - doesn't match - when captured + returns captured values if there is no block + with a remaining [] at the end behaves like single capture returns captured values if there is no block yields captured value(s) and returns true if there is a block - 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 - when inside a union, with a matching value - is expected to match code s(:int, 10) and 10 - 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 matches original target node - is expected to match code 1 - in a position which does not match original target node - behaves like nonmatching - doesn't match - simple sequence - 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 the same type and matching children - is expected to match code s(:int, 1), :+, and s(:int, 1) - on a node with the same type and non-matching children - with non-matching receiver type - behaves like nonmatching - doesn't match - with non-matching selector - behaves like nonmatching - doesn't match - on a node with 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 too many children - behaves like nonmatching - doesn't match - ellipsis - with a wildcard at the end, but no remaining child to match it - behaves like nonmatching - doesn't match - with [] at the end, but no remaining child to match it - behaves like nonmatching - doesn't match - preceding a capture + with remaining patterns at the end behaves like single capture returns captured values if there is no block yields captured value(s) and returns true if there is a block - with a nodetype at the end, but no remaining child to match it - behaves like nonmatching - doesn't match - preceding multiple captures + with a remaining capture at the end behaves like multiple capture returns captured values if there is no block yields captured value(s) and returns true if there is a block - at the very beginning of a sequence - is expected to match code s(:int, 10), :*, and s(:int, 1) - with a set at the end, but no remaining child to match it - behaves like nonmatching - doesn't match - with a nested sequence at the end, but no remaining child - behaves like nonmatching - doesn't match + 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 + unions + with a nested sequence + is expected to match code s(:const, nil, :Const) and :method + variadic + multiple + works for complex cases + with variadic terms + works for cases with fixed arity before and after union + works for cases with variadic terms after union + works for cases with variadic terms before and after union + with fixed terms + works for cases with variadic terms after union + works for cases with variadic terms before and after union + works for cases with fixed arity before and after union + at the top level + containing symbol literals + when the AST has a matching symbol + is expected to match code s(:send, nil, :obj) and :b + when the AST does not have a matching symbol + behaves like nonmatching + doesn't match + containing 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 multiple [] + on a node which meets all requirements of the second [] + is expected to match code 2.4 + on a node which meets all requirements of the first [] + is expected to match code 3 + on a node which meets some requirements but not all + behaves like nonmatching + doesn't match + containing mixed node and literals + is expected to match code nil and :obj + nested inside a sequence + is expected to match code s(:const, nil, :Const) and :method -RuboCop::AST::ClassNode - #body - with a single expression body - is expected to be send type - with a multi-expression body - is expected to be begin type - with an empty body - is expected to be nil - #identifier - is expected to be const type +RuboCop::AST::AsgnNode + #expression + with a `gvasgn` node + is expected to eq s(:send, nil, :value) + with a `lvasgn` node + is expected to eq s(:send, nil, :value) + with a `ivasgn` node + is expected to eq s(:send, nil, :value) + with a `cvasgn` node + is expected to eq s(:send, nil, :value) + #name + with a `lvasgn` 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 `ivasgn` node + is expected to eq :@var .new - is expected to be a kind of RuboCop::AST::ClassNode - #parent_class - when no parent class is specified + with a `cvasgn` 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 + with a `ivasgn` node + is expected to be a kind of RuboCop::AST::AsgnNode + +RuboCop::AST::ResbodyNode + .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 + #exception_variable + when an exception variable is not given is expected to be nil - when a parent class is specified - is expected to be const type + 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 + is expected to all be const type + with a single exception + is expected to eq 1 + is expected to all be const type -RuboCop::AST::OpAsgnNode +RuboCop::AST::SymbolNode + #value + is expected to eq :foo .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 :% + with a symbol node + is expected to be a kind of RuboCop::AST::SymbolNode + +Set#=== + tests for inclusion + +RuboCop::AST::UntilNode + .new + with a statement until + is expected to be a kind of RuboCop::AST::UntilNode + with a modifier until + is expected to be a kind of RuboCop::AST::UntilNode + #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 + #loop_keyword? + with a modifier until + is expected to be loop keyword + with a statement until + is expected to be loop keyword + #keyword + is expected to eq "until" + #inverse_keyword + is expected to eq "while" + +RuboCop::AST::HashNode + #each_pair + when passed a block + yields all the pairs + when not passed a block + is expected to be a kind of Enumerator + #each_value + when not passed a block + is expected to be a kind of Enumerator + when passed a block + yields all the pairs + #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 + #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 + #values + with a hash with string keys + is expected to eq 2 + is expected to all be send type + with an empty hash + is expected to be empty + with a hash with literal values + is expected to eq 3 + is expected to all be literal + #pairs_on_same_line? + with all pairs on the same line + is expected to be pairs on same line + with no pairs on the same line + is expected not to be pairs on same line + with some pairs on the same line + is expected to be pairs on same line + #each_key + when passed a block + yields all the pairs + when not passed a block + is expected to be a kind of Enumerator + .new + is expected to be a kind of RuboCop::AST::HashNode + #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 + #pairs + with a hash of variables + is expected to eq 2 + is expected to all be pair type + with an empty hash + is expected to be empty + with a hash of literals + is expected to all be pair type + is expected to eq 3 + #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 all be sym type + is expected to eq 3 + +RuboCop::AST::AndAsgnNode + .new + is expected to be a kind of RuboCop::AST::AndAsgnNode + #name + is expected to eq :var #assignment_node is expected to be a kind of RuboCop::AST::AsgnNode #expression is expected to eq s(:send, nil, :value) - #name - is expected to eq :var + #operator + is expected to eq :"&&" -RuboCop::AST::RegexpNode - #ignore_case? - with no options - is expected not to be ignore case - with other options - is expected not to be ignore case - with i and other options - is expected to be ignore case - with only i option - is expected to be ignore case - #fixed_encoding? - with no options - is expected not to be fixed encoding - with other options - is expected not to be fixed encoding - with only u option - is expected to be fixed encoding - with u and other options - is expected to be fixed encoding - #multiline_mode? - with only m option - is expected to be multiline mode - with no options - is expected not to be multiline mode - with m and other options - is expected to be multiline mode - with other options - is expected not to be multiline mode - #no_encoding? - with n and other options - is expected to be no encoding - with only n option - is expected to be no encoding - with other options - is expected not to be no encoding - with no options - is expected not to be no encoding - #options - with a regexp with "o" option - is expected to eq 0 - with an empty regexp - is expected to eq 0 - with a regexp without option +RuboCop::AST::InPatternNode + when using Ruby 2.7 or newer + #branch_index + is expected to eq 1 + is expected to eq 2 is expected to eq 0 - with a regexp with multiple options + #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? + without a then keyword + is expected not to be then + with a then keyword + is expected to be then + #pattern + with a hash pattern + is expected to be hash pattern type + with an as pattern + is expected to be match as type + with a value pattern + is expected to be int type + with a pin operator + is expected to be pin type + with an array pattern + is expected to be array pattern type + with a variable pattern + is expected to be match var type + with an alternative pattern + is expected to be match alt type + +RuboCop::AST::KeywordSplatNode + #same_line? + when both pairs are on the same line + is expected to be same line s(:kwsplat, + s(:send, nil, :foo)) + when a multiline pair shares the same line + is expected to be same line s(:pair, + s(:sym, :a), + s(:begin)) + is expected to be same line s(:kwsplat, + s(:send, nil, :foo)) + when pairs are on separate lines + is expected not to be same line s(:kwsplat, + s(:send, nil, :foo)) + #hash_rocket? + is expected not to be hash rocket + #operator + is expected to eq "**" + #value_delta + 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 left aligned + is expected to eq 0 + when keyword splat is ahead + is expected to eq 0 + when using hash rocket delimiters + when keyword splat is ahead + is expected to eq 0 + when keyword splat is left aligned + is expected to eq 0 + when keyword splat is on the same line + is expected to eq 0 + when keyword splat is behind + is expected to eq 0 + #value + is expected to eq s(:kwsplat, + s(:send, nil, :foo)) + .new + is expected to be a kind of RuboCop::AST::KeywordSplatNode + #key_delta + with alignment set to :right + when using colon delimiters + when keyword splat is behind + is expected to eq 0 + when keyword splat is ahead + is expected to eq 0 + when keyword splat is aligned + 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 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 + with alignment set to :left + when using hash rocket delimiters + when keyword splat is behind + is expected to eq -2 + when keyword splat is on the same line + is expected to eq 0 + when keyword splat is aligned + is expected to eq 0 + when keyword splat is ahead + is expected to eq 2 + when using colon delimiters + when keyword splat is aligned + is expected to eq 0 + when keyword splat is on the same line + is expected to eq 0 + when keyword splat is behind + is expected to eq -2 + when keyword splat is ahead + is expected to eq 2 + #key + is expected to eq s(:kwsplat, + s(:send, nil, :foo)) + #colon? + is expected not to be colon + +RuboCop::AST::ForNode + #keyword + is expected to eq "for" + .new + is expected to be a kind of RuboCop::AST::ForNode + #loop_keyword? + is expected to be loop keyword + #post_condition_loop? + is expected not to be post condition loop + #void_context? + without a do keyword + is expected to be void context + with a do keyword + is expected to be void context + #collection + is expected to be sym type + #body + is expected to be sym type + #do? + without a do keyword + is expected not to be do + with a do keyword + is expected to be do + #variable + is expected to be lvasgn type + +RuboCop::AST::IfNode + #branches + with a ternary operator + is expected to all be literal + is expected to eq 2 + with an elsif statement + is expected to all be literal is expected to eq 3 - with a regexp with single option + with an unless statement + is expected to all be literal is expected to eq 1 - #regopt - with a multi-line regexp without option - is expected to be empty - is expected to be regopt type - with an empty regexp - 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 with option - is expected to eq [:i, :m, :x] - is expected to be regopt type - with an empty regexp with option - is expected to eq [:i, :x] - is expected to be regopt type - with a regexp without option - is expected to be empty - is expected to be regopt type - #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 - #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 %r/-delimiters - is expected to be percent r literal - with /-delimiters - is expected not to be percent r literal - #single_interpolation? - with o and other options - is expected to be single interpolation - with only o option - is expected to be single interpolation - with no options - is expected not to be single interpolation - with other options - is expected not to be single interpolation - #slash_literal? - with multi-line %r{-delimiters - is expected not to be slash literal - with %r<-delimiters - is expected not to be slash literal - with %r/-delimiters - is expected not to be slash literal - with /-delimiters - is expected to be slash literal - with %r{-delimiters - is expected not to be slash literal - #delimiters - 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 ["<", ">"] - with multi-line %r{-delimiters - is expected to eq ["{", "}"] - .new - is expected to be a kind of RuboCop::AST::RegexpNode - #to_regexp - with a regexp with an "u" option - is expected to eq "/abc/" - with a regexp with an "n" option - is expected to eq "/abc/n" - with an empty regexp with option - is expected to eq //ix - with a multi-line regexp without option - is expected to eq / -.+ -/ - with an empty regexp - is expected to eq // - with a multi-line regexp with option - is expected to eq / -.+ -/ix - with a regexp without option - is expected to eq /.+/ - with a regexp with an "o" option - is expected to eq "/abc/i" - with a regexp with option - is expected to eq /.+/mix - #content - with a regexp without option - is expected to eq ".+" - with an empty regexp + with an else statement + is expected to eq 2 + is expected to all be literal + with an if statement + is expected to all be literal + is expected to eq 1 + #if_branch + with an if statement + is expected to be sym type + with a ternary operator + is expected to be sym type + with an unless statement + is expected to be sym type + #modifier_form? + with a modifier if statement + is expected to be modifier form + with a ternary operator + is expected not to be modifier form + with a non-modifier if statement + is expected not to be modifier form + with a non-modifier unless statement + is expected not to be modifier form + with a modifier unless statement + is expected to be modifier form + #inverse_keyword? + with an if statement + is expected to eq "unless" + with an unless statement + is expected to eq "if" + with a ternary operator is expected to eq "" - with a regexp with option - is expected to eq ".+" - with a multi-line regexp with option - is expected to eq "\n.+\n" - with an empty regexp with option + #elsif? + with an elsif statement + is expected to be elsif + with an if statement comtaining an elsif + is expected not to be elsif + without an elsif statement + is expected not to be elsif + #else_branch + with an if statement + is expected to be int type + with an unless statement + is expected to be int type + with a ternary operator + is expected to be int type + #unless? + with an unless statement + is expected to be unless + with an if statement + is expected not to be unless + with a ternary operator + is expected not to be unless + #each_branch + when passed a block + yields all the branches + when not passed a block + is expected to be a kind of Enumerator + #ternary? + with an if statement + is expected not to be ternary + with an unless statement + is expected not to be ternary + with a ternary operator + is expected to be ternary + #keyword + with a ternary operator is expected to eq "" - with a multi-line regexp without option - is expected to eq "\n.+\n" - #delimiter? - with /-delimiters - is expected not to be delimiter "{" - is expected to be delimiter "/" - with %r/-delimiters - is expected not to be delimiter "%r/" - is expected not to be delimiter "{" - is expected not to be delimiter "}" - is expected not to be delimiter "%" - 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 "%r{" - is expected not to be delimiter "%" - is expected to be delimiter "}" - is expected to be delimiter "{" - is expected not to be delimiter "/" - is expected not to be delimiter "%r/" - is expected not to be delimiter "r" - is expected not to be delimiter "%r" - with multi-line %r{-delimiters - is expected not to be delimiter "%r/" - is expected not to be delimiter "%r{" - is expected to be delimiter "{" - is expected to be delimiter "}" - is expected not to be delimiter "%r" - is expected not to be delimiter "%" - is expected not to be delimiter "r" - is expected not to be delimiter "/" - with %r<-delimiters - 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 to be delimiter "<" - is expected not to be delimiter "%" - is expected not to be delimiter "%r" - is expected not to be delimiter "/" - is expected to be delimiter ">" - is expected not to be delimiter "}" - is expected not to be delimiter "%r{" - #extended? - with no options - is expected not to be extended - with x and other options - is expected to be extended - with only x option - is expected to be extended - with other options - is expected not to be extended + with an if statement + is expected to eq "if" + with an unless statement + is expected to eq "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 conditionals in else clause + is expected not to be elsif conditional + with nested conditionals in if clause + is expected not to be elsif conditional + with one elsif conditional + is expected to be elsif conditional + with multiple elsif conditionals + is expected to be elsif conditional + with nested ternary operators + when nested in the falsey branch + is expected not to be elsif conditional + when nested in the truthy branch + is expected not to be elsif conditional + #nested_conditional? + with nested conditionals in elsif clause + 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 ternary operators + when nested in the truthy branch + is expected to be nested conditional + when nested in the falsey branch + is expected to be nested conditional + #else? + with an elsif statement + is expected to be else + without an else statement + is expected not to be elsif + .new + with a ternary operator + 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 regular if statement + is expected to be a kind of RuboCop::AST::IfNode -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 +RuboCop::AST::FloatNode .new - 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 heredoc - is expected not to be character literal - with a normal string literal - is expected not to be character literal - with a character literal - is expected to be character literal + is expected to be a kind of RuboCop::AST::FloatNode + #value + is expected to eq 1.5 + #sign? + explicit positive float + is expected to be sign + explicit negative float + is expected to be sign + +RuboCop::AST::RuboCopCompatibility + when ran from an incompatible version of Rubocop + issues a warning + when ran from a compatible version of Rubocop + issues a warning + +RuboCop::AST::ForwardArgsNode + when using Ruby 2.7 or newer + #to_a + is expected to contain exactly (be forward arg type) RuboCop::AST::Traversal knows all current node types - for example a b{c d}, 1.0i do end - traverses all nodes - for example class Foo end - traverses all nodes - for example <<-'HERE' -#@1 -HERE + for example "#@a #@@a #$a" traverses all nodes - for example case foo; when 'bar'; bar; end + for example p :foo, {** proc do end, b: proc do end} traverses all nodes - for example f{ |foo: 1, &b| } + for example case foo; + in {Foo: 42 + } + false + ; end traverses all nodes - for example foo[0, 1] &&= 2 + for example foo and bar traverses all nodes - for example if foo -then bar end + for example fun(1) { } traverses all nodes - for example def f(**nil); end + for example *b = bar traverses all nodes - for example a b{c(d)}, 1 do end + for example def f o=1, &b; end traverses all nodes - for example <<-E - 1 \ - 2 - 3 -E + for example def f ((*)); end traverses all nodes - for example a b{c(d)}, /x/m do end + for example f{ |foo: 1, &b| } traverses all nodes - for example foo[1, 2] + for example <<-"HERE" +a\ +b +HERE traverses all nodes - for example o = { -a: -1 -} + for example not m foo traverses all nodes - for example `#@1` + for example foo, bar, baz = 1, 2 traverses all nodes - for example f{ |o=1, *r, &b| } + for example case foo; in 1 | 2 then true; end traverses all nodes - for example foo[:baz => 1,] + for example case foo; in "#{ 'a' }": 1 then true; end traverses all nodes - for example foo.m += raise(bar) rescue nil + for example p <<~E + x +E traverses all nodes - for example -> * { } + for example foo.a ||= 1 traverses all nodes - for example meth rescue bar + for example a b{c d}, "x" do end traverses all nodes - for example def f &b; end + for example class Foo < Bar; end traverses all nodes - for example %s{#@1} + for example p <<~E + x + \ y +E traverses all nodes - for example if foo; bar; else baz; end + for example foo.A += m foo traverses all nodes - for example foo && bar + for example retry traverses all nodes - for example def x; self::A ||= 1; end + for example module A; _1; end traverses all nodes - for example -> a: { } + for example a b{c(d)}, 1.0r do end traverses all nodes - for example foo::(1) + for example -2.0 ** 10 traverses all nodes - for example a # -# -.foo + for example f{ |a, o=1, *r, p, &b| } traverses all nodes - when given an unexpected AST - with too many children - raises debugging error - with too few children - raises debugging error - for example def f ((a, *r, p)); end + for example if foo; bar; elsif baz; 1; else 2; end traverses all nodes - for example 1..2 + for example def f *, **; end traverses all nodes - for example foo === 1 + for example while foo; meth end traverses all nodes - for example foo::C ||= raise bar rescue nil + for example not(foo) traverses all nodes - for example "#@@1" + for example def m; class << self; module M; end; end; end traverses all nodes - for example case foo; in ::A then true; end + for example foo.fun traverses all nodes - for example a b(c d), "x" do end + for example fun traverses all nodes - for example case foo; in "#{ 'a' }": then true; end + for example foo[1, 2] = 3 traverses all nodes - for example _2 = 1 + for example super(foo) traverses all nodes - for example while class << self; tap do end; end; break; end + for example `foobar` traverses all nodes - for example %q(foobar) + for example def m; class << self; A = nil; end; end traverses all nodes - for example foo = meth rescue bar + for example %x{#@@1} traverses all nodes - for example begin; meth; rescue; baz; ensure; bar; end + for example f{ |*s, &b| } traverses all nodes - for example foo.a += m foo + for example case foo; in ^foo then nil; end traverses all nodes - for example <<-`HERE` -#@1 -HERE + for example fun (f bar) traverses all nodes - for example f{ |&b| } + for example def String::foo; end traverses all nodes - for example def a b: -return -end + for example class A; _1; end traverses all nodes - for example "#{1}" + for example def x; ::A ||= 1; end traverses all nodes - for example ->(a; foo, bar) { } + for example return(foo) traverses all nodes - for example ((b, )) = foo + for example {a: if true then 42 end} traverses all nodes - for example fun(:foo => 1, &baz) + for example false ? raise {} : tap {} traverses all nodes - for example 42.1ri + for example ..100 traverses all nodes - for example module Foo; end + for example a b{c d}, 1 do end traverses all nodes - for example $foo + for example a = b = raise :x traverses all nodes - for example while class Foo; tap do end; end; break; end + for example ...100 traverses all nodes - for example fun + for example true ? 1.tap do |n| p n end : 0 traverses all nodes - for example ...100 + for example foo ? 1 : 2 traverses all nodes - for example foo.(1) + for example BEGIN { 1 } traverses all nodes - for example def f(**); end + for example def f(&block); end traverses all nodes - for example unless foo then bar; end + for example f{ |o=1, &b| } traverses all nodes - for example Bar::Foo + for example a b(c(d)), /x/m do end traverses all nodes - for example def f foo = 1; end + for example p <<~E + E traverses all nodes - for example -> do rescue; end + for example :'foo' traverses all nodes - for example def foo() a:b end + for example a += b = raise :x traverses all nodes - for example nil + for example meth 1 do end.fun bar do end traverses all nodes - for example foo > 1 + for example begin; rescue LoadError; else; end traverses all nodes - for example %x{#@@1} + for example %s{a\ +b} traverses all nodes - for example -2.0 ** 10 + for example def f foo: +; end traverses all nodes - for example until foo do meth end + for example case foo; in [*, x] then true; end traverses all nodes - for example redo + for example class << foo; nil; end traverses all nodes - for example %W[#@1] + for example begin; meth; rescue; baz; else foo; ensure; bar end traverses all nodes - for example a b{c d}, :e do end + for example begin; meth; rescue foo => ex; bar; end traverses all nodes - for example case foo; in [x, y, *] then true; end + for example a b{c(d)}, 1 do end traverses all nodes - for example f{ |a,| } + for example a b{c(d)}, /x/ do end traverses all nodes - for example def f (((a))); end + for example case foo; in ** then true; end traverses all nodes - for example case foo; in 1 | 2 then true; end + for example super() traverses all nodes - for example def foo(...); super(...); end + for example f{ |foo: 1, bar: 2, **baz, &b| } traverses all nodes - for example foo.m += raise bar rescue nil + for example redo traverses all nodes - for example case foo; in [x, y] then true; end + for example foo, bar = meth rescue [1, 2] traverses all nodes - for example %i{a\ -b} + for example fun! traverses all nodes - for example foo || bar + for example def foo + a:b end traverses all nodes - for example !foo + for example foo[bar,] traverses all nodes - for example p :foo, {** proc do end, b: proc do end} + for example assert do: true traverses all nodes - for example def self::foo; end + for example foo !~ 1 traverses all nodes - for example yield(foo) + for example foo (-1.3).abs traverses all nodes - for example def f *r, p, &b; end + for example ->{ } traverses all nodes - for example "foo#{bar}baz" + for example def foo(...); bar(...); end traverses all nodes - for example case foo; - in {a: - 2} - false - ; end + for example %i[ #@@1 ] traverses all nodes - for example begin foo!; bar! end + for example return foo traverses all nodes - for example f{ |a| } + for example $+ traverses all nodes - for example 42ri + for example begin; meth; ensure; bar; end traverses all nodes - for example m { |**nil| } + when a class defines `on_block_pass` + calls it for all block-pass arguments + for example foo.a &&= 1 traverses all nodes - for example p begin 1.times do 1 end end + for example super do end traverses all nodes - for example alias :foo bar + for example f { || a:b } traverses all nodes - for example if (bar; a, b = foo); end + for example var = 10; var traverses all nodes - for example foo | 1 + for example +2.0 ** 10 traverses all nodes - for example unless foo; bar; else baz; end + for example %x{a\ +b} traverses all nodes - for example foo[bar, :baz => 1,] + for example case foo; in **nil then true; end traverses all nodes - for example f{ |*r, p, &b| } + for example m a + b do end traverses all nodes - for example bar unless foo + for example <<~FOO + baz\ + qux +FOO traverses all nodes - for example foo = bar, 1 + for example break(foo) traverses all nodes - for example foo::A += m foo + for example /source/im traverses all nodes - for example Bar::Foo = 10 + for example 1..2 traverses all nodes - for example a b(c(d)), /x/m do end + for example foo, bar = m foo traverses all nodes - for example case foo; in a: 1, _a:, ** then true; end + for example foo += meth rescue bar traverses all nodes - for example def foo(_, _); end + for example `#@1` traverses all nodes - for example def f ; end + for example case foo; when 1, *baz; bar; when *foo; end traverses all nodes - for example $10 + for example if foo; bar; end traverses all nodes - for example foo, bar = 1, 2 + for example * = bar traverses all nodes - for example 1.33 + for example case foo; in "#{ %Q{a} }": 1 then true; end traverses all nodes - for example alias $a $+ + for example foo.fun (1) {} traverses all nodes - for example <<`HERE` + for example <= 1 - traverses all nodes - for example def f o=1, *r, p, &b; end + for example foo[0] += raise bar rescue nil traverses all nodes - for example def self.foo; end + for example def String; end traverses all nodes - for example foo != 1 + for example foo && (a, b = bar) traverses all nodes - for example foo::A = 1 + for example @@foo traverses all nodes - for example begin ensure end + for example 'a\ +b' traverses all nodes - for example foo, bar, baz = 1, 2 + for example %I[#@@1] traverses all nodes - for example foo * 1 + for example a b{c d}, 1.0 do end traverses all nodes - for example self.a, self[1, 2] = foo + for example %q{a\ +b} traverses all nodes - for example f { || a:b } + for example /#{1}(?bar)/ =~ 'bar' traverses all nodes - for example foo::m += raise(bar) rescue nil + for example `a\ +b` traverses all nodes - for example def f(*); end + for example ->(a) { } traverses all nodes - when a class defines on_arg - calls it for all arguments - for example proc {_1 = nil} + for example f{ |o=1, *r, &b| } traverses all nodes - for example 1 in [a]; a + for example bar def foo; self.each do end end traverses all nodes - for example a b{c(d)}, /x/ do end + for example a b(c(d)), 1 do end traverses all nodes - for example case foo; in [x, y, *z] then true; end + for example @foo, @@bar = *foo traverses all nodes - for example fun(1) { } + for example let () { m(a) do; end } traverses all nodes - for example false ? raise do end : tap do end + for example foo =~ 1 traverses all nodes - for example <<~E - 1 \ - 2 - 3 -E + for example def END; end traverses all nodes - for example [1, *foo, 2] + for example def f ((*r, p)); end traverses all nodes - for example def String.foo; end + for example "#@1" traverses all nodes - for example let (:a) { m do; end } + for example foo / 1 traverses all nodes - for example 42 + for example -> do end traverses all nodes - for example a b{c d}, 1 do end + for example a b{c d}, /x/ do end traverses all nodes - for example { foo: 2 } + for example break foo traverses all nodes - for example p <<~E - x - - y -E + for example def f(*foo); end traverses all nodes - for example if (a, b = foo); end + for example case foo; in [x, *, y] then true; end traverses all nodes - for example case foo; in ->{ 42 } then true; end + for example foo::C ||= raise bar rescue nil traverses all nodes - for example :"a\ -b" + for example t=1;(foo)?t:T traverses all nodes - for example *b, c = bar + for example meth 1 do end::fun bar traverses all nodes - for example case foo; in "#{ %Q{a} }": then true; end + for example %q{#@1} traverses all nodes - for example fun! + for example case foo; in **a then true; end traverses all nodes - for example [*foo] + for example %i[] traverses all nodes - for example 'foobar' + for example a b(c(d)), "x" do end traverses all nodes - for example foo <= 1 + for example "#@@1" traverses all nodes - for example * = bar + for example case foo; in A[x:] then true; end traverses all nodes - for example foo - 1 + for example B::A += 1 traverses all nodes - for example a b{c(d)}, 1.0i do end + for example case foo; in { a: 1, } then true; end traverses all nodes - for example case foo; in ** then true; end + for example foo > 1 traverses all nodes - for example /#{1}(?bar)/ =~ 'bar' + for example %I[foo #{bar}] traverses all nodes - for example f{ |*| } + for example a # +# +&.foo traverses all nodes - for example case foo; - in {Foo: 42 - } - false - ; end + for example def BEGIN; end traverses all nodes - for example ?a + for example case foo; in [*x, y] then true; end traverses all nodes - for example p ->() do a() do end end + for example def foo(...); end traverses all nodes - for example A += 1 + for example foo[m bar] traverses all nodes - for example lambda{|;a|a} + for example def f a, *r, &b; end traverses all nodes - for example f{ |a, *s, &b| } + for example f{ |a, &b| } traverses all nodes - for example a b(c d), 1.0 do end + for example foo::fun traverses all nodes - for example @@foo + for example -42 traverses all nodes - for example <<-"HERE" -#@1 -HERE + for example 1.33 traverses all nodes for example def f(foo: 1); end traverses all nodes - for example Foo = 10 - traverses all nodes - for example p <<~"E" - x - #{foo} + for example p <<~E + x + +y E traverses all nodes - for example a b{c(d)}, 1.0 do end + for example a b(c(d)), 1.0i do end traverses all nodes - for example m = -> *args do end + for example foo[1, 2] traverses all nodes - for example foo += meth rescue bar + for example fun do end traverses all nodes - for example case foo; in 1..2 then true; end + for example if foo; bar; else baz; end traverses all nodes - for example foo ^ 1 + for example %w[] traverses all nodes - for example fun (1 -) + for example -foo traverses all nodes - for example def foo(_a, _a); end + for example def f(**foo); end traverses all nodes - for example defined? @foo + for example case foo; in self then true; end traverses all nodes - for example for a in foo do p a; end + for example f{ |*r, p, &b| } traverses all nodes - for example case foo; in x, then nil; end + for example super foo traverses all nodes - for example f <<-TABLE do -TABLE -end + for example case foo; in A[1, 2] then true; end traverses all nodes - for example def _5; end + for example %{#@1} traverses all nodes - for example %W() + for example <<`HERE` +foo +bar +HERE traverses all nodes - for example a = 1; a b: 1 + for example <<-`HERE` +a\ +b +HERE traverses all nodes - for example a = b += raise :x + for example <<-"HERE" +#@1 +HERE traverses all nodes - for example %q{#@1} + for example f(a ? "a":1) traverses all nodes - for example f{ |*s| } + for example foo >= 1 traverses all nodes - for example begin; meth; rescue => ex; bar; end + for example fun (1).to_i traverses all nodes - for example f{ |foo: 1, bar: 2, **baz, &b| } + for example ->{ } traverses all nodes - for example foo.A += 1 + for example %I{a\ +b} traverses all nodes - for example not foo + for example assert dogs traverses all nodes - for example foo::C ||= raise(bar) rescue nil + for example (foo, bar) = 1, 2 traverses all nodes - for example <<~FOO - baz\ - qux -FOO + for example !/wat/ traverses all nodes - for example foo & 1 + for example m { |**nil| } traverses all nodes - for example def f foo: -1 -; end + for example p <<~"E" + x + #{foo} +E traverses all nodes - for example -> (a) { } + for example case foo; + in {a: 1 + } + false + ; end traverses all nodes - for example f (g rescue nil) + for example while foo do meth end traverses all nodes - for example def String; end + for example -> do rescue; end traverses all nodes - for example a, *b = bar + for example def f a, o=1, p, &b; end traverses all nodes - for example case foo; in ..2 then true; end + for example a b(c d), 1.0 do end traverses all nodes - for example foo.A = 1 + for example *, c, d = bar traverses all nodes - for example fun(foo, *bar) + for example f{ |*| } traverses all nodes - for example %i[] + for example __ENCODING__ traverses all nodes - for example def f a, *r, &b; end + for example a &&= 1 traverses all nodes - for example proc {_1 = nil} + for example class Foo end traverses all nodes - for example m { |(foo, bar)| } + for example <<-'HERE' +#@1 +HERE traverses all nodes - for example a b(c(d)), :e do end + for example foo::m += raise(bar) rescue nil traverses all nodes - for example [1, *foo] + for example f{ |a, c| } traverses all nodes - for example def f(foo:); end + for example !(foo..bar) traverses all nodes - for example foo::fun + for example def f a, o=1, *r, p, &b; end traverses all nodes - for example %{#@1} + for example %W[foo #{bar}] traverses all nodes - for example foo = baz, *bar + for example f{ |a, o=1, &b| } traverses all nodes - for example [1, 2] + for example m "#{}#{()}" traverses all nodes - for example %w[ #@1 ] + for example %{#@@1} traverses all nodes - for example :'foo' + for example [*foo] traverses all nodes - for example END { 1 } + for example foo += raise(bar) rescue nil traverses all nodes - for example def f ((a, *)); end + for example a b{c d}, 1.0i do end traverses all nodes - for example fun(foo, :foo => 1, &baz) + for example def f ((a, *, p)); end traverses all nodes - for example f{ |a, *r, p, &b| } + for example td (1_500).toString(); td.num do; end traverses all nodes - for example f{ |*, &b| } + for example meth 1 do end::fun(bar) traverses all nodes - for example a, *b, c = bar + for example case foo; in { a: 1 } then true; end traverses all nodes - for example %x{#@1} + for example foo[1, 2] traverses all nodes - for example ::A += 1 + for example lambda{|;a|a} traverses all nodes - for example case 1; in 2; 3; else; end + for example f (g rescue nil) traverses all nodes - for example meth 1 do end::fun bar + for example { foo: 2, **bar } traverses all nodes - for example def f ((*r, p)); end + for example `foo#{bar}baz` traverses all nodes - for example def f foo: -; end + for example foo::Fun() traverses all nodes - for example "#@a #@@a #$a" + for example begin; meth; rescue; foo; end traverses all nodes - for example meth do; foo; rescue; bar; end + for example foo[1, 2] = 3 traverses all nodes - for example super do end + for example a b(c d), :e do end traverses all nodes - for example if foo then bar; end + for example f{ || } traverses all nodes - for example begin; meth; rescue Exception, foo; bar; end + for example <<'HERE' +foo +bar +HERE traverses all nodes - for example -> do end + for example self::a, foo = foo traverses all nodes - for example "a\ -b" + for example %W[#@@1] traverses all nodes - for example 'a\ -b' + for example !foo traverses all nodes - for example m do _1 + _9 end + for example case foo; in A(1, 2) then true; end traverses all nodes - for example case foo; - in {a: 1 - } - false - ; end + for example a, *b = bar traverses all nodes - for example fun(:foo => 1) + for example ?a 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 p <<~E + x + y +E traverses all nodes - for example class A < B -end + for example case foo; in 1; end traverses all nodes - for example foo, bar = meth rescue [1, 2] + for example if foo +then bar end traverses all nodes - for example case foo; in "#{ %q{a} }": 1 then true; end + for example foo::A += m foo traverses all nodes - for example case foo; in a: 1, b: 2 then true; end + for example { 1 => 2 } traverses all nodes - for example def BEGIN; end + for example self::A, foo = foo traverses all nodes - for example def m; class << self; module M; end; end; end + for example m { _1 + _9 } traverses all nodes - for example def m; class << self; A = nil; end; end + for example f{ |a| } traverses all nodes - for example fun(*bar) + for example ~foo traverses all nodes - for example f{ |a| } + for example :'a\ +b' traverses all nodes - for example @@var = 10 + for example def String=; end traverses all nodes - for example case foo; in "a": then true; end + for example unless foo then bar; end traverses all nodes - for example case foo; when 'bar', 'baz'; bar; end + for example foo.a += m foo traverses all nodes - for example { 'foo': 2, 'bar': {}} + for example foo = baz, *bar traverses all nodes - for example meth 1 do end::fun(bar) + for example case foo; in "#{ %Q{a} }": then true; end traverses all nodes - for example !/wat/ + for example %Q{a\ +b} traverses all nodes - for example foo.C += raise bar rescue nil + for example "#{1}" traverses all nodes - for example @foo, @@bar = *foo + for example _1 traverses all nodes - for example if /wat/; end + for example p <<~E + x + y +E traverses all nodes - for example +2.0 ** 10 + for example foo = meth rescue bar traverses all nodes - for example -2 ** 10 + for example %i{a\ +b} traverses all nodes - for example f{ |a, b,| } + for example case foo; in a: 1, _a:, ** then true; end traverses all nodes - for example meth 1 do end.fun bar do end + for example def f *r, &b; end traverses all nodes - for example case foo; in 1...2 then true; end + for example case foo; in "#{ %q{a} }": 1 then true; end traverses all nodes - for example class Foo; end + for example def self::foo; end traverses all nodes - for example def f o=1, &b; end + for example case foo; in A::B then true; end traverses all nodes - for example def f a, o=1, *r, p, &b; end + for example f{ |o=1, p, &b| } traverses all nodes - for example m { |foo| } + for example foo = raise bar rescue nil traverses all nodes - for example fun(&bar) + for example %W[foo #{bar}foo#@baz] traverses all nodes - for example def self._6; end + for example case foo; in a: 1 then true; end traverses all nodes - for example fun(f bar) + for example def f o=1, *r, &b; end traverses all nodes - for example foo[1, 2] = 3 + for example foo[bar, :baz => 1,] traverses all nodes - for example a b{c(d)}, 1.0r do end + for example a b{c d}, 1.0r do end traverses all nodes - for example -1.33 + for example next traverses all nodes - for example ->{ } + for example a, b = *foo, bar traverses all nodes - for example foo.A += m foo + for example def f (((a))); end traverses all nodes - for example def self.m; _1; end + for example def a; @@var |= 10; end traverses all nodes - for example foo / 1 + for example case 1; in 2; 3; else; end traverses all nodes - for example !(a, b = foo) + for example fun () {} traverses all nodes - for example f(a ? "a":1) + for example foo::m += raise bar rescue nil traverses all nodes - for example [ 1, 2 => 3 ] + for example def f ((a, *r)); end traverses all nodes - for example def f(**foo); end + for example alias :foo bar traverses all nodes - for example false ? raise {} : tap {} + for example def f(**nil); end traverses all nodes - for example a b{c d}, /x/ do end + for example a ? b & '': nil traverses all nodes - for example case 1; in 2; 3; else; 4; end + for example while def foo; tap do end; end; break; end traverses all nodes - for example yield foo + for example :"#@@1" traverses all nodes - for example foo ? 1 : 2 + for example m "#{[]}" traverses all nodes - for example ->(a) { } + for example bar unless foo traverses all nodes - for example f{ |o=1, p, &b| } + for example meth while foo traverses all nodes - for example case foo; in self then true; end + for example a&.b traverses all nodes - for example def a; @@var |= 10; end + for example fun(*bar) traverses all nodes - for example foo.fun + for example case foo; in 1..2 then true; end traverses all nodes - for example def foo - a:b end + for example class Foo < a:b; end traverses all nodes - for example module Bar::Foo; end + for example foo ** 1 traverses all nodes - for example case foo; in "#{ 'a' }": 1 then true; end + for example yield traverses all nodes - for example case foo; in *x, y, z then nil; end + for example proc {_1 = nil} traverses all nodes - for example super() + for example fun (1 +) traverses all nodes - for example while class Foo a = tap do end; end; break; end + for example return traverses all nodes - for example + for example case foo; in x, then nil; end traverses all nodes - for example defined?(foo) + for example -> * { } traverses all nodes - for example def END; end + for example %w[ #@@1 ] traverses all nodes - for example 42i + for example case foo; in ::A then true; end traverses all nodes - for example def String::foo; end + for example !(foo...bar) traverses all nodes - for example a @b do |c|;end + for example @var = 10 traverses all nodes - for example _1 + for example foo.a += 1 traverses all nodes - for example a b(c d), :e do end + for example if /wat/; end traverses all nodes - for example if foo..bar; end + for example a b(c d), 1.0r do end traverses all nodes - for example p :foo, {a: proc do end, b: proc do end} + for example case foo; in "#{ 'a' }": then true; end traverses all nodes - for example -> (arg={}) {} + for example def f a, *r, p, &b; end traverses all nodes - for example def foo(...); bar(...); end + for example case foo; in a:, b: then true; end traverses all nodes - when a class defines `on_block_pass` - calls it for all block-pass arguments - for example case foo; in x if true; nil; end + for example a b(c d), 1.0i do end traverses all nodes - for example case foo; in { a: 1 } then true; end + for example { 'foo': 2 } traverses all nodes - for example case foo; in { a: 1, } then true; end + for example not() traverses all nodes - for example f{ |a, o=1, *r, p, &b| } + for example a b(c d), /x/m do end traverses all nodes - for example case foo; in ^foo then nil; end + for example foo = bar = m foo traverses all nodes - for example m { _1 + _9 } + for example %W() traverses all nodes - for example foo[bar,] + for example a, (b, c) = foo traverses all nodes - for example a b(c d), 1.0i do end + for example f{ |;a| } traverses all nodes - for example while def foo a = tap do end; end; break; end + for example END { 1 } traverses all nodes - for example foo <=> 1 + for example proc {|_3|} traverses all nodes - for example case foo; in a: 1 then true; end + for example p p{p(p);p p}, tap do end traverses all nodes - for example def f ((*r)); end + for example begin; meth; rescue Exception, foo; bar; end traverses all nodes - for example self.A, foo = foo + for example $10 traverses all nodes - for example assert dogs + for example fun(:foo => 1) traverses all nodes - for example return fun foo do end + for example a ||= 1 traverses all nodes - for example begin; meth; rescue => @ex; bar; end + for example def f foo: -1 +; end traverses all nodes - for example foo "#{(1+1).to_i}" do; end + for example next foo traverses all nodes - for example !(foo..bar) + for example case foo; in {} then true; end traverses all nodes - for example %w[foo bar] + for example case foo; in (1) then true; end traverses all nodes - for example foo.fun (1) {} + for example __FILE__ traverses all nodes - for example m "#{}#{()}" + for example if (bar; a, b = foo); end traverses all nodes - for example -42 + for example case foo; in ..2 then true; end traverses all nodes - for example @foo + for example a = b += raise :x traverses all nodes - for example foo&.bar {} + for example +42 traverses all nodes - for example foo[0, 1] ||= 2 + for example while class << self; a = tap do end; end; break; end traverses all nodes - for example ::A, foo = foo + for example foo === 1 traverses all nodes - for example def f *r, &b; end + for example p :foo, {:a => proc do end, b: proc do end} traverses all nodes - for example f{ |a, c| } + for example yield(foo) traverses all nodes - for example case foo; in 1; end + for example f{ |foo:| } traverses all nodes - for example a, *, c = bar + for example "#{-> foo {}}" traverses all nodes - for example break(foo) + for example def x; self::A ||= 1; end traverses all nodes - for example p -> { :hello }, a: 1 do end + for example foo[0, 1] += 2 traverses all nodes - for example module A; _1; end + for example a b(c(d)), 1.0r do end traverses all nodes - for example p <<~"E" - x - #{" y"} -E + for example foo - 1 traverses all nodes - for example __ENCODING__ + for example m { |foo| } traverses all nodes - for example %i[ #@@1 ] + for example foo, bar = 1, 2 traverses all nodes - for example /#@1/ + for example if (a, b = foo); end traverses all nodes - for example foo % 1 + for example %I[foo#{bar}] traverses all nodes - for example <<-"HERE" -a\ -b -HERE + for example { 1 => 2, :foo => "bar" } traverses all nodes - for example p <<~E - x - y -E + for example class Foo; end traverses all nodes - for example foo and bar + for example let (:a) { m do; end } traverses all nodes - for example a b(c d), 1.0r do end + for example m [] do end traverses all nodes - for example %{a\ -b} + for example @foo traverses all nodes - for example def f *, **; end + for example @@var = 10 traverses all nodes - for example !(foo...bar) + for example m { |(foo, bar)| } traverses all nodes - for example foo += raise(bar) rescue nil + for example :'#@@1' traverses all nodes for example %Q{#@1} traverses all nodes - for example unless foo; bar; end - traverses all nodes - for example foo = m foo + for example :"foo#{bar}baz" traverses all nodes - for example -foo + for example begin; meth; rescue; foo; else; bar; end traverses all nodes - for example break + for example not foo traverses all nodes - for example %i[foo bar] + for example fun(foo, :foo => 1, &baz) traverses all nodes - for example case; when foo; 'foo'; end + for example defined? foo traverses all nodes - for example {a: if true then 42 end} + for example 1.. traverses all nodes - for example a b{c d}, 1.0 do end + for example case foo; in "a": then true; end traverses all nodes - for example f{ |o=1, &b| } + for example def f ((*r)); end traverses all nodes - for example case [__FILE__, __LINE__ + 1, __ENCODING__] - in [__FILE__, __LINE__, __ENCODING__] - end + for example a b{c(d)}, /x/m do end traverses all nodes - for example super(foo) + for example *b, c = bar traverses all nodes - for example { 1 => 2 } + for example foo.m += raise bar rescue nil traverses all nodes - for example %I[#@1] + for example foo * 1 traverses all nodes - for example '#@@1' + for example false ? raise do end : tap do end traverses all nodes - for example fun(*bar, &baz) + for example :"#@1" traverses all nodes - for example begin; meth; ensure; bar; end + for example foo = m foo traverses all nodes - for example bar def foo; self.each do end end + for example until foo do meth end traverses all nodes - for example @@var |= 10 + for example case foo; in [x] then nil; end traverses all nodes - for example case foo; in A(1, 2) then true; end + for example "a\ +b" traverses all nodes - for example foo or bar + for example def f(foo, bar); end traverses all nodes - for example a b(c d), /x/ do end + for example meth do; foo; rescue; bar; end traverses all nodes - for example (foo, bar) = 1, 2 + for example -2 ** 10 traverses all nodes - for example def f(foo=1, bar=2); end + for example self traverses all nodes - for example :'#@1' + for example <<-"HERE" +#@@1 +HERE traverses all nodes - for example foo.fun bar + for example def foo(...); bar(...); end traverses all nodes - for example m [], 1 do end + for example ->(a; foo, bar) { } traverses all nodes - for example a&.b + for example super foo, bar do end traverses all nodes - for example :'#@@1' + for example if foo then bar; else baz; end traverses all nodes - for example '#@1' + for example foo != 1 traverses all nodes - for example ->{ } + for example case foo; in 1, "a", [], {} then nil; end traverses all nodes - for example fun (1) {} + for example case foo; in A[] then true; end traverses all nodes - for example def f (foo: 1, &b); end + for example f{ |a,| } traverses all nodes - for example foo.a = 1 + for example __LINE__ traverses all nodes - for example meth while foo + for example def String.foo; end traverses all nodes - for example case foo; in 1 => a then true; end + for example meth 1 do end.fun(bar) traverses all nodes - for example %I[#@@1] + for example foo::Fun bar traverses all nodes - for example m a + b do end + for example def m; class << self; class C; end; end; end traverses all nodes - for example f{ |a, &b| } + for example begin meth end until foo traverses all nodes for example f{ |a, o=1, p, &b| } traverses all nodes - for example true + for example def foo(_, _); end traverses all nodes - for example !m foo + for example foo or bar traverses all nodes - for example fun (1).to_i + for example case foo; when 'bar', 'baz'; bar; end traverses all nodes - for example a += b = raise :x + for example def f(foo:); end traverses all nodes - for example m [] do end + for example foo + 1 traverses all nodes - for example foo !~ 1 + for example -> a: { } traverses all nodes - for example %I() + for example case foo; in "a": 1 then true; end + traverses all nodes + for example case foo; in *x then nil; end traverses all nodes for example yield() traverses all nodes - for example def x; ::A ||= 1; end + for example a = 1; a b: 1 traverses all nodes - for example fun(foo, *bar, &baz) + for example A += 1 traverses all nodes - for example begin; meth; rescue; foo; else; bar; end + for example case foo; + in {a: + 2} + false + ; end traverses all nodes - for example fun(1) + for example foo <= 1 traverses all nodes - for example f{ |a, o=1, o1=2, *r, &b| } + for example m = -> *args do end traverses all nodes - for example super foo + for example { foo: 2 } traverses all nodes - for example fun() { } + for example def _5; end traverses all nodes - for example f{ |*s, &b| } + for example a&.b &&= 1 traverses all nodes - for example f{ |a, *| } + for example '#@@1' traverses all nodes - for example foo.a ||= 1 + for example 1...2 traverses all nodes - for example let () { m(a) do; end } + for example alias $a $+ traverses all nodes - for example -> { _1 + _9} + for example <<-'HERE' +#@@1 +HERE traverses all nodes - for example foo = raise bar rescue nil + for example -> (arg={}) {} traverses all nodes - for example __FILE__ + for example nil traverses all nodes - for example def f(*foo); end + for example if (bar); foo; end traverses all nodes - for example [ 1 => 2 ] + for example def f ((a, a1)); end traverses all nodes - for example "#@1" + for example def f(*); end traverses all nodes - for example next fun foo do end + for example fun(&bar) traverses all nodes - for example -> do _1 + _9 end + for example unless foo then bar; else baz; end traverses all nodes - for example defined? foo + for example foo.A = 1 traverses all nodes - for example <(scope) {}; scope traverses all nodes - for example p <<~E - x - \ y -E + for example case foo; in ->{ 42 } then true; end traverses all nodes - for example begin; meth; rescue; foo; end + for example begin meth end while foo traverses all nodes - for example p <<~E + for example p <<~E " y" x - y E traverses all nodes - for example foo[0] += raise bar rescue nil - traverses all nodes - for example def f **baz, &b; end - traverses all nodes - for example case foo; in x then x; end - traverses all nodes - for example B::A += 1 + for example [1, *foo] traverses all nodes - for example case foo; when 'bar'; bar; else baz; end + for example -> { _1 + _9} traverses all nodes - for example a b(c(d)), "x" do end + for example fun (1) traverses all nodes - for example next() + for example module Foo; end traverses all nodes - for example ::Foo + for example ((b, )) = foo traverses all nodes - for example case foo; in x, y, then nil; end + for example def f o=1, p, &b; end traverses all nodes - for example `foo#{bar}baz` + for example %w[ #@1 ] traverses all nodes - for example %s{#@@1} + for example case foo; in x if true; nil; end traverses all nodes - for example foo = bar = m foo + for example foo >> 1 traverses all nodes - for example "#{-> foo {}}" + for example f{ |a, b,| } traverses all nodes for example m def x(); end; 1.tap do end traverses all nodes - for example /#)/x + for example module Bar::Foo; end traverses all nodes - for example next(foo) + for example true traverses all nodes - for example case foo; in 1... then true; end + for example %s{#@@1} traverses all nodes - for example case foo; - in a: {b:}, c: - p c - ; end + for example %I[#@1] traverses all nodes - for example t=1;(foo)?t:T + for example p <<~E + x + y +E traverses all nodes - for example a, * = bar + for example [/()\1/, ?#] traverses all nodes - for example retry + for example /(?bar)/ =~ 'bar'; match traverses all nodes - for example unless foo then bar; else baz; end + for example %r{#@1} traverses all nodes - for example def f a, o=1, p, &b; end + for example foo == 1 traverses all nodes - for example case; when foo; 'foo'; else 'bar'; end + for example '#@1' traverses all nodes - for example while foo do meth end + for example f{ } traverses all nodes - for example a += 1 + for example <<~E + 1 \ + 2 + 3 +E traverses all nodes - for example self + for example case 1; in 2; 3; else; 4; end traverses all nodes - for example def f(&block); end + for example def f(**); end traverses all nodes - for example %r{a\ -b} + for example -1.33 traverses all nodes - for example if foo...bar; end + for example @a |= 1 traverses all nodes - for example foo.a &&= 1 + for example __ENCODING__ traverses all nodes - for example super foo, bar do end + for example case foo; in 1...2 then true; end traverses all nodes - for example foo += raise bar rescue nil + for example foo ^ 1 traverses all nodes - for example while foo; meth end + for example super traverses all nodes - for example case foo; in A(x:) then true; end + for example def until; end traverses all nodes - for example f{ |a| } + for example meth[] {} traverses all nodes - for example meth until foo + for example p :foo, {a: proc do end, b: proc do end} traverses all nodes - for example case foo; in "#{ %q{a} }": then true; end + for example class << foo; _1; end traverses all nodes - for example @a |= 1 + for example meth 1 do end.fun {} traverses all nodes - for example until foo; meth end + for example begin; meth; rescue Exception; bar; end traverses all nodes for example 42r traverses all nodes - for example /#@@1/ - traverses all nodes - for example case foo; in [x, *, y] then true; end - traverses all nodes - for example `a\ -b` - traverses all nodes - for example if (bar); foo; end - traverses all nodes - for example def f ((a, *r)); end - traverses all nodes - for example not(foo) - traverses all nodes - for example def m; class << self; class C; end; end; end + for example %s{#@1} traverses all nodes - for example def foo; end + for example m do _1 + _9 end traverses all nodes - for example __ENCODING__ + for example case foo; in *x, y, z then nil; end traverses all nodes - for example foo::a += m foo + for example defined? @foo traverses all nodes - for example def until; end + for example p <<~"E" + x\n y +E traverses all nodes - for example undef foo, :bar, :"foo#{1}" + for example foo::a += 1 traverses all nodes - for example Foo + for example 42 traverses all nodes - for example fun(foo, :foo => 1) + for example foo.(1) traverses all nodes - for example +42 + for example case foo; in x, y, then nil; end traverses all nodes - for example fun () {} + for example traverses all nodes - for example p :foo, {:a => proc do end, b: proc do end} + for example fun (1) {} traverses all nodes - for example while not (true) do end + for example f{ |a, *, &b| } 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 a += b += raise :x traverses all nodes - for example 1... + for example p <<~"E" + x + #{" y"} +E traverses all nodes for example p <<~E x - y + + y E traverses all nodes - for example def String=; end - traverses all nodes - for example ..100 + for example 1... traverses all nodes - for example def f(foo, bar); end + for example a b(c d), /x/ do end traverses all nodes - for example f{ |foo:| } + for example for a in foo; p a; end traverses all nodes - for example foo << 1 + for example next() traverses all nodes - for example for a in foo; p a; end + for example <<-E + 1 \ + 2 + 3 +E traverses all nodes - for example *, c, d = bar + for example case foo; in 1... then true; end traverses all nodes - for example *b = bar + for example begin; meth; rescue => ex; bar; end traverses all nodes - for example a&.b = 1 + for example def foo; end traverses all nodes - for example foo::fun bar + for example case foo; in x unless true; nil; end traverses all nodes - for example p p{p(p);p p}, tap do end + for example f{ |o=1, *r, p, &b| } traverses all nodes - for example proc {|_3|} + for example { 'foo': 2, 'bar': {}} traverses all nodes - for example begin meth end until foo + for example meth (-1.3).abs traverses all nodes - for example a b{c(d)}, "x" do end + for example def f ((a, *r, p)); end traverses all nodes - for example case foo; in * then nil; end + for example p :foo, {proc do end => proc do end, b: proc do end} traverses all nodes - for example module ::Foo; end + for example a b(c d), "x" do end traverses all nodes - for example case foo; in x unless true; nil; end + for example p <<~E + x + y +E traverses all nodes - for example foo + for example foo | 1 traverses all nodes for example f{ | | } traverses all nodes - for example td (1_500).toString(); td.num do; end + for example foo || bar traverses all nodes - for example :'a\ -b' + for example until foo; meth end traverses all nodes - for example %I{a\ -b} + for example fun(f bar) traverses all nodes - for example var = 10; var + for example case foo; in 1.. then true; end traverses all nodes - for example `foobar` + for example a # + # +.foo traverses all nodes - for example case foo; in ...2 then true; end + for example foo = *bar traverses all nodes - for example a b{c d}, "x" do end + for example %w{a\ +b} traverses all nodes - for example a &&= 1 + for example $var = 10 traverses all nodes - for example case foo; in A() then true; end + for example break() traverses all nodes - for example BEGIN { 1 } + for example 'foobar' traverses all nodes - for example foo[1, 2] + for example def f (foo: 1, &b); end traverses all nodes - for example yield + for example Bar::Foo traverses all nodes - for example fun { } + for example foo "#{(1+1).to_i}" do; end traverses all nodes - for example %x{a\ -b} + for example def f(foo); end traverses all nodes - for example case foo; in A::B then true; end + for example def f ((*, p)); end traverses all nodes - for example def f o=1, *r, &b; end + for example begin; meth; rescue => @ex; bar; end traverses all nodes - for example { 1 => 2, :foo => "bar" } + for example foo += raise bar rescue nil traverses all nodes - for example foo = raise(bar) rescue nil + for example p <<~`E` + x + #{foo} +E traverses all nodes - for example case foo; in [x, *y, z] then true; end + for example case foo; when 'bar'; bar; end traverses all nodes - for example p <<~E - x -E + for example def f(foo=1, bar=2); end traverses all nodes - for example meth 1 do end.fun(bar) {} + for example [ 1 => 2 ] traverses all nodes - for example def f ((*)); end + for example /a\ +b/ traverses all nodes - for example foo >> 1 + for example for a in foo do p a; end traverses all nodes - for example %W{a\ -b} + for example f{ |a, *s, &b| } traverses all nodes - for example def f ((a, a1)); end + for example a b(c(d)), :e do end traverses all nodes - for example <<'HERE' -foo -bar + for example case foo; in [x, y] then true; end + traverses all nodes + for example %q(foobar) + traverses all nodes + for example <<-`HERE` +#@@1 HERE traverses all nodes - for example -> a: 1 { } + for example a b(c d), 1 do end traverses all nodes - for example meth 1 do end.fun {} + for example %x{#@1} traverses all nodes - for example f x: -> do meth do end end + for example yield foo traverses all nodes - for example foo[0, 1] += 2 + for example for a, b in foo; p a, b; end traverses all nodes - for example m1 :k => m2 do; m3() do end; end + for example <<-`HERE` +#@1 +HERE traverses all nodes for example p <<~E - x - -y E traverses all nodes - for example break() + for example _2 = 1 traverses all nodes - for example a b(c(d)), 1 do end + for example foo::C ||= raise(bar) rescue nil traverses all nodes - for example while def foo; tap do end; end; break; end + for example foo::A = 1 traverses all nodes - for example case foo; in A[1, 2] then true; end + for example 1 in [a]; a traverses all nodes - for example not() + for example :"a\ +b" traverses all nodes - for example %w{a\ -b} + for example ::A += 1 traverses all nodes - for example %W[foo #{bar}foo#@baz] + for example def self._6; end traverses all nodes - for example foo = *bar + for example foo.fun bar traverses all nodes - for example break fun foo do 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 def (foo).foo; end + for example case foo; + in {a: + } + true + ; end traverses all nodes - for example foo::fun (1) {} + for example a b(c(d)), 1.0 do end traverses all nodes - for example %W[#@@1] + for example f{ |&b| } traverses all nodes - for example case foo; in [x,] then nil; end + for example meth 1 do end.fun bar traverses all nodes - for example def foo -=begin -=end -end + for example foo.C += raise bar rescue nil traverses all nodes - for example %W"#{1}" + for example meth rescue bar traverses all nodes - for example %Q{#@@1} + for example case foo; when 'bar'; bar; else baz; end traverses all nodes - for example meth[] {} + for example m ->(a: ->{_1}) {a} traverses all nodes - for example %I[foo #{bar}] + for example while class Foo a = tap do end; end; break; end traverses all nodes - for example class << foo; nil; end + for example begin end traverses all nodes - for example %i[ #@1 ] + for example def (foo).foo; end traverses all nodes - for example begin meth end while foo + for example case foo; in x then x; end + traverses all nodes + for example %Q{#@@1} traverses all nodes for example %q{#@@1} traverses all nodes - for example %{#@@1} + for example undef foo, :bar, :"foo#{1}" traverses all nodes - for example a, b = *foo, bar + for example %w[foo bar] traverses all nodes - for example a b{c(d)}, :e do end + for example f <<-TABLE do +TABLE +end traverses all nodes - for example f{ |o=1, *r, p, &b| } + for example m ->(a = ->{_1}) {a} traverses all nodes - for example foo += m foo + for example case foo; in x, y then nil; end traverses all nodes - for example break foo + for example foo::a += m foo traverses all nodes - for example fun (1) + for example foo || (a, b = bar) traverses all nodes - for example 42.1i + for example foo::a = 1 traverses all nodes - for example p <<~E -E + for example case foo; in ...2 then true; end traverses all nodes - for example assert do: true + for example %i[ #@1 ] traverses all nodes - for example p <<~E - x - y -E + for example def foo raise; raise A::B, ''; end traverses all nodes - for example p <<~`E` - x - #{foo} -E + for example def f **baz, &b; end traverses all nodes - for example case foo; in *x then nil; end + for example foo & 1 traverses all nodes - for example f{ |; -a -| } + for example f{ |a| } traverses all nodes - for example case foo; in **a then true; end + for example ::Foo traverses all nodes - for example foo::Fun() + for example /#@1/ traverses all nodes - for example return foo + for example f{ |a, *r, p, &b| } traverses all nodes - for example foo ** 1 + for example begin ensure end traverses all nodes - for example meth 1 do end.fun(bar) + for example meth 1 do end.fun(bar) {} traverses all nodes - for example case foo; in {} then true; end + for example foo.m += raise(bar) rescue nil traverses all nodes - for example begin; meth; rescue Exception; bar; end + for example a b{c(d)}, 1.0 do end traverses all nodes - for example 42.1r + for example foo::fun (1) {} traverses all nodes - for example a b{c d}, /x/m do end + for example foo <=> 1 traverses all nodes - for example return(foo) + for example case foo; in * then nil; end traverses all nodes - for example a ||= 1 + for example next(foo) traverses all nodes - for example foo && (a, b = bar) + for example case foo; in [x,] then nil; end traverses all nodes - for example [/()\1/, ?#] + for example %W[#@1] traverses all nodes - for example /(?bar)/ =~ 'bar'; match + for example foo[0, 1] &&= 2 traverses all nodes - for example %s{a\ -b} + for example o = { +a: +1 +} traverses all nodes - for example super + for example a&.b = 1 traverses all nodes - for example foo::Fun bar + for example [1, *foo, 2] traverses all nodes - for example begin end + for example def f ((a, *)); end traverses all nodes - for example f{ |a, o=1, &b| } + for example 42i traverses all nodes - for example foo::m += raise bar rescue nil + for example def f *r, p, &b; end traverses all nodes - for example begin; rescue LoadError; else; end + for example m1 :k => m2 do; m3() do end; end traverses all nodes - for example p <<~E " y" - x -E + for example /#@@1/ traverses all nodes - for example 1.. + for example a, * = bar traverses all nodes - for example begin; meth; rescue; baz; else foo; ensure; bar end + for example "foo#{bar}baz" traverses all nodes - for example @var = 10 + for example -> do _1 + _9 end traverses all nodes - for example $var = 10 + for example $foo traverses all nodes - for example meth (-1.3).abs + for example if foo..bar; end traverses all nodes - for example foo[1, 2] = 3 + for example case foo; in A() then true; end traverses all nodes - for example desc "foo" do end + for example fun(foo, *bar, &baz) traverses all nodes - for example <<-'HERE' -#@@1 -HERE + for example !m foo traverses all nodes - for example case foo; in x, y then nil; end + for example while def self.foo a = tap do end; end; break; end traverses all nodes - for example <<-`HERE` -#@@1 -HERE + for example "foo#@a" "bar" traverses all nodes - for example a b{c d}, 1.0r do end + for example def f o=1, *r, p, &b; end traverses all nodes - for example class Foo < a:b; end + for example p -> { :hello }, a: 1 do end traverses all nodes - for example :foo + for example foo&.bar {} traverses all nodes - for example ->(scope) {}; scope + when given an unexpected AST + with too few children + raises debugging error + with too many children + raises debugging error + for example case; when foo; 'foo'; else 'bar'; end traverses all nodes - for example next + for example fun() { } traverses all nodes - for example def f ((a, *, p)); end + for example bar if foo traverses all nodes - for example next foo + for example 42.1ri traverses all nodes - for example { 'foo': 2 } + for example foo.A += 1 traverses all nodes - for example <<-`HERE` -a\ -b -HERE + for example -> a: 1 { } traverses all nodes - for example p <<~"E" - x\n y + for example p <<~E + x + y E traverses all nodes - for example def foo raise; raise A::B, ''; end - traverses all nodes - for example p :foo, {"a": proc do end, b: proc do end} + for example while def self.foo; tap do end; end; break; end traverses all nodes - for example foo[0, 1] += m foo + for example case; when foo; 'foo'; end traverses all nodes - for example foo (-1.3).abs + for example a b{c d}, /x/m do end traverses all nodes - for example a b(c d), 1 do end + for example desc "foo" do end traverses all nodes - for example %W[foo #{bar}] + for example 42.1r traverses all nodes - for example %I[foo#{bar}] + for example %r{#@@1} traverses all nodes - for example case foo; in **nil then true; end + for example foo[0, 1] ||= 2 traverses all nodes - for example { foo: 2, **bar } + for example def f a, &b; end traverses all nodes - for example a b(c d), /x/m do end + for example fun(foo, *bar) traverses all nodes - for example case foo; in "#{ %Q{a} }": 1 then true; end + for example f{ |a, *s| } traverses all nodes - for example case foo; when 'bar' then bar; end + for example Foo traverses all nodes - for example def f(foo); end + for example :foo traverses all nodes - for example __LINE__ + for example foo::fun bar traverses all nodes - for example case foo; in (1) then true; end + for example %W{a\ +b} traverses all nodes for example def x(_4) end traverses all nodes - for example %w[ #@@1 ] + for example +foo traverses all nodes - for example class Foo < Bar; end + for example return fun foo do end traverses all nodes - for example case foo; in A[] then true; end + for example foo += m foo traverses all nodes - for example case foo; in a:, b: then true; end + for example def f a, o=1, &b; end + traverses all nodes + for example if foo then bar; end + traverses all nodes + for example f{ |a, o=1, o1=2, *r, &b| } + traverses all nodes + for example f{ |; +a +| } + traverses all nodes + for example foo && bar traverses all nodes for example /\xa8/n =~ "" traverses all nodes - for example f{ |a, *, &b| } + for example !(a, b = foo) traverses all nodes - for example %Q{a\ -b} + for example foo[0, 1] += m foo traverses all nodes - for example a&.b &&= 1 + for example { } traverses all nodes - for example /a\ -b/ + for example <<-'HERE' +a\ +b +HERE traverses all nodes - for example def f a, &b; end + for example def a b: +return +end traverses all nodes - for example def foo(...); end + for example f x: -> do meth do end end traverses all nodes - for example foo[m bar] + for example p <<~E + x + \ y +E traverses all nodes - for example class << foo; _1; end + for example fun(:foo => 1, &baz) traverses all nodes - for example foo[0] += raise(bar) rescue nil + for example foo = bar, 1 traverses all nodes - for example :"foo#{bar}baz" + for example false traverses all nodes - for example case foo; in x, *y, z then nil; end + for example a b{c(d)}, :e do end traverses all nodes - for example return + for example def self.m; _1; end traverses all nodes - for example `#@@1` + for example while class Foo; tap do end; end; break; end traverses all nodes - for example a, (b, c) = foo + for example while not (true) do end traverses all nodes - for example %q{a\ -b} + for example ->(**nil) {} traverses all nodes - for example :"#@@1" + for example module ::Foo; end traverses all nodes - for example begin; meth; rescue foo => ex; bar; end + for example f{ |a| } traverses all nodes - for example a b(c(d)), 1.0 do end + for example self.A, foo = foo traverses all nodes - for example def f (foo: 1, bar: 2, **baz, &b); end + for example 42.1i traverses all nodes - for example f{ |;a| } + for example [ 1, 2 => 3 ] traverses all nodes - for example p <<~E - E + for example case foo; + in a: {b:}, c: + p c + ; end traverses all nodes - for example foo.a += 1 + for example a b{c(d)}, 1.0i do end traverses all nodes - for example p <<~E - x - \ y -E + for example case foo; in A(x:) then true; end traverses all nodes - for example a b(c(d)), /x/ do end + for example foo = raise(bar) rescue nil traverses all nodes - for example ~foo + for example defined?(foo) traverses all nodes - for example a # - # -&.foo + for example -> (a) { } traverses all nodes - for example case foo; in [x] then nil; end + for example :'#@1' traverses all nodes - for example 1...2 + for example case foo; in [x, y,] then true; end traverses all nodes - for example def f ((*, p)); end + for example ::Foo = 10 traverses all nodes - for example { } + for example f{ |*, &b| } traverses all nodes - for example if foo then bar; else baz; end + for example foo.C += raise(bar) rescue nil traverses all nodes - for example def f a, o=1, &b; end + for example a, *b, c = bar traverses all nodes - for example false + for example meth until foo traverses all nodes - for example "foo#@a" "bar" + for example /#)/x + traverses all nodes + for example Bar::Foo = 10 + traverses all nodes + for example 42ri traverses all nodes for example def f a, o=1, *r, &b; end traverses all nodes - for example case foo; in 1.. then true; end + for example class A < B +end traverses all nodes - for example ->(**nil) {} + for example a b{c(d)}, "x" do end traverses all nodes - for example /source/im + for example def foo() a:b end traverses all nodes - for example while class << self; a = tap do end; end; break; end + for example case [__FILE__, __LINE__ + 1, __ENCODING__] + in [__FILE__, __LINE__, __ENCODING__] + end traverses all nodes - for example foo + 1 + for example fun { } traverses all nodes - for example case foo; when 1, *baz; bar; when *foo; end + for example proc {_1 = nil} traverses all nodes - for example () + for example return() traverses all nodes - for example p :foo, {proc do end => proc do end, b: proc do end} + for example /foo#{bar}baz/ traverses all nodes - for example m ->(a = ->{_1}) {a} + for example fun(foo, :foo => 1) traverses all nodes - for example case foo; in a: then true; end + for example foo < 1 traverses all nodes - for example <<-'HERE' -a\ -b -HERE + for example `#@@1` traverses all nodes for example a # - # +# .foo traverses all nodes - for example m ->(a: ->{_1}) {a} + for example case foo; in [x, y, *z] then true; end traverses all nodes - for example class A; _1; end + when a class defines on_arg + calls it for all arguments + for example def f ; end traverses all nodes - for example a ? b & '': nil + for example self.a, self[1, 2] = foo traverses all nodes - for example case foo; in A[x:] then true; end + for example a b{c d}, :e do end traverses all nodes - for example fun (f bar) + for example def f &b; end traverses all nodes - for example %r{#@@1} + for example f{ |**baz, &b| } traverses all nodes - for example a # -# -&.foo + for example begin foo!; bar! end traverses all nodes - for example return() + for example %W"#{1}" traverses all nodes - for example case foo; in 1, "a", [], {} then nil; end + for example break traverses all nodes - for example %r{#@1} + for example foo[:baz => 1,] traverses all nodes - for example %w[] + for example case foo; in [x, y, *] then true; end traverses all nodes - for example foo =~ 1 + for example %i[foo bar] traverses all nodes - for example foo.C += raise(bar) rescue nil + for example def f (foo: 1, bar: 2, **baz, &b); end traverses all nodes - for example while def self.foo; tap do end; end; break; end + for example break fun foo do end traverses all nodes - for example def f o=1, p, &b; end + for example foo % 1 traverses all nodes - for example p <<~E - x - y -E + for example next fun foo do end traverses all nodes - for example $+ + for example def foo(...); super(...); end traverses all nodes - for example a b(c(d)), 1.0r do end + for example [1, 2] traverses all nodes - for example +foo + for example foo::(1) traverses all nodes - for example ::Foo = 10 + for example case foo; in a: then true; end traverses all nodes - for example f{ || } + for example case foo; in A then true; end traverses all nodes - for example f{ |**baz, &b| } + for example foo << 1 traverses all nodes - for example a = b = raise :x + for example a += 1 traverses all nodes - for example def foo(...); bar(...); end + for example tap (proc do end) traverses all nodes - for example foo == 1 + for example p ->() do a() do end end traverses all nodes - for example fun do end + for example def f foo = 1; end traverses all nodes - for example foo || (a, b = bar) + for example case foo; in 1 => a then true; end traverses all nodes - for example self::A, foo = foo + for example while class << self; tap do end; end; break; end traverses all nodes - for example a += b += raise :x + for example %r{a\ +b} traverses all nodes - for example case foo; in [*, x] then true; end + for example @@var |= 10 traverses all nodes - for example m "#{[]}" + for example ::A, foo = foo + traverses all nodes + for example a # + # +&.foo + traverses all nodes + for example unless foo; bar; end + traverses all nodes + for example begin; meth; rescue; baz; ensure; bar; end + traverses all nodes + for example foo.a = 1 + traverses all nodes + for example Foo = 10 + traverses all nodes + for example # coding:utf-8 + "\xD0\xBF\xD1\x80\xD0\xBE\xD0\xB2\xD0\xB5\xD1\x80\xD0\xBA\xD0\xB0" traverses all nodes -RuboCop::AST::ConstNode - #namespace - is expected to eq "::Foo::Bar" - #short_name - is expected to eq :BAZ - #relative? - with a non-namespaced constant - is expected to be relative - #each_path - yields all parts of the namespace - #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 - #module_name? - is expected not to be module name - with a constant with a lowercase letter - is expected to be module name - -RuboCop::AST::RangeNode +RuboCop::AST::ClassNode + #parent_class + when a parent class is specified + is expected to be const type + when no parent class is specified + is expected to be nil + #body + with a multi-expression body + is expected to be begin type + with an empty body + is expected to be nil + with a single expression body + is expected to be send type .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 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 beignless range - is expected to be range type - is expected to be a kind of RuboCop::AST::RangeNode - -RuboCop::AST::NodePattern::Parser - sequences - parses unions of literals as a set - parses function calls - generates specialized nodes - expands ... in sequence head deep inside unions - parses simple sequences properly - parses capture vs repetition with correct priority - -RuboCop::AST::CaseMatchNode - when using Ruby 2.7 or newer - #each_in_pattern - when passed a block - yields all the conditions - when not passed a block - is expected to be a kind of Enumerator - #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 - .new - is expected to be a kind of RuboCop::AST::CaseMatchNode - #keyword - is expected to eq "case" - #in_pattern_branches - is expected to eq 3 - is expected to all be in pattern type - #branches - when there is an else - with empty else - returns all the bodies - with else body - returns all the bodies - when there is no else keyword - returns only then when bodies - #else? - with an else statement - is expected to be else - without an else statement - is expected not to be else + is expected to be a kind of RuboCop::AST::ClassNode + #identifier + is expected to be const type -RuboCop::AST::DefinedNode - #method_name - is expected to eq :defined? - #arguments - is expected to eq 1 - is expected to all be sym type +RuboCop::AST::RegexpNode .new - with a defined? node - is expected to be a kind of RuboCop::AST::DefinedNode - #receiver - is expected to be nil - -RuboCop::AST::ArrayNode - #each_value - without block - is expected to be a kind of Enumerator - with block - is expected to eq ["(int 1)", "(int 2)", "(int 3)"] - is expected to be a kind of RuboCop::AST::ArrayNode - #values - with an empty array + is expected to be a kind of RuboCop::AST::RegexpNode + #ignore_case? + with no options + is expected not to be ignore case + with i and other options + is expected to be ignore case + with other options + is expected not to be ignore case + with only i option + is expected to be ignore case + #slash_literal? + with %r/-delimiters + is expected not to be slash literal + with multi-line %r{-delimiters + is expected not to be slash literal + with %r<-delimiters + is expected not to be slash literal + with %r{-delimiters + is expected not to be slash literal + with /-delimiters + is expected to be slash literal + #to_regexp + with a multi-line regexp without option + is expected to eq / +.+ +/ + with a regexp with an "n" option + is expected to eq "/abc/n" + with a regexp with an "u" option + is expected to eq "/abc/" + with a regexp with an "o" option + is expected to eq "/abc/i" + 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 // + with a regexp with option + is expected to eq /.+/mix + with a multi-line regexp with option + is expected to eq / +.+ +/ix + #single_interpolation? + with no options + is expected not to be single interpolation + with only o option + is expected to be single interpolation + with o and other options + is expected to be single interpolation + with other options + is expected not to be single interpolation + #extended? + with only x option + is expected to be extended + with other options + is expected not to be extended + with x and other options + is expected to be extended + with no options + is expected not to be extended + #content + with a regexp with option + is expected to eq ".+" + with a regexp without option + is expected to eq ".+" + with an empty regexp with option + is expected to eq "" + with a multi-line regexp without option + is expected to eq "\n.+\n" + with a multi-line regexp with option + is expected to eq "\n.+\n" + with an empty regexp + is expected to eq "" + #fixed_encoding? + with only u option + is expected to be fixed encoding + with no options + is expected not 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 + #delimiter? + with %r{-delimiters + is expected not to be delimiter "%" + is expected not to be delimiter "/" + is expected to be delimiter "{" + is expected not to be delimiter "%r/" + is expected not to be delimiter "%r{" + is expected not to be delimiter "%r" + is expected not to be delimiter "r" + is expected to be delimiter "}" + with %r/-delimiters + is expected to be delimiter "/" + is expected not to be delimiter "r" + is expected not to be delimiter "%" + is expected not to be delimiter "%r/" + is expected not to be delimiter "%r" + is expected not to be delimiter "{" + is expected not to be delimiter "}" + with multi-line %r{-delimiters + is expected not to be delimiter "/" + is expected to be delimiter "{" + is expected not to be delimiter "%r" + is expected not to be delimiter "%" + is expected not to be delimiter "%r{" + is expected not to be delimiter "%r/" + is expected 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 "r" + is expected not to be delimiter "%r<" + is expected not to be delimiter "}" + is expected not to be delimiter "{" + is expected to be delimiter "<" + is expected not to be delimiter "%r" + is expected not to be delimiter "/" + is expected not to be delimiter "%r/" + is expected to be delimiter ">" + with /-delimiters + is expected not to be delimiter "{" + is expected to be delimiter "/" + #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 %r{-delimiters + is expected to be percent r literal + with multi-line %r{-delimiters + is expected to be percent r literal + #interpolation? + with no interpolation returns false + is expected not to be interpolation + with direct variable interpoation + is expected to be interpolation + with regexp quote + is expected to be interpolation + #no_encoding? + with n and other options + is expected to be no encoding + with only n option + is expected to be no encoding + with no options + is expected not to be no encoding + with other options + is expected not to be no encoding + #delimiters + with /-delimiters + is expected to eq ["/", "/"] + with %r{-delimiters + is expected to eq ["{", "}"] + with multi-line %r{-delimiters + is expected to eq ["{", "}"] + with %r<-delimiters + is expected to eq ["<", ">"] + with %r/-delimiters + is expected to eq ["/", "/"] + #multiline_mode? + with other options + is expected not to be multiline mode + with m and other options + is expected to be multiline mode + with only m option + is expected to be multiline mode + with no options + is expected not to be multiline mode + #regopt + with an empty regexp is expected to be empty - with an array of variables - is expected to eq 2 - is expected to all be send type - with an array of literals - is expected to all be literal + is expected to be regopt type + with an empty regexp with option + is expected to be regopt type + is expected to eq [:i, :x] + 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 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 regopt type + is expected to be empty + #options + with a regexp with "o" option + is expected to eq 0 + with a regexp without option + is expected to eq 0 + with an empty regexp + is expected to eq 0 + with a regexp with multiple options is expected to eq 3 - #square_brackets? - with a percent literal - is expected not to be square brackets - with square brackets - is expected to be square brackets + with a regexp with single option + is expected to eq 1 + +RuboCop::AST::ModuleNode .new - is expected to be a kind of RuboCop::AST::ArrayNode - #percent_literal? - with a symbol percent literal - is expected not to be percent literal :string - is expected to be percent literal - is expected to be percent literal :symbol - with square brackets - is expected not to be percent literal :string - is expected not to be percent literal - is expected not to be percent literal :symbol - with a string percent literal - is expected to be percent literal - is expected to be percent literal :string - is expected not to be percent literal :symbol - #bracketed? - with a percent literal - is expected to be bracketed - unbracketed + is expected to be a kind of RuboCop::AST::ModuleNode + #identifier + is expected to be const type + #body + with a single expression body + is expected to be send type + with an empty body is expected to be nil - with square brackets - is expected to be bracketed + with a multi-expression body + is expected to be begin type + +RuboCop::AST::AndNode + .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 + #semantic_operator? + with a semantic and node + is expected to be semantic operator + with a logical and node + is expected not to be semantic operator + #lhs + with a logical and node + is expected to be sym type + with a semantic and node + is expected to be sym 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 + #rhs + with a logical and node + is expected to be int type + with a semantic and node + is expected to be int type + #operator + with a logical and node + is expected to eq "&&" + with a semantic and node + is expected to eq "and" + #alternate_operator + with a semantic and node + is expected to eq "&&" + with a logical and node + is expected to eq "and" + #inverse_operator + with a logical and node + is expected to eq "||" + with a semantic and node + is expected to eq "or" 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 a single argument + with a single argument and braces 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 + with a single argument + is expected to eq 1 with no arguments is expected to be empty - with no arguments and braces - is expected to be empty with multiple literal arguments is expected to eq 2 - with a single argument and braces - is expected to eq 1 - .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 - -Changelog - merges correctly - parses correctly - Changelog::Entry - generates correct content -RuboCop::AST::KeywordSplatNode +RuboCop::AST::IntNode #value - is expected to eq s(:kwsplat, - s(:send, nil, :foo)) - #operator - is expected to eq "**" - #key_delta - with alignment set to :left - when using colon delimiters - when keyword splat is on the same line - is expected to eq 0 - 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 using hash rocket delimiters - when keyword splat is on the same line - is expected to eq 0 - 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 - with alignment set to :right - when using hash rocket 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 behind - is expected to eq 0 - when keyword splat is aligned - is expected to eq 0 - when using colon delimiters - when keyword splat is aligned - is expected to eq 0 - when keyword splat is on the same line - is expected to eq 0 - when keyword splat is behind - is expected to eq 0 - when keyword splat is ahead - is expected to eq 0 + is expected to eq 10 .new - is expected to be a kind of RuboCop::AST::KeywordSplatNode - #key - is expected to eq s(:kwsplat, - s(:send, nil, :foo)) - #value_delta - when using colon 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 - when using hash rocket delimiters - when keyword splat is ahead - is expected to eq 0 - when keyword splat is behind - is expected to eq 0 - when keyword splat is on the same line - is expected to eq 0 - when keyword splat is left aligned - is expected to eq 0 - #colon? - is expected not to be colon - #hash_rocket? - is expected not to be hash rocket - #same_line? - when both pairs are on the same line - is expected to be same line s(:kwsplat, - s(:send, nil, :foo)) - when a multiline pair shares the same line - is expected to be same line s(:pair, - s(:sym, :a), - s(:begin)) - is expected to be same line s(:kwsplat, - s(:send, nil, :foo)) - when pairs are on separate lines - is expected not to be same line s(:kwsplat, - s(:send, nil, :foo)) - -RuboCop::AST::RuboCopCompatibility - when ran from an incompatible version of Rubocop - issues a warning - when ran from a compatible version of Rubocop - issues a warning + is expected to be a kind of RuboCop::AST::IntNode + #sign? + explicit positive int + is expected to be sign + explicit negative int + is expected to be sign -RuboCop::AST::PairNode - #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 :right - when using colon delimiters - when receiver key is ahead - when second pair is a keyword splat - is expected to eq 0 - when both pairs are explicit pairs - is expected to eq 2 - when 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 second pair is a keyword splat - is expected to eq 0 - when both pairs are explicit pairs - is expected to eq 0 - when both keys are on the same line - when both pairs are explicit pairs - is expected to eq 0 - when second pair is a keyword splat - is expected to eq 0 - when 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 receiver key is ahead - when both pairs are explicit pairs - is expected to eq 2 - when second pair is a keyword splat - is expected to eq 0 - when both keys are on the same line - when second pair is a keyword splat - is expected to eq 0 - when both pairs are explicit pairs - is expected to eq 0 - when 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 0 - with alignment set to :left - 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 both pairs are explicit pairs - is expected to eq -2 - when second pair is a keyword splat - is expected to eq -2 - when keys are aligned - when second key is a keyword splat - is expected to eq 0 - when both keys are explicit keys - is expected to eq 0 - when receiver key is ahead - when both pairs are explicit pairs - is expected to eq 2 - when second pair is a keyword splat - is expected to eq 2 - when using colon 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 2 - when receiver key is behind - when second pair is a keyword splat - is expected to eq -2 - when both pairs are reail pairs - is expected to eq -2 - when keys are aligned - when second pair is a keyword splat - is expected to eq 0 - when both pairs are explicit pairs - is expected to eq 0 - when both keys are on the same line - when both pairs are explicit pairs - is expected to eq 0 - when second pair is a keyword splat - is expected to eq 0 - #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 a multiline pair shares the same line - when last pair is a keyword splat - is expected to be same line s(:pair, - s(:sym, :a), - s(:begin)) - is expected to be same line s(:kwsplat, - s(:send, nil, :foo)) - when both pairs are explicit pairs - is expected to be same line s(:pair, - s(:sym, :a), - s(:begin)) - is expected to be same line s(:pair, - s(:sym, :b), - s(:int, 2)) - when pairs are on separate lines - when both pairs are explicit pairs - is expected not to be same line s(:pair, - s(:sym, :b), - s(:int, 2)) - when last pair is a keyword splat - is expected not to be same line s(:kwsplat, - s(:send, nil, :foo)) - #colon? - when using a colon delimiter - is expected to be colon - when using a hash rocket delimiter - is expected not to be colon +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) .new - is expected to be a kind of RuboCop::AST::PairNode - #value_on_new_line? - when value starts on a new line - is expected to be value on new line - when pair is on a single line - is expected not to be value on new line - when value spans multiple lines - is expected not to be value on new line - #hash_rocket? - when using a colon delimiter - is expected not to be hash rocket - when using a hash rocket delimiter - is expected to be hash rocket - #value_omission? - when using hash value omission - is expected to be value omission - when not using hash value omission - is expected not to be value omission - #value_delta - when using hash rocket delimiters - when receiver value is ahead - is expected to eq 2 - when values are aligned - when both pairs are explicit pairs - is expected to eq 0 - when second pair is a keyword splat - is expected to eq 0 - when both pairs are on the same line - is expected to eq 0 - when receiver value is behind - is expected to eq -2 - when using colon delimiters - when both pairs are on the same line - is expected to eq 0 - when receiver value is behind - is expected to eq -2 - when values are aligned - when second pair is a keyword splat - is expected to eq 0 - when both pairs are explicit pairs - is expected to eq 0 - when receiver value is ahead - is expected to eq 2 - #key - when using a symbol key - is expected to be sym type - when using a string key - is expected to be str type - #delimiter - when using a colon delimiter - is expected to eq ":" - is expected to eq ": " - when using a hash rocket delimiter - is expected to eq " => " - is expected to eq "=>" - #value - is expected to be int type - -RuboCop::AST::NodePattern::Sets - is expected to eq "::RuboCop::AST::NodePattern::Sets::SET_1_2_3_ETC" - is expected to eq "::RuboCop::AST::NodePattern::Sets::SET_1_2_3_ETC" - is expected not to eq "::RuboCop::AST::NodePattern::Sets::SET_1_2_3_ETC_2" - creates a constant with the right value - -RuboCop::AST::AsgnNode + with an `op_asgn_node` node + is expected to be a kind of RuboCop::AST::OpAsgnNode #name - with a `cvasgn` node - is expected to eq :@@var - with a `gvasgn` node - is expected to eq :$var - with a `ivasgn` node - is expected to eq :@var - with a `lvasgn` node - is expected to eq :var - .new - with a `ivasgn` node - is expected to be a kind of RuboCop::AST::AsgnNode - with a `lvasgn` node - is expected to be a kind of RuboCop::AST::AsgnNode - with a `cvasgn` node - is expected to be a kind of RuboCop::AST::AsgnNode - with a `gvasgn` node - is expected to be a kind of RuboCop::AST::AsgnNode - #expression - with a `ivasgn` node - is expected to eq s(:send, nil, :value) - with a `gvasgn` 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::InPatternNode - when using Ruby 2.7 or newer - #branch_index - is expected to eq 2 - is expected to eq 1 - is expected to eq 0 - #body - without a then keyword - is expected to be array type - with a then keyword - is expected to be sym type - #then? - with a then keyword - is expected to be then - without a then keyword - is expected not to be then - #pattern - with a hash pattern - is expected to be hash pattern type - with an array pattern - is expected to be array pattern type - with a pin operator - is expected to be pin type - with a variable pattern - is expected to be match var type - with a value pattern - is expected to be int type - with an alternative pattern - is expected to be match alt type - with an as pattern - is expected to be match as type - .new - is expected to be a kind of RuboCop::AST::InPatternNode - -RuboCop::AST::NodePattern::Lexer - provides tokens via next_token - when given a regexp /test/ - round trips - when given a regexp /[abc]+\/()?/x - round trips - with $type+ - is parsed as `$ int + x` - when given arithmetic symbols - is parsed as `:&` - when given node types and constants - distinguishes them - when given a regexp ending with a backslash - does not lexes it properly - when given a regexp /back\\slash/ - round trips + is expected to eq :var + #assignment_node + is expected to be a kind of RuboCop::AST::AsgnNode RuboCop::AST::RescueNode + #body + is expected to be send type + #resbody_branches + is expected to eq 2 + is expected to all be resbody type .new is expected to be a kind of RuboCop::AST::RescueNode - #else? - with an else statement - is expected to be else - without an else statement - is expected not to be else #else_branch - with an else statement - is expected to be send type without an else statement is expected to be nil + with an else statement + is expected to be send type #branches - when there is no else keyword - returns only then rescue bodies when there is an else returns all the bodies with an empty else returns all the bodies - #body - is expected to be send type - #resbody_branches - is expected to eq 2 - is expected to all be resbody type - -RuboCop::AST::OrNode - #lhs - with a logical or node - is expected to be sym type - with a semantic or node - is expected to be sym type - #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 semantic or node - is expected to eq "and" - with a logical or node - is expected to eq "&&" - #rhs - with a semantic or node - is expected to be int type - with a logical or node - is expected to be int type - #operator - with a semantic or node - is expected to eq "or" - with a logical or node - is expected to eq "||" - #semantic_operator? - with a logical or node - is expected not to be semantic operator - with a semantic or node - is expected to be semantic operator - #alternate_operator - with a logical or node - is expected to eq "or" - with a semantic or node - is expected to eq "||" - -RuboCop::AST::Procarg0Node - .new - with a block - is expected to be a kind of RuboCop::AST::ArgNode - #name - is expected to eq :x + when there is no else keyword + returns only then rescue bodies + #else? + with an else statement + is expected to be else + without an else statement + is expected not to be else -RuboCop::AST::Token - #space_after - returns nil when there is not a space after token - returns truthy MatchData when there is a space after token - #end_pos - returns index of last char in token range of entire source - #to_s - returns string of token data - #space_before - returns nil when it is on the first line - returns nil when there is not a space before token - returns truthy MatchData when there is a space before token - .from_parser_token - returns a #to_s useful for debugging - sets parser token's range to rubocop token's pos - sets parser token's text to rubocop token's text - sets parser token's type to rubocop token's type - type predicates - #end? - returns true for end tokens - returns false for non end 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 - #new_line? - returns true for new line tokens - returns false for non new line tokens - #dot? - returns false for non dot tokens - returns true for dot tokens - #comment? - returns false for non comment tokens - returns true for comment tokens - #rescue_modifier? - returns false for non rescue modifier tokens - returns true for rescue modifier tokens - #semicolon? - returns false for non semicolon tokens - returns true for semicolon tokens - #left_bracket? - returns false for non left_bracket tokens - returns true for all left_bracket tokens - #left_brace? - returns false for non right_bracket tokens - returns true for right_bracket tokens - #regexp_dots? - returns false for non comma tokens - returns true for regexp tokens - #equals_sign? - returns false for non equals sign tokens - returns true for equals sign tokens - #right_bracket? - returns true for all right_bracket tokens - returns false for non right_bracket tokens - with braces & parens - #left_curly_brace? - returns true for left block brace tokens - returns false for non left block brace tokens - #right_parens? - returns false for non right parens tokens - returns true for right parens 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 - #left_brace? - returns true for left hash brace tokens - returns false for non left hash brace tokens - #left_array_bracket? - returns false for non left_array_bracket tokens - returns true for left_array_bracket tokens - #line - returns line of token - #begin_pos - returns index of first char in token range of entire source - #column - returns index of first char in token range on that line +RuboCop::AST::LambdaNode + #arguments + is expected to eq 2 + #method_name + is expected to eq :lambda + #receiver + is expected to be nil RuboCop::AST::DstrNode #value - with interpolation - is expected to eq "foo \#{bar} baz" - with a multiline string - is expected to eq "this is a multiline string" with implicit concatenation is expected to eq "foo bar baz" + 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 - #value - is expected to eq :foo - .new - with a symbol node - is expected to be a kind of RuboCop::AST::SymbolNode +RuboCop::AST::NodePattern::Parser + sequences + parses function calls + parses simple sequences properly + generates specialized nodes + parses capture vs repetition with correct priority + expands ... in sequence head deep inside unions + parses unions of literals as a set -RuboCop::AST::AndNode - #operator - with a semantic and node - is expected to eq "and" - with a logical and node - is expected to eq "&&" - #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 semantic and node - is expected to be int type - with a logical and node - is expected to be int type - #inverse_operator - with a logical and node - is expected to eq "||" - with a semantic and node - is expected to eq "or" - #lhs - with a logical and node - is expected to be sym type - with a semantic and node - is expected to be sym type - #alternate_operator - with a logical and node - is expected to eq "and" - with a semantic and node - is expected to eq "&&" - .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 - #logical_operator? - with a logical and node - is expected to be logical operator - with a semantic and node - is expected not to be logical operator +RuboCop::AST::ProcessedSource + .from_file + raises a Errno::ENOENT when the file does not exist + when the file exists + returns an instance of ProcessedSource + sets the file path to the instance's #path + with heavily commented source + #comments_before_line + returns comments on or before given line + #each_comment + yields all comments + #comment_at_line + returns the comment at the given line number + returns nil if line has no comment + #find_comment + yields nil when there is no match + yields correct comment + #contains_comment? + provided source_range on line without comment + is expected to equal false + 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 + #line_with_comment? + returns false for lines without comments + returns true for lines with comments + #each_comment_in_lines + yields the comments + #ast + is the root node of AST + #file_path + returns file path + #first_token_of + accepts Node as an argument + returns first token for node + token enumerables + #each_token + yields all tokens + #find_token + yields correct token + yields nil when there is no match + #last_token_of + accepts Node as an argument + returns last token for node + #path + is the path passed to .new + #tokens_within + accepts Node as an argument + returns tokens for node + when heredoc as argument is present + returns tokens for heredoc node + returns tokens for node before heredoc + returns tokens for node after heredoc + #parser_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 + when the source could not be parsed due to encoding error + returns the error + #blank? + with source of no content + returns true + with source with content + returns false + #lines + is an array + has same number of elements as line count + contains lines as string without linefeed + valid_syntax? + when a line starts with an integer literal + tokenizes the source correctly + 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 could not be parsed due to encoding error + returns false + when the source is valid but has some warning diagnostics + returns true + when the source is completely valid + returns true + #tokens + has an array of tokens + #following_line + returns source of line after token + #comments + is an array of comments + when the source is invalid + returns [] + #preceding_line + returns source of line before token + #buffer + is a source buffer + #start_with? + with blank source + returns false + with present source + returns true when passed string that starts source + returns false when passed string that does not start source + #[] + when an index is passed + returns the line + when a range is passed + returns the array of lines + when start index and length are passed + returns the array of lines -RuboCop::AST::DefNode +RuboCop::AST::CaseMatchNode when using Ruby 2.7 or newer - #argument_forwarding? - is expected to be argument forwarding - .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 - #body - with a multi-expression body - is expected to be begin type - with a single expression body + #branches + when there is no else keyword + returns only then when bodies + when there is an else + with else body + returns all the bodies + with empty else + returns all the bodies + #each_in_pattern + when passed a block + yields all the conditions + when not passed a block + is expected to be a kind of Enumerator + #keyword + is expected to eq "case" + #else_branch + #else? + with an else statement + is expected to be sym type + without an else statement + is expected to be nil + with an empty else statement + is expected to be empty else type + .new + is expected to be a kind of RuboCop::AST::CaseMatchNode + #in_pattern_branches + is expected to eq 3 + is expected to all be in pattern type + #else? + with an else statement + is expected to be else + without an else statement + is expected not to be else + +RuboCop::AST::SendNode + #receiver + with a variable receiver is expected to be send type - with no body + with no receiver is expected to be nil - #operator_method? + with a literal receiver + is expected to be str type + #camel_case_method? + with a camel case method + is expected to be camel case method with a regular method - is expected not to be operator method - with a unary operator method - is expected to be operator method - with a setter method - is expected not to be operator method - with a binary operator method - is expected to be operator method + is expected not to be camel case method + #arithmetic_operation? + with a binary arithmetic operation + is expected to be arithmetic operation + with a regular method call + is expected not to be arithmetic operation + with a unary numeric operation + is expected not to be arithmetic operation + #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 + #double_colon? + with 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 + without a dot + is expected not to be double colon + #dot? + with a double colon + is expected not to be dot + without a dot + is expected not to be dot + with a dot + is expected to be dot + with a unary method + is expected not to be dot + #self_receiver? + with a non-self receiver + is expected not to be self receiver + with an implicit receiver + is expected not to be self receiver + with a self receiver + is expected to be self receiver + #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 #arguments? + with no arguments + is expected not to be arguments with multiple mixed arguments is expected to be arguments - with a single rest argument + with multiple literal arguments is expected to be arguments - with a single keyword argument + with a single literal argument is expected to be arguments - with multiple regular arguments + with a single splat argument is expected to be arguments + #nonmutating_unary_operator_method? + with a nonmutating unary operator method + is expected to be nonmutating unary operator method + with a regular method + is expected not to be nonmutating unary operator method + #loop_keyword? + is expected not to be loop keyword + #lambda_literal? + with a stabby lambda + is expected to be lambda literal + with a lambda method + is expected not to be lambda literal + with `a.() {}` style method + is expected not to be lambda + with a non-lambda method + is expected not to be lambda + #first_argument + with multiple mixed arguments + is expected to be sym type with no arguments - is expected not to be arguments - with a single regular argument - is expected to be arguments + is expected to be nil + with multiple literal arguments + is expected to be sym type + with a single splat argument + is expected to be splat type + with a single literal argument + is expected to be sym type + #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 lambda method + is expected to be lambda + with a stabby lambda method + is expected to be lambda + with a method named lambda in a class + is expected not to be lambda + #assignment_method? + with an assignment method + is expected 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 a regular method + is expected not to be assignment method + #const_receiver? + with a non-constant receiver + is expected not to be const receiver + with a constant receiver + is expected to be const receiver + with a self receiver + is expected not to be const receiver + #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 + #non_bare_access_modifier? + when node is not an access modifier + is expected not 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 a non-bare `module_function` + is expected to be non bare access modifier + #comparison_method? + with a regular method + is expected not to be comparison method + with a negation method + is expected not to be comparison method + with a comparison method + is expected to be comparison method + #def_modifier? + with a prefixed def modifier + is expected to be def modifier + with several prefixed def modifiers + is expected to be def modifier + with a block containing a method definition + is expected not to be def modifier + #prefix_not? + with a non-negated method + is expected not to be prefix not + with keyword `not` + is expected to be prefix not + with a bang method + is expected not to be prefix not + .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 #bang_method? - with a predicate method + with a regular method is expected not to be bang method with a bang method is expected to be bang method - with a regular method + with a predicate method is expected not to be bang method - #rest_argument? - with a rest argument - is expected to be rest argument + #nonmutating_binary_operator_method? + with a regular method + is expected not to be nonmutating binary operator method + with a mutating binary operator method + is expected not to be nonmutating binary operator method + with a nonmutating binary operator method + is expected to be nonmutating binary operator method + #method? + when message does not match + when argument is a symbol + is expected not to be method :foo + when argument is a string + is expected not to be method "foo" + when message matches + when argument is a string + is expected to be method "bar" + when argument is a symbol + is expected to be method :bar + #block_literal? + with a block argument + is expected not to be block literal + with a block literal + is expected to be block literal + with no block + is expected not to be block literal + with Ruby >= 2.7 + with a numblock literal + is expected to be block literal + #post_condition_loop? + is expected not to be post condition loop + #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 + #binary_operation?? + with a regular method call + is expected not to be binary operation + with an implicit call method + is expected not to be binary operation + with a binary operation + is expected to be binary operation + with a unary operation + is expected not to be binary operation + #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 + when node is a bare `module_function` + is expected to be access modifier + #splat_argument? + with a splat argument + is expected to be splat argument with no arguments - is expected not to be rest argument + is expected not to be splat argument + with regular arguments + is expected not to be splat argument with mixed arguments - is expected to be rest argument + is expected to be splat argument + #command? + 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" + 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 + #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 + #negation_method? + with a non-negated method + is expected not to be negation method + with suffix `not` + is expected not to be negation method + with prefix `not` + is expected to be negation method + with prefix bang + is expected to be negation method + #macro? + without a receiver + when parent is a keyword begin inside of an class + is expected to be macro + with Ruby >= 2.7 + when parent is a numblock in a macro scope + is expected to be macro + when parent is a block in a macro scope + is expected to be macro + when the condition of an if + is expected not to be macro + when in the global scope + is expected to be macro + when parent is a module + 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 in an if + is expected to be macro + without a parent + is expected to be macro + when parent is a begin without a parent + is expected to be macro + when parent is a singleton class + is expected to be macro + when parent is a class constructor + is expected to be macro + when parent is a method definition + is expected not to be macro + when parent is a block not in a macro scope + is expected not to be 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 + #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 + #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 call with no argument + is expected to be nil + with a prefixed def modifier + is expected to eq :bar + #arguments + with a single literal argument + is expected to eq 1 + with a single splat argument + is expected to eq 1 + with multiple literal arguments + is expected to eq 2 + with multiple mixed arguments + is expected to eq 2 + with no arguments + is expected to be empty + #attribute_accessor? + with an accessor + returns the accessor method and Array] + with a call without arguments + is expected to be nil + #block_argument? + with no arguments + is expected not to be block argument with regular arguments - is expected not to be rest 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 block argument + #last_argument + with a single splat argument + is expected to be splat type + with a single literal argument + is expected to be sym type + with multiple mixed arguments + is expected to be splat type + with multiple literal arguments + is expected to be sym type + with no arguments + is expected to be nil + #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 + #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 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 + when node is not an access modifier + is expected not to be bare access modifier + #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 + #enumerable_method? + with an enumerable method + is expected to be enumerable method + with a regular method + is expected not to be enumerable method + #setter_method? + with an operator 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 + with a regular method + is expected not to be setter method + #method_name + 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 + with an operator method + is expected to eq :== + #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 + #block_node + with Ruby >= 2.7 + with a numblock literal + is expected to be numblock type + with a block argument + is expected to be nil + with a block literal + is expected to be block type + with no block + is expected to be nil + +RuboCop::AST::DefNode #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 a single keyword argument + is expected to be kwoptarg 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 + with a single regular argument + is expected to be arg type + with a single rest argument + is expected to be restarg type #void_context? with a comparison method is expected not to be void context - with an initializer method + with a regular assignment method is expected to be void context with a regular method is expected not to be void context - with a bracket assignment method + with an initializer method is expected to be void context - with a regular assignment method + with a bracket assignment method is expected to be void context - #first_argument - with a single keyword argument - is expected to be kwoptarg type + #arguments? + with multiple mixed arguments + is expected to be arguments + with a single rest argument + is expected to be arguments with no arguments - is expected to be nil + is expected not to be arguments with multiple regular arguments - is expected to be arg type + is expected to be arguments + with a single regular argument + is expected to be arguments + with a single keyword argument + is expected to be arguments + when using Ruby 2.7 or newer + #argument_forwarding? + is expected to be argument forwarding + #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" + #last_argument with multiple mixed arguments + is expected to be restarg type + with no arguments + is expected to be nil + with a single regular argument is expected to be arg type + with a single keyword argument + is expected to be kwoptarg type with a single rest argument is expected to be restarg type - with a single regular argument + with multiple regular arguments is expected to be arg type + #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 + .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 + #body + with a single expression body + is expected to be send type + with no body + is expected to be nil + with a multi-expression body + is expected to be begin type + #method_name + with a plain method + is expected to eq :foo + with a setter method + is expected to eq :foo= + with a unary method + is expected to eq :-@ + with an operator method + is expected to eq :== + #comparison_method? + with a regular method + is expected not to be comparison method + with a comparison method + is expected to be comparison method + #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 + with a unary operator method + is expected to be operator method #endless? with standard method definition is expected not to be endless with endless method definition is expected to be endless #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 - #const_receiver? - with an instance method definition - is expected not to be const receiver - with a class method definition - is expected not to be const receiver with a singleton method definition - is expected to be const receiver + is expected to be const type + #bang_method? + with a predicate method + is expected not to be bang method + with a bang method + is expected to be bang method + with a regular method + is expected not to be bang method #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 a bracket assignment method - is expected 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 - #method_name - with an operator method - is expected to eq :== - 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 #block_argument? - with a block argument - is expected to be block argument with mixed arguments is expected to be 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 - #last_argument - with multiple mixed arguments - is expected to be restarg type - with no arguments - is expected to be nil - with a single keyword argument - is expected to be kwoptarg type - with a single rest argument - is expected to be restarg type - with a single regular argument - is expected to be arg type - with multiple regular arguments - is expected to be arg type - #predicate_method? - with a bang method - is expected not to be predicate method - with a predicate method - is expected to be predicate method - with a regular method - is expected not to be predicate method - #method? - when message does not match - when argument is a symbol - is expected not to be method :foo - when argument is a string - is expected not to be method "foo" - when message matches - when argument is a symbol - is expected to be method :bar - when argument is a string - is expected to be method "bar" + #self_receiver? + with an instance method definition + is expected not to be self receiver + with a class method definition + is expected to be self receiver + with a singleton method definition + is expected not to be self receiver + #const_receiver? + with a class method definition + is expected not to be const receiver + with a singleton method definition + is expected to be const receiver + with an instance method definition + is expected not to be const receiver #arguments - with a single rest argument - is expected to eq 1 - with multiple regular arguments - is expected to eq 2 with no arguments is expected to be empty - with multiple mixed arguments - is expected to eq 2 with a single regular argument is expected to eq 1 + with a single rest argument + is expected to eq 1 with argument forwarding is expected to eq 1 - #comparison_method? - with a regular method - is expected not to be comparison method - with a comparison method - is expected to be comparison method + with multiple mixed arguments + is expected to eq 2 + with multiple regular arguments + is expected to eq 2 + #rest_argument? + 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 + with mixed arguments + is expected to be rest argument -RuboCop::AST::WhenNode - #body - without a then keyword - is expected to be array type - with a then keyword +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::OrNode + #lhs + with a logical or node + is expected to be sym type + with a semantic or node is expected to be sym type + #logical_operator? + with a semantic or node + is expected not to be logical operator + with a logical or node + is expected to be logical operator .new - is expected to be a kind of RuboCop::AST::WhenNode - #each_condition - when not passed a block + 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 + #rhs + with a semantic or node + is expected to be int type + with a logical or node + is expected to be int type + #alternate_operator + with a logical or node + is expected to eq "or" + with a semantic or node + is expected to eq "||" + #operator + with a semantic or node + is expected to eq "or" + with a logical or node + is expected to eq "||" + #inverse_operator + with a logical or node + is expected to eq "&&" + with a semantic or node + is expected to eq "and" + #semantic_operator? + with a semantic or node + is expected to be semantic operator + with a logical or node + is expected not to be semantic operator + +RuboCop::AST::ArrayNode + #square_brackets? + with a percent literal + is expected not to be square brackets + with square brackets + is expected to be square brackets + .new + is expected to be a kind of RuboCop::AST::ArrayNode + #each_value + with block + is expected to be a kind of RuboCop::AST::ArrayNode + is expected to eq ["(int 1)", "(int 2)", "(int 3)"] + without block is expected to be a kind of Enumerator - when passed a block - yields all the conditions - #conditions - with a single condition - is expected to all be literal - is expected to eq 1 - with a multiple conditions + #percent_literal? + with a symbol percent literal + is expected to be percent literal + is expected to be percent literal :symbol + is expected not to be percent literal :string + with a string percent literal + is expected to be percent literal + is expected not to be percent literal :symbol + is expected to be percent literal :string + with square brackets + is expected not to be percent literal + is expected not to be percent literal :symbol + is expected not to be percent literal :string + #bracketed? + unbracketed + is expected to be nil + with square brackets + is expected to be bracketed + with a percent literal + is expected to be bracketed + #values + with an array of literals is expected to all be literal is expected to eq 3 - #branch_index - is expected to eq 1 - is expected to eq 0 - is expected to eq 2 - #then? - without a then keyword - is expected not to be then - with a then keyword - is expected to be then + with an empty array + is expected to be empty + with an array of variables + is expected to eq 2 + is expected to all be send type + +RuboCop::AST::SelfClassNode + #body + with a single expression body + is expected to be send type + with an empty body + is expected to be nil + with a multi-expression body + is expected to be begin type + .new + is expected to be a kind of RuboCop::AST::SelfClassNode + #identifier + is expected to be self type -Finished in 4.81 seconds (files took 1.97 seconds to load) +Finished in 3.61 seconds (files took 1.79 seconds to load) 2392 examples, 0 failures -Randomized with seed 8497 +Randomized with seed 55165 ┌──────────────────────────────────────────────────────────────────────────────┐ @@ -6559,12 +6595,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/3490227/tmp/hooks/B01_cleanup starting +I: user script /srv/workspace/pbuilder/3490227/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/3429604 and its subdirectories -I: Current time: Mon May 20 05:43:36 -12 2024 -I: pbuilder-time-stamp: 1716227016 +I: removing directory /srv/workspace/pbuilder/3490227 and its subdirectories +I: Current time: Mon Jun 23 14:07:53 +14 2025 +I: pbuilder-time-stamp: 1750637273