Diff of the two buildlogs: -- --- b1/build.log 2024-12-29 03:43:57.987212817 +0000 +++ b2/build.log 2024-12-29 03:47:47.388695415 +0000 @@ -1,6 +1,6 @@ I: pbuilder: network access will be disabled during build -I: Current time: Fri Jan 30 22:06:10 -12 2026 -I: pbuilder-time-stamp: 1769853970 +I: Current time: Sun Dec 29 17:44:01 +14 2024 +I: pbuilder-time-stamp: 1735443841 I: Building the build Environment I: extracting base tarball [/var/cache/pbuilder/unstable-reproducible-base.tgz] I: copying local configuration @@ -26,54 +26,86 @@ 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/102872/tmp/hooks/D02_print_environment starting +I: user script /srv/workspace/pbuilder/8405/tmp/hooks/D01_modify_environment starting +debug: Running on ionos12-i386. +I: Changing host+domainname to test build reproducibility +I: Adding a custom variable just for the fun of it... +I: Changing /bin/sh to bash +'/bin/sh' -> '/bin/bash' +lrwxrwxrwx 1 root root 9 Dec 29 03:44 /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/8405/tmp/hooks/D01_modify_environment finished +I: user script /srv/workspace/pbuilder/8405/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='i386' - DEBIAN_FRONTEND='noninteractive' - DEB_BUILD_OPTIONS='buildinfo=+all reproducible=+all parallel=22 ' - DISTRIBUTION='unstable' - HOME='/root' - HOST_ARCH='i386' + BASH=/bin/sh + BASHOPTS=checkwinsize:cmdhist:complete_fullquote:extquote:force_fignore:globasciiranges:globskipdots:hostcomplete:interactive_comments:patsub_replacement:progcomp:promptvars:sourcepath + BASH_ALIASES=() + BASH_ARGC=() + BASH_ARGV=() + BASH_CMDS=() + BASH_LINENO=([0]="12" [1]="0") + BASH_LOADABLES_PATH=/usr/local/lib/bash:/usr/lib/bash:/opt/local/lib/bash:/usr/pkg/lib/bash:/opt/pkg/lib/bash:. + BASH_SOURCE=([0]="/tmp/hooks/D02_print_environment" [1]="/tmp/hooks/D02_print_environment") + BASH_VERSINFO=([0]="5" [1]="2" [2]="37" [3]="1" [4]="release" [5]="i686-pc-linux-gnu") + BASH_VERSION='5.2.37(1)-release' + BUILDDIR=/build/reproducible-path + BUILDUSERGECOS='second user,second room,second work-phone,second home-phone,second other' + BUILDUSERNAME=pbuilder2 + BUILD_ARCH=i386 + DEBIAN_FRONTEND=noninteractive + DEB_BUILD_OPTIONS='buildinfo=+all reproducible=+all parallel=10 ' + DIRSTACK=() + DISTRIBUTION=unstable + EUID=0 + FUNCNAME=([0]="Echo" [1]="main") + GROUPS=() + HOME=/root + HOSTNAME=i-capture-the-hostname + HOSTTYPE=i686 + HOST_ARCH=i386 IFS=' ' - INVOCATION_ID='0f0c32b9eeed48b7a711622f581e896f' - LANG='C' - LANGUAGE='en_US:en' - LC_ALL='C' - LD_LIBRARY_PATH='/usr/lib/libeatmydata' - LD_PRELOAD='libeatmydata.so' - 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='102872' - PS1='# ' - PS2='> ' + INVOCATION_ID=1b31c8adf3db4053905b92f6d6d07638 + LANG=C + LANGUAGE=de_CH:de + LC_ALL=C + LD_LIBRARY_PATH=/usr/lib/libeatmydata + LD_PRELOAD=libeatmydata.so + MACHTYPE=i686-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=8405 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.UFZNy5JW/pbuilderrc_cVNk --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.UFZNy5JW/b1 --logfile b1/build.log ruby-rubocop-ast_1.24.0-2.dsc' - SUDO_GID='112' - SUDO_UID='107' - SUDO_USER='jenkins' - TERM='unknown' - TZ='/usr/share/zoneinfo/Etc/GMT+12' - USER='root' - _='/usr/bin/systemd-run' - http_proxy='http://213.165.73.152: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.UFZNy5JW/pbuilderrc_85iJ --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.UFZNy5JW/b2 --logfile b2/build.log ruby-rubocop-ast_1.24.0-2.dsc' + SUDO_GID=112 + SUDO_UID=107 + SUDO_USER=jenkins + TERM=unknown + TZ=/usr/share/zoneinfo/Etc/GMT-14 + UID=0 + USER=root + _='I: set' + http_proxy=http://46.16.76.132:3128 I: uname -a - Linux ionos6-i386 6.1.0-28-amd64 #1 SMP PREEMPT_DYNAMIC Debian 6.1.119-1 (2024-11-22) x86_64 GNU/Linux + Linux i-capture-the-hostname 6.1.0-28-amd64 #1 SMP PREEMPT_DYNAMIC Debian 6.1.119-1 (2024-11-22) x86_64 GNU/Linux I: ls -l /bin - lrwxrwxrwx 1 root root 7 Nov 22 2024 /bin -> usr/bin -I: user script /srv/workspace/pbuilder/102872/tmp/hooks/D02_print_environment finished + lrwxrwxrwx 1 root root 7 Nov 22 14:40 /bin -> usr/bin +I: user script /srv/workspace/pbuilder/8405/tmp/hooks/D02_print_environment finished -> Attempting to satisfy build-dependencies -> Creating pbuilder-satisfydepends-dummy package Package: pbuilder-satisfydepends-dummy @@ -270,7 +302,7 @@ Get: 147 http://deb.debian.org/debian unstable/main i386 ruby-rspec-mocks all 3.13.0c0e0m0s1-2 [81.3 kB] Get: 148 http://deb.debian.org/debian unstable/main i386 ruby-rspec all 3.13.0c0e0m0s1-2 [5184 B] Get: 149 http://deb.debian.org/debian unstable/main i386 ruby-whitequark-parser all 3.3.4.2-2 [507 kB] -Fetched 49.1 MB in 1s (35.6 MB/s) +Fetched 49.1 MB in 2s (32.1 MB/s) Preconfiguring packages ... Selecting previously unselected package libpython3.12-minimal:i386. (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 ... 19844 files and directories currently installed.) @@ -769,8 +801,8 @@ Setting up tzdata (2024b-4) ... Current default time zone: 'Etc/UTC' -Local time is now: Sat Jan 31 10:06:38 UTC 2026. -Universal Time is now: Sat Jan 31 10:06:38 UTC 2026. +Local time is now: Sun Dec 29 03:46:04 UTC 2024. +Universal Time is now: Sun Dec 29 03:46:04 UTC 2024. Run 'dpkg-reconfigure tzdata' if you wish to change it. Setting up autotools-dev (20220109.1) ... @@ -903,7 +935,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/8405/tmp/hooks/A99_set_merged_usr starting +Not re-configuring usrmerge for unstable +I: user script /srv/workspace/pbuilder/8405/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 @@ -943,7 +979,7 @@ │ ruby-rubocop-ast: Installing files and building extensions for ruby3.1 │ └──────────────────────────────────────────────────────────────────────────────┘ -/usr/bin/ruby3.1 -S gem build --config-file /dev/null --verbose /tmp/d20260130-111279-a87h7r/gemspec +/usr/bin/ruby3.1 -S gem build --config-file /dev/null --verbose /tmp/d20241229-17213-lo6xrc/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: @@ -953,7 +989,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/d20260130-111279-a87h7r/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/d20241229-17213-lo6xrc/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 @@ -1080,3612 +1116,3747 @@ warning: parser/current is loading parser/ruby31, which recognizes 3.1.6-compliant syntax, but you are running 3.1.2. Please see https://github.com/whitequark/parser#compatibility-with-ruby-mri. -Randomized with seed 22326 +Randomized with seed 29460 -RuboCop::AST::ConstNode - #each_path - yields all parts of the namespace - #relative? - with a non-namespaced constant - is expected to be relative - #module_name? - is expected not to be module name - with a constant with a lowercase letter - is expected to be module name - #absolute? - is expected to be absolute - with a constant not starting with :: - is expected not to be absolute - with a non-namespaced constant - is expected not to be absolute - #short_name - is expected to eq :BAZ - #namespace - is expected to eq "::Foo::Bar" +RuboCop::AST::ArgsNode + .new + with a lambda literal + is expected to be a kind of RuboCop::AST::ArgsNode + with a method definition + is expected to be a kind of RuboCop::AST::ArgsNode + with a block + 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 lambda literal + is expected to equal true + with a method definition + is expected to equal true + with a block + is expected to equal true + with arguments + with a lambda literal + is expected to equal false + with a method definition + is expected to equal false + with delimiters + with a method definition + is expected to equal false + with a block + is expected to equal false + with a lambda literal + is expected to equal false RuboCop::AST::ArgNode #default_value - with a regular argument - is expected to be nil - with a double splatted argument - is expected to be nil - with an optional argument - is expected to eq s(:int, 42) - with an optional keyword argument - is expected to eq s(:int, 42) with a shadow argument is expected to be nil + with a splatted argument + is expected to be nil with a block is expected to be nil + with an optional argument + is expected to eq s(:int, 42) with argument forwarding with Ruby >= 2.7 is expected to be nil with Ruby >= 3.0 is expected to be nil - with a splatted argument + with a regular argument + is expected to be nil + with a double splatted argument is expected to be nil with a block argument is expected to be nil - .new - with a block - is expected to be a kind of RuboCop::AST::ArgNode with an optional keyword argument - is expected to be a kind of RuboCop::AST::ArgNode - with a method definition - is expected to be a kind of RuboCop::AST::ArgNode - with a shadow argument - is expected to be a kind of RuboCop::AST::ArgNode - with a lambda literal - is expected to be a kind of RuboCop::AST::ArgNode - with an optional argument - is expected to be a kind of RuboCop::AST::ArgNode - with argument forwarding - with Ruby >= 2.7 - is expected to be a kind of RuboCop::AST::ArgNode - with Ruby >= 3.0 - is expected to be a kind of RuboCop::AST::ArgNode - with a double splatted argument - is expected to be a kind of RuboCop::AST::ArgNode - with a keyword argument - is expected to be a kind of RuboCop::AST::ArgNode - with a block argument - is expected to be a kind of RuboCop::AST::ArgNode - with a splatted argument - is expected to be a kind of RuboCop::AST::ArgNode + is expected to eq s(:int, 42) #default? - with a block argument + with a block is expected to equal false - with a double splatted argument + with a shadow argument + is expected to equal false + with a block argument is expected to equal false + with an optional argument + is expected to equal true with a splatted argument is expected to equal false + with a regular argument + is expected to equal false with argument forwarding with Ruby >= 3.0 is expected to equal false with Ruby >= 2.7 is expected to equal false - with a shadow argument - is expected to equal false - with a block - is expected to equal false - with a regular argument - is expected to equal false with an optional keyword argument is expected to equal true - with an optional argument - is expected to equal true + with a double splatted argument + is expected to equal false #name + with a nameless double splatted argument + is expected to be nil + with an optional keyword argument + is expected to eq :x + with a double splatted argument + is expected to eq :x + with a block + is expected to eq :x + with a nameless splatted argument + is expected to be nil with an optional argument is expected to eq :x with a shadow argument is expected to eq :x - with a regular argument - is expected to eq :x with a block argument is expected to eq :x with argument forwarding - with Ruby >= 3.0 - is expected to be nil with Ruby >= 2.7 is expected to be nil - with a splatted argument + with Ruby >= 3.0 + is expected to be nil + with a regular argument is expected to eq :x with a keyword argument is expected to eq :x - with an optional keyword argument - is expected to eq :x - with a nameless splatted argument - is expected to be nil - with a block - is expected to eq :x - with a nameless double splatted argument - is expected to be nil - with a double splatted argument + with a splatted argument is expected to eq :x - -RuboCop::AST::Token - #begin_pos - returns index of first char in token range of entire source - #space_after - returns truthy MatchData when there is a space after token - returns nil when there is not a space after token - #column - returns index of first char in token range on that line - #line - returns line of token - type predicates - #right_bracket? - returns false for non right_bracket tokens - returns true for all right_bracket tokens - #left_ref_bracket? - returns false for non left_ref_bracket tokens - returns true for left_ref_bracket tokens - #rescue_modifier? - returns false for non rescue modifier tokens - returns true for rescue modifier tokens - #end? - returns false for non end tokens - returns true for end tokens - #dot? - returns true for dot tokens - returns false for non dot tokens - #left_bracket? - returns true for all left_bracket tokens - returns false for non left_bracket tokens - #comment? - returns false for non comment tokens - returns true for comment tokens - #semicolon? - returns true for semicolon tokens - returns false for non semicolon tokens - with braces & parens - #right_parens? - returns true for right parens tokens - returns false for non right parens tokens - #right_curly_brace? - returns true for all right brace tokens - returns false for non right brace tokens - #left_parens? - returns true for left parens tokens - returns false for non left parens tokens - #left_brace? - returns false for non left hash brace tokens - returns true for left hash brace tokens - #left_curly_brace? - returns false for non left block brace tokens - returns true for left block brace tokens - #left_array_bracket? - returns false for non left_array_bracket tokens - returns true for left_array_bracket tokens - #left_brace? - returns false for non right_bracket tokens - returns true for right_bracket tokens - #equals_sign? - returns false for non equals sign tokens - returns true for equals sign tokens - #regexp_dots? - returns false for non comma tokens - returns true for regexp tokens - #new_line? - returns true for new line tokens - returns false for non new line tokens - #comma? - returns true for comma tokens - returns false for non comma tokens - #end_pos - returns index of last char in token range of entire source - #space_before - returns truthy MatchData when there is a space before token - returns nil when there is not a space before token - returns nil when it is on the first line - .from_parser_token - sets parser token's range to rubocop token's pos - returns a #to_s useful for debugging - sets parser token's text to rubocop token's text - sets parser token's type to rubocop token's type - #to_s - returns string of token data - -Set#=== - tests for inclusion - -RuboCop::AST::Procarg0Node - #name - is expected to eq :x .new + with a block argument + is expected to be a kind of RuboCop::AST::ArgNode + with a double splatted argument + is expected to be a kind of RuboCop::AST::ArgNode + with argument forwarding + with Ruby >= 3.0 + is expected to be a kind of RuboCop::AST::ArgNode + with Ruby >= 2.7 + is expected to be a kind of RuboCop::AST::ArgNode + with a shadow argument + is expected to be a kind of RuboCop::AST::ArgNode + with an optional argument + is expected to be a kind of RuboCop::AST::ArgNode + with a keyword argument + is expected to be a kind of RuboCop::AST::ArgNode + with a method definition + is expected to be a kind of RuboCop::AST::ArgNode with a block is expected to be a kind of RuboCop::AST::ArgNode + with a splatted argument + is expected to be a kind of RuboCop::AST::ArgNode + with a lambda literal + is expected to be a kind of RuboCop::AST::ArgNode + with an optional keyword argument + is expected to be a kind of RuboCop::AST::ArgNode -RuboCop::AST::ResbodyNode - #exceptions - with multiple exceptions +RuboCop::AST::YieldNode + #camel_case_method? + is expected not to be camel case method + #setter_method? + is expected not to be setter method + #command? + when argument is a string + is expected to be command "yield" + when argument is a symbol + is expected to be command :yield + #assignment_method? + is expected not to be assignment method + #method_name + is expected to eq :yield + #arguments + with a single splat argument + is expected to eq 1 + with multiple literal arguments is expected to eq 2 - is expected to all be const type - with a single exception - is expected to all be const type + with a single literal argument is expected to eq 1 - without exception - is expected to eq 0 - .new - is expected to be a kind of RuboCop::AST::ResbodyNode - #exception_variable - for an implicit rescue - is expected to eq "ex" - for an explicit rescue - is expected to eq "ex" - when an exception variable is not given + with multiple mixed arguments + is expected to eq 2 + with no arguments + is expected to be empty + #first_argument + with a single literal argument + is expected to be sym type + with a single splat argument + is expected to be splat type + with no arguments is expected to be nil - #body - is expected to be sym type - #branch_index - is expected to eq 0 - is expected to eq 2 - is expected to eq 1 - -Changelog - parses correctly - merges correctly - Changelog::Entry - generates correct content - -RuboCop::AST::ModuleNode - #identifier - is expected to be const type - .new - is expected to be a kind of RuboCop::AST::ModuleNode - #body - with an empty body + with multiple literal arguments + is expected to be sym type + with multiple mixed arguments + is expected to be sym type + #last_argument + with multiple literal arguments + is expected to be sym type + with multiple mixed arguments + is expected to be splat type + with no arguments is expected to be nil - with a multi-expression body - is expected to be begin type - with a single expression body - is expected to be send type - -RuboCop::AST::SymbolNode - #value - is expected to eq :foo - .new - with a symbol node - is expected to be a kind of RuboCop::AST::SymbolNode - -RuboCop::AST::YieldNode - .new - is expected to be a kind of RuboCop::AST::YieldNode + with a single splat argument + is expected to be splat type + with a single literal argument + is expected to be sym type #implicit_call? is expected not to be implicit call + #comparison_method? + is expected not to be comparison method + #method? + when message matches + when argument is a string + is expected to be method "yield" + when argument is a symbol + is expected to be method :yield + when message does not match + when argument is a symbol + is expected not to be method :foo + when argument is a string + is expected not to be method "foo" + #predicate_method? + is expected not to be predicate method + #operator_method? + is expected not to be operator method + #double_colon? + is expected not to be double colon + #dot? + is expected not to be dot #arguments? with multiple literal arguments is expected to be arguments - with multiple mixed arguments + with a single splat 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 a single literal argument is expected to be arguments + with multiple mixed arguments + is expected to be arguments + .new + is expected to be a kind of RuboCop::AST::YieldNode + #receiver + is expected to be nil #block_node is expected to be nil + #block_literal? + is expected not to be block literal + #const_receiver? + is expected not to be const receiver + #self_receiver? + is expected not to be self receiver #macro? is expected not to be macro - #double_colon? - is expected not to be double colon - #assignment_method? - is expected not to be assignment method - #comparison_method? - is expected not to be comparison method - #command? - when argument is a symbol - is expected to be command :yield - when argument is a string - is expected to be command "yield" - #camel_case_method? - is expected not to be camel case method + #parenthesized? + with no arguments + when using parentheses + is expected to be parenthesized + when not using parentheses + is expected not to be parenthesized + with arguments + when using parentheses + is expected to be parenthesized + when not using parentheses + is expected not to be parenthesized #splat_argument? with a splat argument is expected to be splat argument with mixed arguments is expected to be splat argument - with regular arguments - is expected not to be splat argument with no arguments is expected not to be splat argument - #self_receiver? - is expected not to be self receiver + with regular arguments + is expected not to be splat argument #bang_method? is expected not to be bang method - #block_literal? - is expected not to be block literal - #predicate_method? - is expected not to be predicate method - #first_argument - with multiple literal arguments - is expected to be sym type - with a single splat argument - is expected to be splat type - with multiple mixed arguments - is expected to be sym type - with no arguments + #block_argument? + is expected not to be block argument + +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 - with a single literal argument + #body + with an empty body + is expected to be nil + with a multi-expression body + is expected to be begin type + with a single expression body + is expected to be send type + .new + is expected to be a kind of RuboCop::AST::ClassNode + #identifier + is expected to be const type + +RuboCop::AST::UntilNode + #do? + with a do keyword + is expected to be do + without a do keyword + is expected not to be do + #loop_keyword? + with a modifier until + is expected to be loop keyword + with a statement until + is expected to be loop keyword + #post_condition_loop? + with a modifier until + is expected to be post condition loop + with a statement until + is expected not to be post condition loop + #inverse_keyword + is expected to eq "while" + .new + with a modifier until + is expected to be a kind of RuboCop::AST::UntilNode + with a statement until + is expected to be a kind of RuboCop::AST::UntilNode + #keyword + is expected to eq "until" + +RuboCop::AST::PairNode + #key + when using a string key + is expected to be str type + when using a symbol key is expected to be sym type - #setter_method? - is expected not to be setter method + #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 + #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, :b), + s(:int, 2)) + is expected to be same line s(:pair, + s(:sym, :a), + s(:begin)) + when pairs are on separate lines + when both pairs are explicit pairs + is expected not to be same line s(:pair, + s(:sym, :b), + s(:int, 2)) + when last pair is a keyword splat + is expected not to be same line s(:kwsplat, + s(:send, nil, :foo)) + when 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)) + #key_delta + with alignment set to :left + when using colon delimiters + when receiver key is ahead + when second pair is a keyword splat + is expected to eq 2 + when both pairs are explicit pairs + is expected to eq 2 + when receiver key is behind + when both pairs are reail pairs + is expected to eq -2 + when second pair is a keyword splat + is expected to eq -2 + when both keys are on the same line + when both pairs are explicit pairs + is expected to eq 0 + when second pair is a keyword splat + is expected to eq 0 + when keys are aligned + when second pair is a keyword splat + is expected to eq 0 + when both pairs are explicit pairs + is expected to eq 0 + when using hash rocket delimiters + when receiver key is ahead + when both pairs are explicit pairs + is expected to eq 2 + when second pair is a keyword splat + is expected to eq 2 + when both keys are on the same line + when second pair is a keyword splat + is expected to eq 0 + when both pairs are explicit pairs + is expected to eq 0 + when receiver key is behind + when second pair is a keyword splat + is expected to eq -2 + when both pairs are explicit pairs + is expected to eq -2 + when 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 + with alignment set to :right + when using hash rocket delimiters + when receiver key is ahead + when both pairs are explicit pairs + is expected to eq 2 + when second pair is a keyword splat + is expected to eq 0 + when both keys are on the same line + when both pairs are explicit pairs + is expected to eq 0 + when second pair is a keyword splat + is expected to eq 0 + when keys are aligned + when 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 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 using colon delimiters + when receiver key is behind + when second pair is a keyword splat + is expected to eq 0 + when both pairs are reail pairs + is expected to eq -2 + when keys are aligned + when second pair is a keyword splat + is expected to eq 0 + when both pairs are explicit pairs + is expected to eq 0 + when receiver key is ahead + when second pair is a keyword splat + is expected to eq 0 + when both pairs are explicit pairs + is expected to eq 2 + when both keys are on the same line + when second pair is a keyword splat + is expected to eq 0 + when both pairs are explicit pairs + is expected to eq 0 + #value_delta + when using colon delimiters + when values are aligned + when both pairs are explicit pairs + is expected to eq 0 + when second pair is a keyword splat + is expected to eq 0 + when 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 + 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 + 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 + #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 + .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 + #inverse_delimiter + when using a hash rocket delimiter + is expected to eq ": " + is expected to eq ":" + when using a colon delimiter + is expected to eq "=>" + is expected to eq " => " + #value + is expected to be int type + #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 + #delimiter + when using a hash rocket delimiter + is expected to eq " => " + is expected to eq "=>" + when using a colon delimiter + is expected to eq ":" + is expected to eq ": " + +RuboCop::AST::Ext::Range + #line_span + accepts an `exclude_end` keyword argument + returns the range of lines a range occupies + +RuboCop::AST::SendNode + #unary_operation? + with a unary operation + is expected to be unary operation + with a binary operation + is expected not to be unary operation + with a regular method call + is expected not to be unary operation + with an implicit call method + is expected not to be unary operation + #binary_operation?? + with a unary operation + is expected not to be binary operation + with a regular method call + is expected not to be binary operation + with an implicit call method + is expected not to be binary operation + with a binary operation + is expected to be binary operation + #splat_argument? + with mixed arguments + is expected to be splat argument + with regular arguments + is expected not to be splat argument + with a splat argument + is expected to be splat argument + with no arguments + is expected not to be splat argument + #predicate_method? + with a regular method + is expected not to be predicate method + with a predicate method + is expected to be predicate method + with a bang method + is expected not to be predicate method + #block_argument? + with no arguments + is expected not 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 mixed arguments + is expected to be block argument + #enumerable_method? + with an enumerable method + is expected to be enumerable method + with a regular method + is expected not 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 + #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 + with prefix bang + is expected to be negation method + #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 + with an implicit call method + is expected to be implicit call + #operator_method? + with a setter method + is expected not to be operator method + with a binary operator method + is expected to be operator method + with a regular method + is expected not to be operator method + with a unary operator method + is expected to be operator method + #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 + with a prefixed def modifier + is expected to be def modifier + #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 #method_name - is expected to eq :yield - #const_receiver? - is expected not to be const receiver - #dot? - is expected not to be dot + with a setter method + is expected to eq :bar= + with an operator method + is expected to eq :== + with a plain method + is expected to eq :bar + with an implicit call method + is expected to eq :call + #assignment_method? + with a regular method + is expected not to be assignment method + with a comparison method + is expected not to be assignment method + with a bracket assignment method + is expected to be assignment method + with an assignment method + is expected to be assignment method + #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 + #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 + #bare_access_modifier? + when node is a bare `module_function` + is expected to be bare access modifier + when node is not an access modifier + is expected not to be bare access modifier + when node has an argument + is expected not to be bare access modifier + with Ruby >= 2.7 + when node is access modifier in block + is expected to be bare access modifier + when node is access modifier in numblock + is expected to be bare access modifier + #attribute_accessor? + with an accessor + returns the accessor method and Array] + with a call without arguments + is expected to be nil + #loop_keyword? + is expected not to be loop keyword + #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 + when node does not have an argument + is expected not to be non bare access modifier + #nonmutating_hash_method? + with a regular method + is expected not to be nonmutating hash method + with a mutating Hash method + is expected not to be nonmutating hash method + with a nonmutating Hash method + is expected to be nonmutating hash method + #command? + when argument is a symbol + with an implicit receiver + is expected to be command :bar + with an explicit receiver + is expected not to be command :bar + when argument is a string + with an implicit receiver + is expected to be command "bar" + with an explicit receiver + is expected not to be command "bar" + #def_modifier + with several prefixed def modifiers + is expected to eq :qux + with call with no argument + is expected to be nil + with a prefixed def modifier + is expected to eq :bar + with a block containing a method definition + is expected to be nil + #post_condition_loop? + is expected not to be post condition loop #arguments - with multiple mixed arguments - is expected to eq 2 + with a single splat argument + is expected to eq 1 with multiple literal arguments is expected to eq 2 - 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 no arguments + is expected to be empty + with multiple mixed arguments + is expected to eq 2 + #prefix_not? + with keyword `not` + is expected to be prefix not + with a non-negated method + is expected not to be prefix not + with a bang method + is expected not to be prefix not + #lambda? + with a non-lambda method + is expected not 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 + with a lambda method + is expected to be lambda + #receiver + with no receiver + is expected to be nil + with a variable receiver + is expected to be send type + with a literal receiver + is expected to be str type + #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 + with a mutating binary operator method + is expected not to be nonmutating binary operator method + #const_receiver? + with a constant receiver + is expected to be const receiver + with a self receiver + is expected not to be const receiver + with a non-constant receiver + is expected not to be const receiver #last_argument + with a single splat argument + is expected to be splat type + with multiple literal arguments + is expected to be sym type + with multiple mixed arguments + is expected to be splat type + with no arguments + is expected to be nil with a single literal argument is expected to be sym type + #first_argument with multiple literal arguments is expected to be sym type + with no arguments + is expected to be nil + with a single literal argument + is expected to be sym type with a single splat argument is expected to be splat type with multiple mixed arguments - is expected to be splat type - with no arguments - is expected to be nil - #block_argument? - is expected not to be block argument + is expected to be sym type + #self_receiver? + with an implicit receiver + is expected not to be self receiver + with a non-self receiver + is expected not to be self receiver + with a self receiver + is expected to be self receiver + #prefix_bang? + with keyword `not` + is expected not to be prefix bang + with a bang method + is expected to be prefix bang + with a non-negated method + is expected not to be prefix bang + #nonmutating_operator_method? + with a nonmutating binary operator method + is expected to be nonmutating operator method + with a nonmutating unary operator method + is expected to be nonmutating operator method + with a regular method + is expected not to be nonmutating operator method + with a mutating binary operator method + is expected not to be nonmutating operator method + #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 #method? + when message matches + when argument is a symbol + is expected to be method :bar + when argument is a string + is expected to be method "bar" when message does not match when argument is a string is expected not to be method "foo" when argument is a symbol is expected not to be method :foo + #macro? + without a receiver + when parent is a begin without a parent + is expected to be macro + when in an if + is expected to be macro + when parent is a struct constructor + is expected to be macro + 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 singleton class + is expected to be macro + when parent is a class + is expected to be macro + when in the global scope + is expected to be macro + when parent is a class constructor + 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 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 + when parent is a module + is expected to be macro + without a parent + is expected to be macro + with a receiver + when parent is a module + is expected not to be macro + when parent is a class + is expected not to be macro + #lambda_literal? + with `a.() {}` style method + is expected not to be lambda + with a non-lambda method + is expected not to be lambda + with a stabby lambda + is expected to be lambda literal + with a lambda method + is expected not to be lambda literal + #nonmutating_string_method? + with a nonmutating String method + is expected to be nonmutating string method + with a mutating String method + is expected not to be nonmutating string method + with a regular method + is expected not to be nonmutating string method + #dot? + without a dot + is expected not to be dot + with a unary method + is expected not to be dot + with a double colon + is expected not to be dot + with a dot + is expected to be dot + #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 + .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 + #arguments? + with a single splat argument + is expected to be arguments + with multiple literal arguments + is expected to be arguments + with multiple mixed arguments + is expected to be arguments + with a single literal argument + is expected to be arguments + with no arguments + is expected not to be arguments + #block_literal? + with Ruby >= 2.7 + with a numblock literal + is expected to be block literal + with a block literal + is expected to be block literal + with no block + is expected not to be block literal + with a block argument + is expected not to be block literal + #double_colon? + with a unary method + is expected not to be double colon + with a double colon + is expected to be double colon + without a dot + is expected not to be double colon + with a dot + is expected not to be double colon + #block_node + with a block literal + is expected to be block type + with a block argument + is expected to be nil + with Ruby >= 2.7 + with a numblock literal + is expected to be numblock type + with no block + is expected to be nil + #setter_method? + with an indexed setter method + is expected to be setter method + with a regular method + is expected not to be setter method + with an operator method + is expected not to be setter method + with a setter method + is expected to be setter method + #nonmutating_array_method? + with a regular method + is expected not to be nonmutating array method + with a nonmutating Array method + is expected to be nonmutating array method + with a mutating Array method + is expected not to be nonmutating array method + #arithmetic_operation? + with a binary arithmetic operation + is expected to be arithmetic operation + with a unary numeric operation + is expected not to be arithmetic operation + with a regular method call + is expected not to be arithmetic operation + +RuboCop::AST::DefNode + #first_argument + with a single regular argument + is expected to be arg type + with a single keyword argument + is expected to be kwoptarg type + with multiple mixed arguments + is expected to be arg type + with a single rest argument + is expected to be restarg type + with no arguments + is expected to be nil + with multiple regular arguments + is expected to be arg type + #arguments? + with a single rest argument + is expected to be arguments + with no arguments + is expected not to be arguments + with multiple regular arguments + is expected to be arguments + with multiple mixed arguments + is expected to be arguments + with a single keyword argument + is expected to be arguments + with a single regular argument + is expected to be arguments + #comparison_method? + with a regular method + is expected not to be comparison method + with a comparison method + is expected to be comparison method + #block_argument? + with mixed arguments + is expected to be block argument + with regular arguments + is expected not to be block argument + with no arguments + is expected not to be block argument + with a block argument + is expected to be block argument + when using Ruby 2.7 or newer + #argument_forwarding? + is expected to be argument forwarding + #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 + #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 "yield" + is expected to be method "bar" + when message does not match + when argument is a string + is expected not to be method "foo" when argument is a symbol - is expected to be method :yield - #parenthesized? + is expected not to be method :foo + #arguments + with a single regular argument + is expected to eq 1 + with multiple mixed arguments + is expected to eq 2 + with argument forwarding + is expected to eq 1 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 + is expected to be empty + with a single rest argument + is expected to eq 1 + with multiple regular arguments + is expected to eq 2 + #rest_argument? + with no arguments + is expected not to be rest argument + with mixed arguments + is expected to be rest argument + with regular arguments + is expected not to be rest argument + with a rest argument + is expected to be rest argument + #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 + #const_receiver? + with a singleton method definition + is expected to be const receiver + with a class method definition + is expected not to be const receiver + with an instance method definition + is expected not to be const receiver + #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 + #method_name + with an operator method + is expected to eq :== + with a unary method + is expected to eq :-@ + with a plain method + is expected to eq :foo + with a setter method + is expected to eq :foo= + #assignment_method? + with a regular method + is expected not to be assignment method + with a comparison method + is expected not to be assignment method + with an assignment method + is expected to be assignment method + with a bracket assignment method + is expected to be assignment method + #void_context? + with a regular assignment method + is expected to be void context + with an initializer method + is expected to be void context + with a regular method + is expected not to be void context + with a comparison method + is expected not to be void context + with a bracket assignment method + is expected to be void context + #predicate_method? + with a regular method + is expected not to be predicate method + with a bang method + is expected not to be predicate method + with a predicate method + is expected to be predicate method + #last_argument + with a single rest argument + is expected to be restarg type + 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 multiple regular arguments + is expected to be arg type + #self_receiver? + with a singleton method definition + is expected not to be self receiver + with an instance method definition + is expected not to be self receiver + with a class method definition + is expected to be self receiver + #body + with no body + is expected to be nil + with a multi-expression body + is expected to be begin type + with a single expression body + is expected to be send type + .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 + #endless? + with endless method definition + is expected to be endless + with standard method definition + is expected not to be endless #operator_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 regular method + is expected not to be operator method + with a binary operator method + is expected to be operator method + +RuboCop::AST::ArrayNode + #percent_literal? + with square brackets + is expected not to be percent literal :string + is expected not to be percent literal :symbol + is expected not to be percent literal + with a symbol percent literal + is expected to be percent literal :symbol + is expected to be percent literal + is expected not to be percent literal :string + with a string percent literal + is expected to be percent literal :string + is expected to be percent literal + is expected not to be percent literal :symbol + #values + with an array of literals + is expected to eq 3 + is expected to all be literal + with an array of variables + is expected to eq 2 + is expected to all be send type + with an empty array + is expected to be empty + #bracketed? + unbracketed + is expected to be nil + with a percent literal + is expected to be bracketed + with square brackets + is expected to be bracketed + #square_brackets? + with a percent literal + is expected not to be square brackets + with square brackets + is expected to be square brackets + .new + is expected to be a kind of RuboCop::AST::ArrayNode + #each_value + without block + is expected to be a kind of Enumerator + with block + is expected to eq ["(int 1)", "(int 2)", "(int 3)"] + is expected to be a kind of RuboCop::AST::ArrayNode + +RuboCop::AST::LambdaNode + #method_name + is expected to eq :lambda + #arguments + is expected to eq 2 #receiver is expected to be nil -RuboCop::AST::NodePattern::Parser - sequences - expands ... in sequence head deep inside unions - generates specialized nodes - parses capture vs repetition with correct priority - parses simple sequences properly - parses unions of literals as a set - parses function calls +RuboCop::AST::StrNode + .new + with a heredoc + is expected to be a kind of RuboCop::AST::StrNode + with a normal string + is expected to be a kind of RuboCop::AST::StrNode + with a string with interpolation + is expected to be a kind of 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 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 + +RuboCop::AST::DstrNode + #value + with implicit concatenation + is expected to eq "foo bar baz" + with interpolation + is expected to eq "foo \#{bar} baz" + with a multiline string + is expected to eq "this is a multiline string" + +RuboCop::AST::HashNode + #braces? + with braces + is expected to be braces + as an argument with no braces + is expected not to be braces + as an argument with braces + is expected to be braces + #pairs_on_same_line? + with some pairs on the same line + is expected to be pairs on same line + with all pairs on the same line + is expected to be pairs on same line + with no pairs on the same line + is expected not to be pairs on same line + #each_value + when passed a block + yields all the pairs + when not passed a block + is expected to be a kind of Enumerator + #each_pair + when passed a block + yields all the pairs + when not passed a block + is expected to be a kind of Enumerator + #mixed_delimiters? + when all pairs are using a colon delimiter + is expected not to be mixed delimiters + when pairs are using different delimiters + is expected to be mixed delimiters + when all pairs are using a hash rocket delimiter + is expected not to be mixed delimiters + #empty? + with a hash containing pairs + is expected not to be empty + with an empty hash + is expected to be empty + with a hash containing a keyword splat + is expected not to be empty + #pairs + with an empty hash + is expected to be empty + with a hash of literals + is expected to eq 3 + is expected to all be pair type + with a hash of variables + is expected to eq 2 + is expected to all be pair type + #keys + with an empty hash + is expected to be empty + with a hash with string keys + is expected to all be str type + is expected to eq 2 + with a hash with symbol keys + is expected to eq 3 + is expected to all be sym type + #each_key + when not passed a block + is expected to be a kind of Enumerator + when passed a block + yields all the pairs + .new + is expected to be a kind of RuboCop::AST::HashNode + #values + with an empty hash + is expected to be empty + with a hash with literal values + is expected to all be literal + is expected to eq 3 + with a hash with string keys + is expected to all be send type + is expected to eq 2 + +RuboCop::AST::AsgnNode + .new + with a `ivasgn` 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 `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 + #name + with a `ivasgn` node + is expected to eq :@var + with a `cvasgn` node + is expected to eq :@@var + with a `lvasgn` node + is expected to eq :var + with a `gvasgn` node + is expected to eq :$var + #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 `cvasgn` node + is expected to eq s(:send, nil, :value) + with a `ivasgn` node + is expected to eq s(:send, nil, :value) + +RuboCop::AST::RescueNode + #else? + without an else statement + is expected not to be else + with an else statement + is expected to be else + #resbody_branches + is expected to all be resbody type + is expected to eq 2 + #branches + when there is an else + returns all the bodies + with an empty else + returns all the bodies + when there is no else keyword + returns only then rescue bodies + #else_branch + without an else statement + is expected to be nil + with an else statement + is expected to be send type + #body + is expected to be send type + .new + is expected to be a kind of RuboCop::AST::RescueNode + +RuboCop::AST::SelfClassNode + #identifier + is expected to be self type + #body + with an empty body + is expected to be nil + with a single expression body + is expected to be send type + with a multi-expression body + is expected to be begin type + .new + is expected to be a kind of RuboCop::AST::SelfClassNode + +RuboCop::AST::Node + #pure? + for a class definition + returns false + for a nested if + where one branch contains an assignment statement + returns false + where the innermost descendants are local vars and literals + returns true + where one branch contains a method call + returns false + for a cvar assignment + returns false + for a module definition + returns false + for an array literal + which contains a method call + returns false + with only literal children + returns true + for a hash literal + with only literal children + returns true + which contains a method call + returns false + for an lvar assignment + returns false + for an integer literal + returns true + for a gvar assignment + returns false + for an ivar assignment + returns false + for a regexp + with options + returns true + with no interpolation + returns true + with interpolated segments + returns false + for a method call + returns false + #class_definition? + with self singleton class + matches + constant defined as Struct without block + does not match + with inheritance + matches + with object singleton class + matches + with ::ClassName + matches + with Class.new + matches + when using numbered parameter + matches + without inheritance + matches + with Struct + matches + when using numbered parameter + matches + namespaced class + matches + #numeric_type? + when complex literal + is true + when float literal + is true + when complex literal whose imaginary part is a rational + is true + when integer literal + is true + when string literal + is true + when rational literal + is true + #class_constructor? + class definition on outer scope + matches + class definition with a block + matches + class definition + does not match + module definition with a block + matches + #struct_constructor? + ::Struct + matches + struct definition with a block + matches + struct definition without block + does not match + #parent_module_name + when node nested in a class << exp + is expected to be nil + 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 module + is expected to eq "Foo" + when node nested in an unknown block + is expected to be nil + when node on top level + is expected to eq "Object" + #argument_type? + block arguments + returns true for all argument types + method arguments + returns true for all argument types + #module_definition? + prepend Module.new + matches + using module keyword + matches + with Module.new + matches + when using numbered parameter + matches + with ::ModuleName + matches + included module definition + matches + nested modules + matches + namespaced modules + matches + #conditional? + when `if` node + is true + when post condition loop node + is false + when `until` node + is true + when `while` node + is true + when `case_match` node + is true + when `case` node + is true + #value_used? + within a method call node + is always true + within an if...else..end node + at the top level + is true only for the condition + nested in a method call + is always true + at the end of a block + is always true + at the top level + is false + within a singleton class node + is always true + within a module definition node + is always true + within a while node + is true only for the condition + within a class definition node + is always true + within an array literal + at the top level + is always false + assigned to an ivar + is always true + #recursive_basic_literal? + 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 `(false && true)` + behaves like literal + returns true for `{ :a => 1, :b => 2 }` + behaves like non literal + returns false for `%r{abx#{foo}}ixo` + behaves like literal + returns true for `false` + behaves like literal + returns true for `[1, 2, 3]` + behaves like non literal + returns false for `[some_method_call]` + behaves like literal + returns true for `{ a: 1, b: 2 }` + behaves like literal + returns true for `(false <=> true)` + behaves like non literal + returns false for `{ :sym => some_method_call }` + 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 `1.0` + behaves like non literal + returns false for `/.#{some_method_call}/` + behaves like non literal + returns false for `some_method_call` + behaves like literal + returns true for `"#{2}"` + behaves like literal + returns true for `1` + behaves like literal + returns true for `(1)` + behaves like non literal + returns false for `(x or false)` + behaves like literal + returns true for `!true` + behaves like literal + returns true for `/./` + behaves like non literal + returns false for `(x == false)` + behaves like literal + returns true for `'str'` + behaves like literal + returns true for `(false or true)` + behaves like non literal + returns false for `(x && false)` + sibling_access + returns trivial values for a root node + for a single child + returns the expected values + for a node with siblings + returns the expected values + +Changelog + parses correctly + merges correctly + Changelog::Entry + generates correct content + +RuboCop::AST::BlockNode + #receiver + with dot operator call + is expected to eq "foo" + with safe navigation operator call + is expected to eq "foo" + #opening_delimiter + when enclosed in do-end keywords + is expected to eq "do" + when enclosed in braces + is expected to eq "{" + #delimiters + when enclosed in do-end keywords + is expected to eq ["do", "end"] + when enclosed in braces + is expected to eq ["{", "}"] + .new + is expected to be a kind of RuboCop::AST::BlockNode + #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 + #braces? + when enclosed in braces + is expected to be braces + when enclosed in do-end keywords + is expected not to be braces + #arguments + >= Ruby 2.7 + using numbered parameters + 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 destructured arguments + is expected to eq 2 + with a single splat argument + is expected to eq 1 + with no arguments + is expected to be empty + #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 each + is expected to be void context + when block method is not each + is expected not to be void context + when block method is tap + is expected to be void context + #lambda? + when block belongs to a non-lambda method + is expected not to be lambda + when block belongs to a method lambda + is expected to be lambda + when block belongs to a stabby lambda + is expected to be lambda + #arguments? + >= Ruby 2.7 + using numbered parameters + is expected not to be arguments + with a single splat argument + is expected to be arguments + with a single argument + is expected to be arguments + with destructuring arguments + is expected to be arguments + with multiple mixed arguments + is expected to be arguments + with no arguments + is expected not to be arguments + #argument_list + with no arguments + is expected to be empty + >= 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] + #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 + +RuboCop::AST::AliasNode + #new_identifier + is expected to be sym type + is expected to eq :foo + #old_identifier + is expected to eq :bar + is expected to be sym type + .new + is expected to be a kind of RuboCop::AST::AliasNode + +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::Procarg0Node + #name + is expected to eq :x + .new + with a block + is expected to be a kind of RuboCop::AST::ArgNode + +RuboCop::AST::DefinedNode + #receiver + is expected to be nil + .new + with a defined? node + is expected to be a kind of RuboCop::AST::DefinedNode + #arguments + is expected to all be sym type + is expected to eq 1 + #method_name + is expected to eq :defined? + +RuboCop::AST::OrAsgnNode + #name + is expected to eq :var + #operator + is expected to eq :"||" + .new + is expected to be a kind of RuboCop::AST::OrAsgnNode + #assignment_node + is expected to be a kind of RuboCop::AST::AsgnNode + #expression + is expected to eq s(:send, nil, :value) + +RuboCop::AST::NodePattern::Lexer + provides tokens via next_token + when given a regexp ending with a backslash + does not lexes it properly + when given node types and constants + distinguishes them + when given a regexp /back\\slash/ + round trips + when given a regexp /[abc]+\/()?/x + round trips + when given arithmetic symbols + is parsed as `:&` + when given a regexp /test/ + round trips + with $type+ + is parsed as `$ int + x` + +RuboCop::AST::AndAsgnNode + #operator + is expected to eq :"&&" + #expression + is expected to eq s(:send, nil, :value) + #assignment_node + is expected to be a kind of RuboCop::AST::AsgnNode + #name + is expected to eq :var + .new + is expected to be a kind of RuboCop::AST::AndAsgnNode + +RuboCop::AST::CasgnNode + #namespace + when the parent is a `cbase` + is expected to eq s(:cbase) + when the parent is a `const` + is expected to eq s(:const, nil, :FOO) + when there is no parent + is expected to be nil + #name + is expected to eq :VAR + .new + with a `casgn` node + is expected to be a kind of RuboCop::AST::CasgnNode + #expression + is expected to eq s(:send, nil, :value) + +RuboCop::AST::ForNode + #body + is expected to be sym type + #post_condition_loop? + is expected not to be post condition loop + #variable + is expected to be lvasgn type + #collection + is expected to be sym type + #loop_keyword? + is expected to be loop keyword + #keyword + is expected to eq "for" + .new + is expected to be a kind of RuboCop::AST::ForNode + #do? + without a do keyword + is expected not to be do + with a do keyword + is expected to be do + #void_context? + with a do keyword + is expected to be void context + without a do keyword + is expected to be void context + +RuboCop::AST::FloatNode + #value + is expected to eq 1.5 + .new + is expected to be a kind of RuboCop::AST::FloatNode + #sign? + explicit negative float + is expected to be sign + explicit positive float + is expected to be sign + +RuboCop::AST::KeywordSplatNode + #key_delta + with alignment set to :left + when using hash rocket delimiters + when keyword splat is ahead + is expected to eq 2 + when keyword splat is on the same line + is expected to eq 0 + when keyword splat is aligned + is expected to eq 0 + when keyword splat is behind + is expected to eq -2 + when using colon delimiters + when keyword splat is aligned + is expected to eq 0 + when keyword splat is behind + is expected to eq -2 + when keyword splat is ahead + is expected to eq 2 + when keyword splat is on the same line + is expected to eq 0 + with alignment set to :right + 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 behind + is expected to eq 0 + when keyword splat is ahead + is expected to eq 0 + when using hash rocket delimiters + when keyword splat is behind + is expected to eq 0 + when keyword splat is ahead + is expected to eq 0 + when keyword splat is on the same line + is expected to eq 0 + when keyword splat is aligned + is expected to eq 0 + #value_delta + when using hash rocket delimiters + when keyword splat is left aligned + is expected to eq 0 + when keyword splat is ahead + is expected to eq 0 + when keyword splat is on the same line + is expected to eq 0 + when keyword splat is behind + is expected to eq 0 + when using colon delimiters + when keyword splat is left aligned + is expected to eq 0 + when keyword splat is ahead + is expected to eq 0 + when keyword splat is behind + is expected to eq 0 + when keyword splat is on the same line + is expected to eq 0 + #key + is expected to eq s(:kwsplat, + s(:send, nil, :foo)) + #value + is expected to eq s(:kwsplat, + s(:send, nil, :foo)) + #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(:kwsplat, + s(:send, nil, :foo)) + is expected to be same line s(:pair, + s(:sym, :a), + s(:begin)) + when pairs are on separate lines + is expected not to be same line s(:kwsplat, + s(:send, nil, :foo)) + #colon? + is expected not to be colon + .new + is expected to be a kind of RuboCop::AST::KeywordSplatNode + #hash_rocket? + is expected not to be hash rocket + #operator + is expected to eq "**" RuboCop::AST::Traversal knows all current node types - for example %q(foobar) - traverses all nodes - for example bar unless foo + for example module Bar::Foo; end traverses all nodes - for example case foo; in [x, y, *] then true; end + for example a &&= 1 traverses all nodes - for example begin end + for example f{ |a,| } traverses all nodes - for example [1, 2] + for example foo <=> 1 traverses all nodes - for example p <<~E - x - y -E + for example -> (a) { } traverses all nodes - for example case foo; in { a: 1 } then true; end + for example ->(a) { } traverses all nodes - for example a b{c(d)}, "x" do end + for example a&.b &&= 1 traverses all nodes - for example while def self.foo a = tap do end; end; break; end + for example a b(c(d)), 1.0r do end traverses all nodes - for example case foo; in [x, y,] then true; end + for example fun(foo, *bar) traverses all nodes - for example def f(foo); end + for example p <<~"E" + x + #{foo} +E traverses all nodes - for example foo && (a, b = bar) + for example def f(*foo); end traverses all nodes - for example def foo -=begin -=end -end + for example def foo(_, _); end traverses all nodes - for example @foo, @@bar = *foo + for example case foo; in x, y, then nil; end traverses all nodes - for example %s{a\ -b} + for example break() traverses all nodes - for example 1.33 + for example <<-`HERE` +#@@1 +HERE traverses all nodes - for example [ 1 => 2 ] + for example foo::a += m foo traverses all nodes - for example __LINE__ + for example `foobar` traverses all nodes - for example p <<~E - x - y -E + for example def String.foo; end traverses all nodes for example f{ |a| } traverses all nodes - for example begin; meth; rescue; baz; ensure; bar; end + for example def f(foo, bar); end traverses all nodes - for example def f(&block); end + for example def m; class << self; class C; end; end; end traverses all nodes - for example def String; end + for example case foo; in [*, x] then true; end traverses all nodes - for example foo::a += m foo + for example begin ensure end traverses all nodes - for example unless foo then bar; end + for example m { |foo| } traverses all nodes - for example f{ |a| } + for example 1.. traverses all nodes - for example '#@1' + for example a b(c(d)), 1.0i do end traverses all nodes - for example p p{p(p);p p}, tap do end + for example traverses all nodes - for example m ->(a = ->{_1}) {a} + for example def f *, **; end traverses all nodes - for example proc {_1 = nil} + for example case foo; in ..2 then true; end traverses all nodes - for example fun(*bar, &baz) + for example case foo; in ->{ 42 } then true; end traverses all nodes - for example a, *b, c = bar + for example -1.33 traverses all nodes for example %I() traverses all nodes - for example -> do rescue; end - traverses all nodes - for example return + for example f{ |a, o=1, p, &b| } traverses all nodes - for example a += 1 + for example begin end traverses all nodes - for example begin; meth; rescue => ex; bar; end + for example if foo +then bar end traverses all nodes - for example a b(c d), :e do end + for example case foo; in x, *y, z then nil; end traverses all nodes - for example def f a, *r, &b; end + for example "foo#@a" "bar" traverses all nodes - for example case foo; when 'bar'; bar; else baz; end + for example <<-E + 1 \ + 2 + 3 +E traverses all nodes - for example class A < B -end + for example case foo; in 1..2 then true; end traverses all nodes - for example def f a, &b; end + for example m { |(foo, bar)| } traverses all nodes - for example 1.. + for example m def x(); end; 1.tap do end traverses all nodes - for example a b(c d), "x" do end + for example def f &b; end traverses all nodes - for example p ->() do a() do end end + for example fun (1).to_i traverses all nodes - for example %q{a\ -b} + for example class Foo < a:b; end traverses all nodes - for example /#@@1/ + for example a b{c(d)}, 1.0i do end traverses all nodes - for example [1, *foo, 2] + for example case foo; in "#{ %Q{a} }": 1 then true; end traverses all nodes for example %I[foo#{bar}] traverses all nodes - for example "#@@1" + for example foo << 1 traverses all nodes - for example @@var |= 10 + for example case foo; when 'bar', 'baz'; bar; end traverses all nodes - for example case foo; in "#{ 'a' }": then true; end + for example def f(**); end traverses all nodes - for example ->{ } + for example not(foo) + traverses all nodes + for example foo::a = 1 + traverses all nodes + for example *, c, d = bar + traverses all nodes + for example super() + traverses all nodes + for example case foo; in * then nil; end + traverses all nodes + for example foo::a += 1 traverses all nodes for example def f o=1, *r, &b; end traverses all nodes - for example foo::a = 1 + for example f{ |*r, p, &b| } traverses all nodes - for example f{ |a, *| } + for example /#{1}(?bar)/ =~ 'bar' traverses all nodes - for example a b{c(d)}, 1.0i do end + for example a b(c(d)), :e do end traverses all nodes - for example <<-`HERE` -#@@1 -HERE + for example foo = baz, *bar traverses all nodes - for example () + for example foo | 1 traverses all nodes - for example self.a, self[1, 2] = foo + for example undef foo, :bar, :"foo#{1}" traverses all nodes - for example m { _1 + _9 } + for example false ? raise do end : tap do end traverses all nodes - for example foo&.bar {} + for example foo.fun bar traverses all nodes - for example a b{c(d)}, 1.0 do end + for example a b{c d}, 1.0r do end traverses all nodes - for example ((b, )) = foo + for example p :foo, {** proc do end, b: proc do end} traverses all nodes - for example meth 1 do end.fun bar + for example /foo#{bar}baz/ traverses all nodes - for example fun do end + for example foo[0] += raise(bar) rescue nil traverses all nodes - for example [ 1, 2 => 3 ] + for example p <<~E + x + \ y +E traverses all nodes - for example foo[bar,] + for example a b(c d), /x/ do end traverses all nodes - for example case foo; in A::B then true; end + for example meth 1 do end.fun bar do end traverses all nodes - for example /#{1}(?bar)/ =~ 'bar' + for example case; when foo; 'foo'; end traverses all nodes - for example * = bar + for example a, *b = bar traverses all nodes - for example super + for example def f ((*)); end traverses all nodes - for example a, b = *foo, bar + for example "a\ +b" traverses all nodes - for example def f ((a, *, p)); end + for example case foo; in "#{ %Q{a} }": then true; end traverses all nodes - for example def m; class << self; module M; end; end; end + for example f{ |a, *, &b| } traverses all nodes - for example case foo; in 1 => a then true; end + for example case foo; in **nil then true; end traverses all nodes - for example fun(foo, *bar, &baz) + for example m "#{}#{()}" traverses all nodes - for example nil + for example !/wat/ traverses all nodes - for example yield foo + for example a @b do |c|;end traverses all nodes - for example ::Foo = 10 + for example def f ((a, a1)); end traverses all nodes - for example f{ |;a| } + for example %q{#@@1} traverses all nodes - for example :'#@1' + for example @var = 10 traverses all nodes - for example :"a\ -b" + for example f{ |a, c| } traverses all nodes - for example fun() { } + for example -42 traverses all nodes - for example a b{c d}, /x/m do end + for example begin; meth; rescue => ex; bar; end traverses all nodes - for example { 'foo': 2 } + for example +foo traverses all nodes - for example BEGIN { 1 } + for example case foo; in [x, *, y] then true; end traverses all nodes - for example %W() + for example a = 1; a b: 1 traverses all nodes - for example case foo; in 1; end + for example 42r traverses all nodes - for example foo & 1 + for example /#@@1/ traverses all nodes - for example /#@1/ + for example a b{c d}, /x/m do end traverses all nodes - for example case foo; in A[1, 2] then true; end + for example def self._6; end traverses all nodes - for example f{ |a, o=1, *r, p, &b| } + for example @@var |= 10 traverses all nodes - for example foo != 1 + for example !(foo...bar) traverses all nodes - for example fun { } + for example def f a, *r, &b; end traverses all nodes - for example def f a, o=1, *r, p, &b; end + for example m "#{[]}" traverses all nodes - for example /foo#{bar}baz/ + for example bar def foo; self.each do end end traverses all nodes - for example case foo; in [*, x] then true; end + for example f{ |a, *s, &b| } traverses all nodes - for example %x{#@@1} + for example begin; meth; rescue; baz; else foo; ensure; bar end traverses all nodes - for example unless foo; bar; end + for example a, *b, c = bar traverses all nodes - for example a b(c d), /x/m do end + for example [1, *foo] traverses all nodes - for example o = { -a: -1 -} + for example begin meth end while foo traverses all nodes - for example desc "foo" do end + for example while foo; meth end traverses all nodes - for example foo | 1 + for example 1 in [a]; a traverses all nodes - for example ::A, foo = foo + for example def self.foo; end traverses all nodes - for example if (bar; a, b = foo); end + for example %W[#@1] traverses all nodes - for example def self._6; end + for example case foo; in 1.. then true; end traverses all nodes - for example !m foo + for example if foo then bar; end traverses all nodes - when a class defines `on_block_pass` - calls it for all block-pass arguments - for example def self.m; _1; end + for example <<-'HERE' +a\ +b +HERE traverses all nodes - for example +foo + for example defined?(foo) traverses all nodes - for example fun(foo, *bar) + for example bar if foo traverses all nodes - when a class defines on_arg - calls it for all arguments - for example def String::foo; end + for example case foo; in "a": 1 then true; end traverses all nodes - for example fun(*bar) + for example def f(**nil); end traverses all nodes - for example %w[ #@@1 ] + for example a += b = raise :x traverses all nodes - for example a b{c(d)}, 1.0r do end + for example def self::foo; end traverses all nodes - for example def f o=1, *r, p, &b; end + for example foo = *bar traverses all nodes - for example self.A, foo = foo + for example def f foo: +; end traverses all nodes - for example a b(c d), 1 do end + for example case foo; in ** then true; end traverses all nodes - for example begin; meth; rescue Exception; bar; end + for example break foo traverses all nodes - for example %s{#@1} + for example %r{#@1} traverses all nodes - for example *b, c = bar + for example -> a: 1 { } traverses all nodes - for example a, *b = bar + for example def f o=1, &b; end traverses all nodes - for example foo += raise(bar) rescue nil + for example false ? raise {} : tap {} + traverses all nodes + for example foo[0, 1] += m foo + traverses all nodes + for example meth 1 do end::fun bar traverses all nodes for example a # # &.foo traverses all nodes - for example next - traverses all nodes - for example case foo; in A() then true; end - traverses all nodes - for example case foo; in x, then nil; end + for example t=1;(foo)?t:T traverses all nodes - for example %{#@@1} + for example f{ |a, o=1, &b| } traverses all nodes - for example <<-'HERE' -#@@1 -HERE + for example case foo; in [x,] then nil; end traverses all nodes - for example case foo; in "#{ 'a' }": 1 then true; end + for example for a in foo; p a; end traverses all nodes - for example begin; meth; rescue Exception, foo; bar; end + for example fun(foo, *bar, &baz) traverses all nodes - for example case foo; in ->{ 42 } then true; end + for example a b{c d}, 1.0 do end traverses all nodes - for example def x; ::A ||= 1; end + for example case foo; in a:, b: then true; end traverses all nodes - for example f{ |a, o=1, p, &b| } + for example <<-`HERE` +#@1 +HERE traverses all nodes - for example foo::Fun bar + for example m { |**nil| } traverses all nodes - for example for a in foo; p a; end + for example :"#@@1" traverses all nodes - for example foo[0, 1] += 2 + for example foo.A += 1 traverses all nodes - for example def f a, o=1, *r, &b; end + for example case foo; in [x] then nil; end traverses all nodes - for example foo += m foo + for example proc {|_3|} traverses all nodes - for example foo.C += raise bar rescue nil + when given an unexpected AST + with too many children + raises debugging error + with too few children + raises debugging error + for example def foo(...); bar(...); end traverses all nodes - for example a b(c d), 1.0i do end + for example END { 1 } traverses all nodes - for example ->(scope) {}; scope + for example <<~E + 1 \ + 2 + 3 +E traverses all nodes - for example case foo; in { a: 1, } then true; end + for example m { _1 + _9 } traverses all nodes - for example :'a\ -b' + for example p <<~E + E traverses all nodes - for example def f ((a, *)); end + for example return(foo) traverses all nodes - for example foo::Fun() + for example a b(c(d)), /x/ do end traverses all nodes - for example fun(f bar) + for example 42ri traverses all nodes for example <<'HERE' foo bar HERE traverses all nodes - for example foo "#{(1+1).to_i}" do; end + for example f{ |**baz, &b| } traverses all nodes - for example a = b = raise :x + for example def f(foo: 1); end traverses all nodes - for example def f(**foo); end + for example fun(foo, :foo => 1) traverses all nodes - for example def a b: -return -end + for example %r{#@@1} traverses all nodes - for example begin ensure end + for example %q(foobar) traverses all nodes - for example <<`HERE` -foo -bar + for example def f(foo:); end + traverses all nodes + for example <<-'HERE' +#@1 HERE traverses all nodes - for example -1.33 + for example foo "#{(1+1).to_i}" do; end traverses all nodes - for example END { 1 } + for example foo.A += m foo traverses all nodes - for example case foo; in "#{ %Q{a} }": then true; end + for example m ->(a: ->{_1}) {a} traverses all nodes - for example p <<~E -E + for example "#{-> foo {}}" traverses all nodes - for example f{ |foo: 1, bar: 2, **baz, &b| } + for example foo::fun (1) {} traverses all nodes - for example foo.a &&= 1 + for example foo < 1 traverses all nodes - for example foo >> 1 + for example module A; _1; end traverses all nodes - for example %i[] + for example defined? @foo traverses all nodes - for example fun! + for example fun(f bar) traverses all nodes - for example m1 :k => m2 do; m3() do end; end + for example case foo; in a: 1, _a:, ** then true; end traverses all nodes - for example meth rescue bar + for example foo, bar = 1, 2 traverses all nodes - for example foo[1, 2] = 3 + for example a b(c d), "x" do end traverses all nodes - for example begin; meth; ensure; bar; end + for example begin; meth; rescue; foo; else; bar; end traverses all nodes - for example foo <=> 1 + for example ?a traverses all nodes - for example <<~E - 1 \ - 2 - 3 -E + for example foo.m += raise bar rescue nil traverses all nodes - for example a # -# -.foo + for example foo[1, 2] traverses all nodes - for example case foo; when 'bar', 'baz'; bar; end + for example case foo; in 1, "a", [], {} then nil; end traverses all nodes - for example %W[#@1] + for example %s{#@@1} traverses all nodes - for example yield + for example 1... traverses all nodes - for example ...100 + for example def BEGIN; end traverses all nodes - for example foo.a ||= 1 + for example def _5; end traverses all nodes - for example foo::(1) + for example foo.A = 1 traverses all nodes - for example a += b += raise :x + for example %W[#@@1] traverses all nodes - for example case foo; in * then nil; end + for example foo&.bar {} traverses all nodes - for example Bar::Foo + for example def foo + a:b end traverses all nodes - for example { foo: 2, **bar } + for example <(a: ->{_1}) {a} + for example %x{#@1} traverses all nodes - for example while class << self; a = tap do end; end; break; end + for example foo[m bar] traverses all nodes - for example case foo; in [x, y, *z] then true; end + for example lambda{|;a|a} traverses all nodes - for example foo || (a, b = bar) + for example case foo; in *x, y, z then nil; end traverses all nodes - for example "#{-> foo {}}" + for example foo.fun traverses all nodes - for example <<-'HERE' + for example <<-"HERE" a\ b HERE traverses all nodes - for example def foo() a:b end - traverses all nodes - for example f{ |*, &b| } - traverses all nodes - for example foo.(1) - traverses all nodes - for example :"#@1" - traverses all nodes - for example while class Foo a = tap do end; end; break; end + for example <<-'HERE' +#@@1 +HERE traverses all nodes - for example f{ |o=1, &b| } + for example foo, bar = m foo traverses all nodes - for example <<-E - 1 \ - 2 - 3 + for example p <<~E + x + y E traverses all nodes - for example foo::C ||= raise bar rescue nil - traverses all nodes - for example a b{c d}, 1 do end - traverses all nodes - for example m "#{[]}" + for example return foo traverses all nodes - for example < 1 + for example case foo; in [x, *y, z] then true; end traverses all nodes - for example meth do; foo; rescue; bar; end + for example foo = raise bar rescue nil traverses all nodes - for example alias :foo bar + for example f{ || } traverses all nodes - for example case foo; in ** then true; end + for example redo traverses all nodes - for example if foo then bar; end + for example foo::C ||= raise(bar) rescue nil traverses all nodes - for example class Foo < a:b; end + for example case foo; in ::A then true; end traverses all nodes - for example a &&= 1 + for example foo.a &&= 1 traverses all nodes - for example a b{c d}, /x/ do end + for example case foo; in x then x; end traverses all nodes - for example case foo; in [x,] then nil; end + for example class Foo < Bar; end traverses all nodes - for example a b{c(d)}, 1 do end + for example true ? 1.tap do |n| p n end : 0 traverses all nodes - for example `a\ -b` + for example f{ |a| } traverses all nodes - for example false + for example a += b += raise :x traverses all nodes - for example p :foo, {proc do end => proc do end, b: proc do end} + for example foo[1, 2] traverses all nodes - for example while foo do meth end + for example case foo; in { a: 1, } then true; end traverses all nodes - for example (foo, bar) = 1, 2 + for example foo += raise bar rescue nil traverses all nodes - for example %x{a\ -b} + for example *b, c = bar traverses all nodes - for example foo - 1 + for example foo::A = 1 traverses all nodes - for example if foo; bar; elsif baz; 1; else 2; end + for example %w[ #@1 ] traverses all nodes - for example a ? b & '': nil + for example case foo; in a: 1, b: 2 then true; end traverses all nodes - for example foo += raise bar rescue nil + for example if foo; bar; end traverses all nodes - for example proc {|_3|} + for example <<-`HERE` +a\ +b +HERE traverses all nodes - for example foo =~ 1 + for example alias $a $+ traverses all nodes - for example a b(c(d)), 1.0i do end + for example -> * { } traverses all nodes - for example case foo; in x, *y, z then nil; end + for example fun(1) traverses all nodes - for example foo = raise bar rescue nil + for example def f ((*r)); end traverses all nodes - for example 42ri + for example case foo; in ^foo then nil; end traverses all nodes - for example f{ } + for example case foo; in a: 1 then true; end traverses all nodes - for example foo ^ 1 + for example case foo; + in {a: + } + true + ; end traverses all nodes - for example def f &b; end + for example def f foo = 1; end traverses all nodes - for example %I[foo #{bar}] + for example f{ |o=1, *r, p, &b| } traverses all nodes - for example next(foo) + for example f{ |&b| } traverses all nodes - for example super do end + for example def a b: +return +end traverses all nodes - for example -foo + for example foo >= 1 traverses all nodes - for example case foo; in "#{ %Q{a} }": 1 then true; end + for example foo = bar = m foo traverses all nodes - for example /source/im + for example a # + # +&.foo traverses all nodes - for example p :foo, {a: proc do end, b: proc do end} + for example 42.1ri traverses all nodes - for example foo = bar = m foo + for example [*foo] traverses all nodes - for example begin meth end until foo + for example fun(:foo => 1) traverses all nodes - for example f{ |a, *, &b| } + for example def a; @@var |= 10; end traverses all nodes - for example case foo; in [x] then nil; end + for example [1, *foo, 2] traverses all nodes for example foo::fun bar traverses all nodes - for example -> a: { } + for example p begin 1.times do 1 end end traverses all nodes - for example %W"#{1}" + for example %I[#@@1] traverses all nodes - for example case foo; in 1, "a", [], {} then nil; end + for example case foo; in [x, y,] then true; end traverses all nodes - for example m [], 1 do end + for example foo::(1) traverses all nodes - for example case foo; in **nil then true; end + for example unless foo then bar; end traverses all nodes - for example <<-`HERE` -#@1 -HERE + for example foo::A += m foo traverses all nodes - for example f (g rescue nil) + for example :'a\ +b' traverses all nodes - for example foo = *bar + for example case foo; in A then true; end traverses all nodes - for example def f foo = 1; end + for example unless foo; bar; end traverses all nodes - for example fun () {} + for example Bar::Foo traverses all nodes - for example %q{#@@1} + for example /#@1/ traverses all nodes - for example if foo..bar; end + for example class A; _1; end traverses all nodes - for example foo + 1 + for example %i[ #@1 ] traverses all nodes - for example 42.1ri + for example f { || a:b } traverses all nodes - for example proc {_1 = nil} + for example @foo, @@bar = *foo traverses all nodes - for example <<-"HERE" -#@@1 -HERE + for example foo >> 1 traverses all nodes - for example defined?(foo) + for example case foo; in { a: 1 } then true; end traverses all nodes - for example -2.0 ** 10 + for example def f ((a, *)); end traverses all nodes - for example case foo; in 1 | 2 then true; end + for example fun { } traverses all nodes - for example begin; meth; rescue => @ex; bar; end + for example p <<~"E" + x\n y +E traverses all nodes - for example { 1 => 2 } + for example f{ |*s| } traverses all nodes - for example begin; meth; rescue; foo; else; bar; end + for example %i[] traverses all nodes - for example fun(:foo => 1) + for example case foo; + in {a: 1 + } + false + ; end traverses all nodes - for example a b(c d), 1.0r do end + for example a b(c(d)), /x/m do end traverses all nodes - for example unless foo; bar; else baz; end + for example def m; class << self; module M; end; end; end traverses all nodes - for example p <<~E - x - \ y -E + for example foo or bar traverses all nodes - for example case foo; in 1..2 then true; end + for example ..100 traverses all nodes - for example f{ |; -a -| } + for example let () { m(a) do; end } traverses all nodes - for example while class << self; tap do end; end; break; end + for example a b{c d}, 1.0i do end traverses all nodes - for example def foo - a:b end + for example a b(c d), 1.0i do end traverses all nodes - for example def f foo: -; end + for example foo && bar traverses all nodes - for example break() + for example meth until foo traverses all nodes - for example foo || bar + for example p <<~E + x + y +E traverses all nodes - for example case foo; when 1, *baz; bar; when *foo; end + for example f{ |foo: 1, bar: 2, **baz, &b| } traverses all nodes - for example %w{a\ -b} + for example foo ^ 1 traverses all nodes for example if (bar); foo; end traverses all nodes - for example a b{c(d)}, /x/ do end + for example case foo; in A() then true; end traverses all nodes - for example a&.b = 1 + for example a b{c(d)}, "x" do end traverses all nodes - for example %x{#@1} + for example if foo..bar; end traverses all nodes - for example Foo = 10 + for example alias :foo bar traverses all nodes - for example redo + for example -> a: { } traverses all nodes - for example case foo; in ...2 then true; end + for example def foo +=begin +=end +end traverses all nodes - for example [1, *foo] + for example !foo traverses all nodes - for example defined? @foo + for example def x; ::A ||= 1; end traverses all nodes - for example %{#@1} + for example f (g rescue nil) traverses all nodes - for example if (a, b = foo); end + for example Foo traverses all nodes - for example def a; @@var |= 10; end + for example m a + b do end traverses all nodes - for example !/wat/ + for example begin meth end until foo traverses all nodes - for example foo.A += m foo + for example f{ |o=1, &b| } traverses all nodes - for example __ENCODING__ + for example fun() { } traverses all nodes - for example f{ |a, o=1, o1=2, *r, &b| } + for example desc "foo" do end traverses all nodes - for example super() + for example %{#@1} traverses all nodes - for example def f(**nil); end + for example ->{ } traverses all nodes - for example case foo; when 'bar'; bar; end + for example a b(c(d)), 1.0 do end traverses all nodes - for example meth (-1.3).abs + for example return traverses all nodes - for example if foo; bar; end + for example p <<~E + x + +y +E traverses all nodes - for example begin foo!; bar! end + for example %w[ #@@1 ] traverses all nodes - for example a b{c d}, 1.0i do end + for example case foo; in self then true; end traverses all nodes - for example def f *, **; end + for example a, (b, c) = foo traverses all nodes - for example meth 1 do end::fun bar + for example while not (true) do end traverses all nodes - for example a&.b &&= 1 + for example def f(foo); end traverses all nodes - for example class << foo; nil; end + for example super traverses all nodes - for example def foo(...); bar(...); end + for example %Q{#@@1} traverses all nodes - for example [/()\1/, ?#] + for example foo & 1 traverses all nodes - for example alias $a $+ + for example /(?bar)/ =~ 'bar'; match traverses all nodes - for example "foo#{bar}baz" + for example return fun foo do end traverses all nodes - for example tap (proc do end) + for example p :foo, {"a": proc do end, b: proc do end} traverses all nodes - for example "#@a #@@a #$a" + for example foo.a += 1 traverses all nodes - for example <<-`HERE` -a\ -b -HERE + for example { foo: 2 } traverses all nodes - for example bar def foo; self.each do end end + for example `#@@1` traverses all nodes - for example f{ |*r, p, &b| } + for example a b{c d}, :e do end traverses all nodes - for example case; when foo; 'foo'; end + for example def foo raise; raise A::B, ''; end traverses all nodes - for example ?a + for example foo = meth rescue bar traverses all nodes - for example def f o=1, p, &b; end + for example meth 1 do end.fun bar traverses all nodes - for example while def foo; tap do end; end; break; end + for example @@var = 10 traverses all nodes - for example case foo; in A[x:] then true; end + for example @foo traverses all nodes - for example f <<-TABLE do -TABLE -end + for example %I[#@1] traverses all nodes - for example fun(1) + for example 'a\ +b' traverses all nodes - for example foo = raise(bar) rescue nil + for example unless foo; bar; else baz; end traverses all nodes - for example *b = bar + for example a ? b & '': nil traverses all nodes - for example yield(foo) + for example foo.m += raise(bar) rescue nil traverses all nodes - for example f{ |o=1, *r, p, &b| } + for example fun(*bar) traverses all nodes - for example foo.a = 1 + for example a += 1 traverses all nodes - for example a b{c d}, "x" do end + for example foo || (a, b = bar) traverses all nodes - for example %{a\ -b} + for example p <<~E + x +E traverses all nodes - for example foo[0, 1] &&= 2 + for example case foo; in 1... then true; end traverses all nodes - for example foo (-1.3).abs + for example def f **baz, &b; end traverses all nodes - for example fun(foo, :foo => 1, &baz) + for example def foo(...); end traverses all nodes - for example :"#@@1" + for example next fun foo do end traverses all nodes - for example ->(a) { } + for example %q{#@1} traverses all nodes - for example { foo: 2 } + for example not foo traverses all nodes - for example def f (((a))); end + for example foo.a ||= 1 traverses all nodes - for example case foo; in (1) then true; end + for example a = b = raise :x traverses all nodes - for example module Bar::Foo; end + for example while def foo; tap do end; end; break; end traverses all nodes - for example while not (true) do end + for example /source/im traverses all nodes - for example foo or bar + for example case foo; in "a": then true; end traverses all nodes - for example foo.C += raise(bar) rescue nil + for example f{ |*, &b| } traverses all nodes - for example begin; rescue LoadError; else; end + for example ->(scope) {}; scope traverses all nodes - for example @@var = 10 + for example nil traverses all nodes - for example t=1;(foo)?t:T + for example m [] do end traverses all nodes - for example def f(foo:); end + for example p :foo, {a: proc do end, b: proc do end} traverses all nodes - for example def String=; end + for example f{ |a, &b| } traverses all nodes - for example fun(:foo => 1, &baz) + for example p <<~E + x + y +E traverses all nodes - for example if /wat/; end + for example fun(*bar, &baz) traverses all nodes - for example a b(c(d)), /x/ do end + for example meth 1 do end::fun(bar) traverses all nodes - for example break + for example def f(**foo); end traverses all nodes - for example case foo; in [x, y] then true; end + for example a b{c d}, /x/ do end traverses all nodes - for example def f o=1, &b; end + for example self traverses all nodes - for example f{ |o=1, p, &b| } + for example foo - 1 traverses all nodes - for example class Foo end + for example foo.C += raise(bar) rescue nil traverses all nodes - for example *, c, d = bar + 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 a b{c d}, 1.0r do end + for example meth 1 do end.fun {} traverses all nodes - for example _1 + for example case foo; in {} then true; end traverses all nodes - for example -> do _1 + _9 end + for example %W"#{1}" traverses all nodes - for example for a in foo do p a; end + for example %w[foo bar] traverses all nodes - for example assert dogs + for example m ->(a = ->{_1}) {a} traverses all nodes - for example a b{c(d)}, :e do end + for example def foo(...); super(...); end traverses all nodes - for example :'foo' + for example m1 :k => m2 do; m3() do end; end traverses all nodes - for example %Q{#@1} + for example next(foo) traverses all nodes - for example def f ((a, a1)); end + for example fun(&bar) traverses all nodes - for example +42 + for example m = -> *args do end traverses all nodes - for example -> { _1 + _9} + for example meth[] {} traverses all nodes - for example a b{c(d)}, /x/m do end + for example 42i traverses all nodes - for example `foo#{bar}baz` + for example foo[bar, :baz => 1,] traverses all nodes - for example <<-"HERE" -#@1 -HERE + for example !m foo traverses all nodes - for example case foo; in 1...2 then true; end + for example a ||= 1 traverses all nodes - for example class Foo; end + for example a b(c d), :e do end traverses all nodes - for example foo[m bar] + for example module Foo; end traverses all nodes - for example def foo(_, _); end + for example %r{a\ +b} traverses all nodes - for example foo && bar + for example ::Foo = 10 traverses all nodes - for example break foo + for example while def self.foo; tap do end; end; break; end traverses all nodes - for example def f ; end + for example _2 = 1 traverses all nodes - for example until foo; meth end + for example td (1_500).toString(); td.num do; end traverses all nodes - for example %r{#@1} + for example %x{a\ +b} traverses all nodes - for example for a, b in foo; p a, b; end + for example case foo; in [x, y] then true; end traverses all nodes - for example 42.1r + for example def f ; end traverses all nodes - for example 1..2 + for example foo += meth rescue bar traverses all nodes - for example fun (1) + for example foo and bar traverses all nodes - for example defined? foo + for example until foo do meth end traverses all nodes - for example break fun foo do end + for example $foo traverses all nodes - for example __ENCODING__ + for example { foo: 2, **bar } traverses all nodes - for example module ::Foo; end + for example class Foo; end traverses all nodes - for example a # - # -&.foo + for example fun (1 +) traverses all nodes - for example foo ** 1 + for example BEGIN { 1 } traverses all nodes - for example %i{a\ -b} + for example %w[] traverses all nodes - for example if foo then bar; else baz; end + for example a b{c(d)}, 1.0r do end traverses all nodes - for example let () { m(a) do; end } + for example foo[0, 1] += 2 traverses all nodes - for example m do _1 + _9 end + for example foo && (a, b = bar) traverses all nodes - for example f{ |*s| } + for example def x; self::A ||= 1; end traverses all nodes for example p <<~"E" x #{" y"} E traverses all nodes - for example case foo; in self then true; end - traverses all nodes - for example @foo - traverses all nodes - for example case foo; in a:, b: then true; end - traverses all nodes - for example def until; end - traverses all nodes - for example def x; self::A ||= 1; end - traverses all nodes - for example foo[1, 2] + for example foo[bar,] traverses all nodes - for example %r{a\ -b} + for example f{ |a, *| } traverses all nodes - for example meth[] {} + for example -> do _1 + _9 end traverses all nodes - for example __FILE__ + for example fun (1) {} traverses all nodes - for example def f ((a, *r)); end + for example a b{c(d)}, /x/m do end traverses all nodes - for example def f(foo, bar); end + when a class defines `on_block_pass` + calls it for all block-pass arguments + for example foo[0, 1] ||= 2 traverses all nodes - for example :foo + for example /\xa8/n =~ "" traverses all nodes - for example def f a, o=1, p, &b; end + for example +42 traverses all nodes - for example def BEGIN; end + for example %W() traverses all nodes - for example foo.A = 1 + for example bar unless foo traverses all nodes - for example a, *, c = bar + for example a b(c d), 1.0 do end traverses all nodes - for example f{ |a, *s, &b| } + for example foo || bar traverses all nodes - for example 42 + for example proc {_1 = nil} traverses all nodes - for example meth 1 do end.fun(bar) {} + for example var = 10; var traverses all nodes - for example foo::A += m foo + for example f{ |foo: 1, &b| } traverses all nodes - for example foo += meth rescue bar + for example f{ |o=1, p, &b| } traverses all nodes - for example let (:a) { m do; end } + for example foo != 1 traverses all nodes - for example m = -> *args do end + for example def f ((*, p)); end traverses all nodes - for example def END; end + for example foo (-1.3).abs traverses all nodes - for example %I[#@@1] + for example 42 traverses all nodes - for example -> (arg={}) {} + for example def foo; end traverses all nodes - for example case foo; - in {Foo: 42 - } - false - ; end + for example def until; end traverses all nodes - for example foo = bar, 1 + for example def String; end traverses all nodes - for example foo = m foo + for example def f foo: -1 +; end traverses all nodes - for example foo, bar, baz = 1, 2 + for example fun traverses all nodes - for example a b(c(d)), /x/m do end + for example f x: -> do meth do end end traverses all nodes - for example meth while foo + for example super(foo) traverses all nodes - for example foo[:baz => 1,] + for example foo traverses all nodes - for example foo !~ 1 + for example case foo; in A[x:] then true; end traverses all nodes - for example meth 1 do end.fun {} + for example @@foo traverses all nodes - for example foo::A = 1 + for example def f *r, &b; end traverses all nodes - for example case foo; in [x, *, y] then true; end + for example for a, b in foo; p a, b; end traverses all nodes - for example "#{1}" + for example case foo; in "#{ 'a' }": then true; end traverses all nodes - for example foo[1, 2] + for example case foo; in [x, y, *z] then true; end traverses all nodes - for example meth 1 do end::fun(bar) + for example p <<~E + x + y +E traverses all nodes - for example while foo; meth end + for example break(foo) traverses all nodes - for example super(foo) + for example f{ |*s, &b| } traverses all nodes - for example a&.b + for example next foo traverses all nodes - for example foo[0] += raise(bar) rescue nil + for example def f ((*r, p)); end traverses all nodes - for example %i[foo bar] + for example class Foo end traverses all nodes - for example assert do: true + for example a b(c d), 1.0r do end traverses all nodes - for example <<-"HERE" -a\ -b -HERE + for example meth 1 do end.fun(bar) traverses all nodes - for example f{ |*s, &b| } + for example if foo then bar; else baz; end traverses all nodes - for example 1...2 + for example def f o=1, *r, p, &b; end traverses all nodes - for example <<~FOO - baz\ - qux -FOO + for example foo = m foo traverses all nodes - for example def foo(_a, _a); end + for example !(foo..bar) traverses all nodes - for example meth until foo + for example f{ |foo:| } traverses all nodes - for example a b(c d), /x/ do end + for example p :foo, {proc do end => proc do end, b: proc do end} traverses all nodes - for example -> a: 1 { } + for example f{ |*| } traverses all nodes - for example f{ |a, &b| } + for example ::A, foo = foo traverses all nodes - for example !(foo..bar) + for example begin foo!; bar! end traverses all nodes - for example true ? 1.tap do |n| p n end : 0 + for example %s{a\ +b} traverses all nodes - for example `#@@1` + for example self::a, foo = foo traverses all nodes - for example meth 1 do end.fun bar do end + for example foo::fun traverses all nodes - for example return fun foo do end + for example ((b, )) = foo traverses all nodes - for example "#@1" + for example foo::m += raise bar rescue nil traverses all nodes - for example case foo; in x, y, then nil; end + for example A += 1 traverses all nodes - for example 1... + for example def f *r, p, &b; end traverses all nodes - for example foo.fun + for example [ 1 => 2 ] traverses all nodes - for example foo::a += 1 + for example -foo traverses all nodes - for example case; when foo; 'foo'; else 'bar'; end + for example p ->() do a() do end end traverses all nodes - for example foo[0, 1] ||= 2 + for example p <<~E + x + y +E traverses all nodes - for example def f *r, p, &b; end + for example meth do; foo; rescue; bar; end traverses all nodes for example p <<~E " y" x E traverses all nodes - for example begin; meth; rescue; foo; end + for example <<~FOO + baz\ + qux +FOO traverses all nodes - for example foo::fun (1) {} + for example @a |= 1 traverses all nodes - for example !(a, b = foo) + for example case foo; in A::B then true; end traverses all nodes - for example -> * { } + for example 1..2 traverses all nodes - for example [*foo] + for example ->(**nil) {} traverses all nodes - for example %q{#@1} + for example if foo; bar; else baz; end traverses all nodes - for example case foo; in ..2 then true; end + for example { 'foo': 2, 'bar': {}} traverses all nodes - for example case foo; in "#{ %q{a} }": then true; end + for example yield foo traverses all nodes - for example 42i + for example 42.1r traverses all nodes - for example case foo; - in a: {b:}, c: - p c - ; end + for example case foo; in [x, y, *] then true; end traverses all nodes - for example f{ |a, *s| } + for example self.a, self[1, 2] = foo traverses all nodes - for example -42 + for example def foo(_a, _a); end traverses all nodes - for example def f ((a, *r, p)); end + for example a b{c(d)}, :e do end traverses all nodes - for example -> do end + for example def f o=1, p, &b; end traverses all nodes for example case foo; - in {a: - 2} + in {Foo: 42 + } false ; end traverses all nodes - for example f(a ? "a":1) + for example <<-"HERE" +#@@1 +HERE traverses all nodes - for example m a + b do end + for example case foo; in 1 => a then true; end traverses all nodes - for example foo.fun (1) {} + for example case foo; in 1 | 2 then true; end traverses all nodes - for example def f a, o=1, &b; end + for example foo::C ||= raise bar rescue nil traverses all nodes - for example /(?bar)/ =~ 'bar'; match + for example class << foo; _1; end traverses all nodes - for example foo[bar, :baz => 1,] + for example %{#@@1} traverses all nodes - for example not(foo) + for example a = b += raise :x traverses all nodes - for example foo < 1 + for example a b{c(d)}, 1 do end traverses all nodes - for example def f ((*, p)); end + for example not() traverses all nodes - for example /#)/x + for example B::A += 1 traverses all nodes - for example foo.m += raise(bar) rescue nil + for example __ENCODING__ traverses all nodes - for example retry + for example unless foo then bar; else baz; end traverses all nodes - for example def foo(...); super(...); end + for example foo ** 1 traverses all nodes - for example +2.0 ** 10 + for example 42.1i traverses all nodes - for example case foo; in x if true; nil; end + for example module ::Foo; end traverses all nodes - for example case foo; in x unless true; nil; end + for example {a: if true then 42 end} traverses all nodes - for example "foo#@a" "bar" + for example foo = bar, 1 traverses all nodes - for example false ? raise {} : tap {} + for example if foo...bar; end traverses all nodes - for example def f(foo: 1); end + for example def self.m; _1; end traverses all nodes - for example foo::fun + for example [ 1, 2 => 3 ] traverses all nodes - for example def f (foo: 1, bar: 2, **baz, &b); end + for example begin; meth; ensure; bar; end traverses all nodes - for example %Q{a\ -b} + for example case foo; in x if true; nil; end traverses all nodes - for example def foo(...); bar(...); end + for example def f ((a, *r, p)); end traverses all nodes - for example f x: -> do meth do end end + for example foo.(1) traverses all nodes - for example f{ |**baz, &b| } + for example super foo traverses all nodes - for example a, (b, c) = foo + for example $var = 10 traverses all nodes - for example foo <= 1 + for example 'foobar' traverses all nodes - for example 42.1i + for example __ENCODING__ traverses all nodes - for example %w[foo bar] + for example { 'foo': 2 } traverses all nodes - for example f{ |a,| } + for example true traverses all nodes - for example self::A, foo = foo + for example o = { +a: +1 +} traverses all nodes - for example a b(c d), 1.0 do end + for example if (bar; a, b = foo); end traverses all nodes - for example while class Foo; tap do end; end; break; end + for example case foo; in A[] then true; end traverses all nodes - for example if foo; bar; else baz; end + for example case foo; in ...2 then true; end traverses all nodes - for example p -> { :hello }, a: 1 do end + for example false traverses all nodes - for example $var = 10 + for example case foo; in A(1, 2) then true; end traverses all nodes - for example undef foo, :bar, :"foo#{1}" + for example case [__FILE__, __LINE__ + 1, __ENCODING__] + in [__FILE__, __LINE__, __ENCODING__] + end traverses all nodes - for example def f(**); end + for example foo += m foo traverses all nodes - for example %s{#@@1} + for example foo += raise(bar) rescue nil traverses all nodes - for example case foo; in a: then true; end + for example foo !~ 1 traverses all nodes - for example yield() + for example ::A += 1 traverses all nodes - for example %Q{#@@1} + for example '#@@1' traverses all nodes - for example a b{c d}, 1.0 do end + for example def f(foo=1, bar=2); end traverses all nodes - for example begin; meth; rescue foo => ex; bar; end + for example p <<~`E` + x + #{foo} +E traverses all nodes - for example fun(1) { } + for example begin; meth; rescue Exception, foo; bar; end traverses all nodes - for example ->(a; foo, bar) { } + for example case; when foo; 'foo'; else 'bar'; end traverses all nodes - for example %I[#@1] + for example next() traverses all nodes - for example p begin 1.times do 1 end end + for example case foo; in "#{ 'a' }": 1 then true; end traverses all nodes - for example :'#@@1' + for example super foo, bar do end traverses all nodes - for example case foo; - in {a: 1 - } - false - ; end + for example def String::foo; end traverses all nodes - for example lambda{|;a|a} + for example case foo; when 'bar'; bar; end traverses all nodes - for example f{ |a, o=1, &b| } + for example foo =~ 1 traverses all nodes - for example f { || a:b } + for example def m; class << self; A = nil; end; end traverses all nodes - for example begin meth end while foo + for example foo / 1 traverses all nodes - for example def f *r, &b; end + for example (foo, bar) = 1, 2 traverses all nodes - for example -2 ** 10 + for example def foo(...); bar(...); end traverses all nodes - for example case 1; in 2; 3; else; end + for example -> do end traverses all nodes - for example next() + for example %I[foo #{bar}] traverses all nodes - for example foo.fun bar + when a class defines on_arg + calls it for all arguments + for example foo, bar, baz = 1, 2 traverses all nodes - for example case foo; in A[] then true; end + for example :"foo#{bar}baz" traverses all nodes - for example def f(*foo); end + for example def f(*); end traverses all nodes - for example def f ((*)); end + for example 1...2 traverses all nodes - for example fun(&bar) + for example { } traverses all nodes - for example m "#{}#{()}" + for example retry traverses all nodes - for example def f(foo=1, bar=2); end + for example self::A, foo = foo traverses all nodes - for example def self::foo; end + for example () traverses all nodes - for example a ||= 1 + for example * = bar traverses all nodes - for example m { |foo| } + for example :foo traverses all nodes - for example Foo + for example fun! traverses all nodes - for example case foo; in x, y then nil; end + for example if (a, b = foo); end traverses all nodes - for example meth 1 do end.fun(bar) + for example %Q{a\ +b} + traverses all nodes + for example f{ |a, *s| } traverses all nodes for example p <<~E - x - - y + x + \ y E traverses all nodes - for example def x(_4) end + for example p <<~E +E traverses all nodes - for example while def self.foo; tap do end; end; break; end + for example *b = bar traverses all nodes - for example m { |**nil| } + for example %w{a\ +b} traverses all nodes - when given an unexpected AST - with too few children - raises debugging error - with too many children - raises debugging error - for example def f ((*r, p)); end + for example begin; meth; rescue; baz; ensure; bar; end traverses all nodes - for example a = b += raise :x + for example case 1; in 2; 3; else; end traverses all nodes - for example def m; class << self; class C; end; end; end + for example "foo#{bar}baz" traverses all nodes - for example foo, bar = 1, 2 + for example while class << self; a = tap do end; end; break; end traverses all nodes - for example fun(foo, :foo => 1) + for example begin; meth; rescue foo => ex; bar; end traverses all nodes - for example td (1_500).toString(); td.num do; end + for example foo === 1 traverses all nodes - for example case foo; in 1.. then true; end + for example foo.a = 1 traverses all nodes - for example foo, bar = m foo + for example foo[0] += raise bar rescue nil traverses all nodes - for example case foo; in A then true; end + for example a b(c(d)), 1 do end traverses all nodes - for example %W[foo #{bar}foo#@baz] + for example case foo; in [*x, y] then true; end traverses all nodes - for example true + for example _1 traverses all nodes - for example next fun foo do end + for example a b{c(d)}, 1.0 do end traverses all nodes - for example %W[foo #{bar}] + for example def f a, o=1, *r, &b; end traverses all nodes - for example def _5; end + for example %i{a\ +b} traverses all nodes - for example case foo; in *x then nil; end + for example case foo; + in a: {b:}, c: + p c + ; end traverses all nodes - for example f{ |a, c| } + for example def foo() a:b end traverses all nodes - for example return(foo) + for example begin; meth; rescue => @ex; bar; end traverses all nodes - for example p <<~"E" - x\n y -E + for example yield(foo) traverses all nodes - for example case foo; in x then x; end + for example a&.b = 1 traverses all nodes - for example def (foo).foo; end + for example [/()\1/, ?#] traverses all nodes - for example f{ | | } + for example f{ |;a| } traverses all nodes - for example case foo; in a: 1 then true; end + for example [1, 2] traverses all nodes - for example foo.m += raise bar rescue nil + for example %W[foo #{bar}] traverses all nodes - for example not foo + for example while class Foo a = tap do end; end; break; end traverses all nodes - for example m def x(); end; 1.tap do end + for example p <<~E + x + + y +E traverses all nodes - for example class Foo < Bar; end + for example f{ } traverses all nodes - for example ::Foo + for example '#@1' traverses all nodes - for example 'a\ -b' + for example foo.a += m foo traverses all nodes - for example fun (f bar) + for example fun(:foo => 1, &baz) traverses all nodes - for example return() + for example foo <= 1 traverses all nodes - for example m [] do end + for example def f a, o=1, p, &b; end traverses all nodes - for example a b(c(d)), 1 do end + for example f{ |a, b,| } traverses all nodes - for example def f (foo: 1, &b); end + for example foo + 1 traverses all nodes - for example a b{c d}, :e do end + for example def f (foo: 1, bar: 2, **baz, &b); end traverses all nodes - for example return foo + for example foo.fun (1) {} traverses all nodes - for example module Foo; end + for example case foo; when 'bar' then bar; end traverses all nodes - for example $+ + for example %Q{#@1} traverses all nodes - for example def self.foo; end + for example foo = raise(bar) rescue nil traverses all nodes - for example a b(c(d)), 1.0r do end + for example break traverses all nodes - for example class << foo; _1; end + for example a b{c d}, "x" do end traverses all nodes - for example case foo; in a: 1, _a:, ** then true; end + for example meth (-1.3).abs traverses all nodes - for example 42r + for example ...100 traverses all nodes - for example 1 in [a]; a + for example def String=; end traverses all nodes - for example /\xa8/n =~ "" + for example def END; end traverses all nodes - for example { } + for example "#@1" traverses all nodes - for example %i[ #@1 ] + for example foo::Fun bar traverses all nodes - for example f{ |&b| } + for example fun(1) { } traverses all nodes - for example case foo; in "#{ %q{a} }": 1 then true; end + for example assert dogs traverses all nodes - for example {a: if true then 42 end} + for example def f a, o=1, &b; end traverses all nodes - for example begin; meth; rescue; baz; else foo; ensure; bar end + for example fun(foo, :foo => 1, &baz) traverses all nodes - for example ::A += 1 + for example p p{p(p);p p}, tap do end traverses all nodes - for example not m foo + for example case foo; in A(x:) then true; end traverses all nodes - for example bar if foo + for example ->{ } traverses all nodes - for example p :foo, {** proc do end, b: proc do end} + for example a b{c(d)}, /x/ do end traverses all nodes - for example -> (a) { } + for example fun (1) traverses all nodes - for example foo::m += raise bar rescue nil + for example -> do rescue; end traverses all nodes - for example %W{a\ -b} + for example next traverses all nodes - for example p <<~"E" - x - #{foo} -E + for example foo > 1 traverses all nodes - for example case foo; when 'bar' then bar; end + for example defined? foo traverses all nodes - for example foo, bar = meth rescue [1, 2] + for example { 1 => 2 } traverses all nodes - for example def foo raise; raise A::B, ''; end + for example m do _1 + _9 end traverses all nodes - for example foo == 1 + for example meth while foo traverses all nodes - for example 'foobar' + for example ~foo traverses all nodes - for example f{ |o=1, *r, &b| } + for example m [], 1 do end traverses all nodes - for example var = 10; var + for example ->(a; foo, bar) { } traverses all nodes - for example case foo; in ::A then true; end + for example Bar::Foo = 10 traverses all nodes - for example foo::C ||= raise(bar) rescue nil + for example ::Foo traverses all nodes - for example p <<~`E` - x - #{foo} -E + for example "#@a #@@a #$a" traverses all nodes - for example :"foo#{bar}baz" + for example :'#@1' traverses all nodes - for example case foo; - in {a: - } - true - ; end + for example :"a\ +b" traverses all nodes - for example def String.foo; end + for example yield() traverses all nodes - for example <<-'HERE' + for example $10 + traverses all nodes + for example <<-"HERE" #@1 HERE traverses all nodes - for example foo - traverses all nodes - for example a, * = bar - traverses all nodes - for example fun (1 -) + for example `#@1` traverses all nodes - for example case foo; in A(1, 2) then true; end + for example fun do end traverses all nodes - for example foo::m += raise(bar) rescue nil + for example %{a\ +b} traverses all nodes - for example '#@@1' + for example "#{1}" traverses all nodes - for example ->(**nil) {} + for example :'#@@1' traverses all nodes - for example super foo, bar do end + for example meth 1 do end.fun(bar) {} traverses all nodes - for example ..100 + for example f{ |; +a +| } traverses all nodes - for example f{ |a, *r, p, &b| } + for example case foo; when 'bar'; bar; else baz; end traverses all nodes - for example def f ((*r)); end + for example %i[foo bar] traverses all nodes - for example p <<~E - x - y -E + for example if /wat/; end traverses all nodes - for example def f **baz, &b; end + for example -> { _1 + _9} traverses all nodes - for example a b(c(d)), "x" do end + for example until foo; meth end traverses all nodes - for example while def foo a = tap do end; end; break; end + for example def f a, &b; end traverses all nodes - for example %w[] + for example :'foo' traverses all nodes - for example f{ |foo:| } + for example Foo = 10 traverses all nodes - for example fun + for example meth rescue bar traverses all nodes - for example case foo; in [x, *y, z] then true; end + for example foo::Fun() traverses all nodes - for example a @b do |c|;end + for example case foo; in x unless true; nil; end traverses all nodes - for example def m; class << self; A = nil; end; end + for example fun () {} traverses all nodes - for example case foo; in a: 1, b: 2 then true; end + for example while class << self; tap do end; end; break; end traverses all nodes - for example foo === 1 + for example case foo; in 1; end traverses all nodes - for example f{ |a, b,| } + for example fun (f bar) traverses all nodes - for example %I{a\ -b} + for example foo, bar = meth rescue [1, 2] traverses all nodes - for example a b(c(d)), :e do end + for example # coding:utf-8 + "\xD0\xBF\xD1\x80\xD0\xBE\xD0\xB2\xD0\xB5\xD1\x80\xD0\xBA\xD0\xB0" traverses all nodes - for example until foo do meth end + for example a, * = bar traverses all nodes - for example foo[0] += raise bar rescue nil + for example <<`HERE` +foo +bar +HERE traverses all nodes - for example case foo; in ^foo then nil; end + for example self.A, foo = foo traverses all nodes - for example def f(*); end + for example a, *, c = bar traverses all nodes - for example $foo + for example def f a, *r, p, &b; end traverses all nodes - for example if foo...bar; end + for example def (foo).foo; end traverses all nodes - for example foo >= 1 + for example if foo; bar; elsif baz; 1; else 2; end traverses all nodes - for example `foobar` + for example foo[1, 2] = 3 traverses all nodes - for example # Extracted from `parser` gem. -# Add the following code at the beginning of `def assert_parses`: + for example a # # -# File.open('./out.rb', 'a+') do |f| -# f << code << "\n\n#----\n" if versions.include? '2.7' -# end - -alias $a $b +.foo traverses all nodes - for example p :foo, {:a => proc do end, b: proc do end} + for example f{ | | } traverses all nodes - for example a += b = raise :x + for example f(a ? "a":1) traverses all nodes - for example %i[ #@@1 ] + for example while class Foo; tap do end; end; break; end traverses all nodes - for example self + for example f <<-TABLE do +TABLE +end traverses all nodes - for example foo[1, 2] = 3 + for example assert do: true traverses all nodes - for example p <<~E - x - y -E + for example let (:a) { m do; end } traverses all nodes - for example ->{ } + for example __FILE__ traverses all nodes - for example m { |(foo, bar)| } + for example %I{a\ +b} traverses all nodes - for example p <<~E - x - -y -E + for example p :foo, {:a => proc do end, b: proc do end} traverses all nodes - for example foo << 1 + for example -> (arg={}) {} traverses all nodes - for example p <<~E - E + for example a b(c d), 1 do end traverses all nodes - for example p <<~E - x - y -E + for example %W[foo #{bar}foo#@baz] traverses all nodes - for example unless foo then bar; else baz; end + for example while foo do meth end traverses all nodes - for example foo.A += 1 + for example /a\ +b/ traverses all nodes - for example ~foo + for example f{ |a, o=1, o1=2, *r, &b| } traverses all nodes - for example case 1; in 2; 3; else; 4; end + for example f{ |o=1, *r, &b| } traverses all nodes - for example a = 1; a b: 1 + for example tap (proc do end) traverses all nodes - for example foo = baz, *bar + for example case foo; in (1) then true; end traverses all nodes - for example def foo; 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 { 1 => 2, :foo => "bar" } + for example /#)/x traverses all nodes - for example foo * 1 + for example def f a, o=1, *r, p, &b; end traverses all nodes - for example fun (1).to_i + for example p -> { :hello }, a: 1 do end + traverses all nodes + for example %W{a\ +b} traverses all nodes for example foo ? 1 : 2 traverses all nodes - for example p :foo, {"a": proc do end, b: proc do end} + for example yield traverses all nodes - for example def foo(...); end + for example def f (foo: 1, &b); end traverses all nodes - for example false ? raise do end : tap do end + for example case foo; in 1...2 then true; end traverses all nodes - for example foo = meth rescue bar + for example foo[0, 1] &&= 2 traverses all nodes - for example # coding:utf-8 - "\xD0\xBF\xD1\x80\xD0\xBE\xD0\xB2\xD0\xB5\xD1\x80\xD0\xBA\xD0\xB0" + for example def f ((a, *r)); end traverses all nodes - for example foo and bar + for example case foo; in A[1, 2] then true; end traverses all nodes - for example f{ || } + for example a&.b traverses all nodes - for example break(foo) + for example foo::m += raise(bar) rescue nil traverses all nodes - for example { 'foo': 2, 'bar': {}} + for example proc {_1 = nil} traverses all nodes - for example /a\ -b/ + for example case foo; in "#{ %q{a} }": 1 then true; end traverses all nodes - for example foo[0, 1] += m foo + for example class << foo; nil; end traverses all nodes - for example !(foo...bar) + for example case 1; in 2; 3; else; 4; end traverses all nodes - for example f{ |foo: 1, &b| } + for example case foo; when 1, *baz; bar; when *foo; end traverses all nodes - for example A += 1 + for example begin; meth; rescue Exception; bar; end traverses all nodes - for example case foo; in *x, y, z then nil; end + for example case foo; + in {a: + 2} + false + ; end traverses all nodes - for example not() + for example foo % 1 traverses all nodes - for example def f a, *r, p, &b; end + for example foo[:baz => 1,] traverses all nodes - for example class A; _1; end + for example not m foo traverses all nodes - for example !foo + for example :"#@1" traverses all nodes - for example next foo + for example $+ traverses all nodes - for example `#@1` + for example a b{c d}, 1 do end traverses all nodes - for example module A; _1; end + for example case foo; in "#{ %q{a} }": then true; end traverses all nodes - for example @var = 10 + for example { 1 => 2, :foo => "bar" } traverses all nodes - for example _2 = 1 + for example def f (((a))); end traverses all nodes - for example B::A += 1 + for example foo[1, 2] = 3 + traverses all nodes + for example `a\ +b` + traverses all nodes + for example while def foo a = tap do end; end; break; end + traverses all nodes + for example __LINE__ + traverses all nodes + for example "#@@1" + traverses all nodes + for example a # + # +.foo + traverses all nodes + for example def x(_4) end traverses all nodes - -RuboCop::AST::AndAsgnNode - .new - is expected to be a kind of RuboCop::AST::AndAsgnNode - #operator - is expected to eq :"&&" - #assignment_node - is expected to be a kind of RuboCop::AST::AsgnNode - #name - is expected to eq :var - #expression - is expected to eq s(:send, nil, :value) RuboCop::AST::SuperNode - #arguments? - with multiple literal arguments - is expected to be arguments - with a single literal argument - is expected to be arguments - with multiple mixed arguments - is expected to be arguments - with no arguments - is expected not to be arguments - with a single splat argument - is expected to be arguments - #method? - when message does not match - when argument is a string - is expected not to be method "foo" - when argument is a symbol - is expected not to be method :foo - when message matches - when argument is a string - is expected to be method "super" - when argument is a symbol - is expected to be method :super - #bang_method? - is expected not to be bang method - #parenthesized? + #block_argument? + with a block argument + is expected to be block argument 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 + 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 #predicate_method? is expected not to be predicate method - #comparison_method? - is expected not to be comparison method - #dot? - is expected not to be dot - #method_name - is expected to eq :super - .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 - #operator_method? - is expected not to be operator method - #receiver - is expected to be nil + #implicit_call? + is expected not to be implicit call #arguments - with a single splat argument - is expected to eq 1 + with no arguments + is expected to be empty with a single literal 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 multiple mixed arguments is expected to eq 2 + with multiple literal arguments + is expected to eq 2 + .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 + #method_name + is expected to eq :super + #macro? + is expected not to be macro + #splat_argument? + with a splat argument + is expected to be splat argument with no arguments - is expected to be empty + is expected not to be splat argument + with regular arguments + is expected not to be splat argument + with mixed arguments + is expected to be splat argument #command? - when argument is a symbol - is expected to be command :super when argument is a string is expected to be command "super" + when argument is a symbol + is expected to be command :super + #bang_method? + is expected not to be bang method + #operator_method? + is expected not to be operator method #last_argument - with a single literal argument - is expected to be sym type - with a single splat argument - is expected to be splat type with no arguments is expected to be nil with multiple literal arguments is expected to be sym type with multiple mixed arguments is expected to be splat type - #macro? - is expected not to be macro - #const_receiver? - is expected not to be const receiver - #first_argument + with a single literal argument + is expected to be sym type with a single splat argument is expected to be splat type + #parenthesized? + with arguments + when not using parentheses + is expected not to be parenthesized + when using parentheses + is expected to be parenthesized with no arguments - is expected to be nil - with a single literal argument - is expected to be sym type - with multiple literal arguments - is expected to be sym type + when using parentheses + is expected to be parenthesized + when not using parentheses + is expected not to be parenthesized + #dot? + is expected not to be dot + #arguments? with multiple mixed arguments - is expected to be sym type - #assignment_method? - is expected not to be assignment method - #implicit_call? - is expected not to be implicit call - #block_literal? - with a block literal - is expected to be block literal - with a block argument - is expected not to be block literal - with no block - is expected not to be block literal + is expected to be arguments + with multiple literal arguments + is expected to be arguments + with a single splat argument + is expected to be arguments + with no arguments + is expected not to be arguments + with a single literal argument + is expected to be arguments + #double_colon? + is expected not to be double colon #self_receiver? is expected not to be self receiver - #setter_method? - is expected not to be setter method #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 - #double_colon? - is expected not to be double colon - #block_argument? + with no block + is expected to be nil with a block argument - is expected to be block argument - with regular arguments - is expected not to be block argument - with no arguments - is expected not to be block argument - with mixed arguments - is expected to be block argument - #splat_argument? - with mixed arguments - is expected to be splat argument - with regular arguments - is expected not to be splat argument - with a splat argument - is expected to be splat argument - with no arguments - is expected not to be splat argument - #camel_case_method? - is expected not to be camel case method - -RuboCop::AST::SendNode - #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 - with a prefixed def modifier - is expected to be def modifier - #attribute_accessor? - with an accessor - returns the accessor method and Array] - with a call without arguments - is expected to be nil - #double_colon? - with a unary method - is expected not to be double colon - with a dot - is expected not to be double colon - without a dot - is expected not to be double colon - with a double colon - is expected to be double colon + is expected to be nil #first_argument with no arguments is expected to be nil with a single literal argument is expected to be sym type - with multiple mixed arguments - is expected to be sym type - with multiple literal arguments - is expected to be sym type - with a single splat argument - is expected to be splat type - #post_condition_loop? - is expected not to be post condition loop - #lambda_literal? - with `a.() {}` style method - is expected not to be lambda - with a stabby lambda - is expected to be lambda literal - with a lambda method - is expected not to be lambda literal - with a non-lambda method - is expected not to be lambda - #non_bare_access_modifier? - when node is a non-bare `module_function` - is expected to be non bare access modifier - when node does not have an argument - is expected not to be non bare access modifier - when node is not an access modifier - is expected not to be non bare access modifier - .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 - #last_argument with multiple literal arguments is expected to be sym type - with no arguments - is expected to be nil with a single splat argument is expected to be splat type - with a single literal argument - is expected to be sym type - with multiple mixed arguments - is expected to be splat type - #arguments? with multiple mixed arguments - is expected to be arguments - with multiple literal arguments - is expected to be arguments - with a single splat argument - is expected to be arguments - with a single literal argument - is expected to be arguments - with no arguments - is expected not to be arguments - #command? - 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" - 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 - #macro? - with a receiver - when parent is a module - is expected not to be macro - when parent is a class - is expected not to be macro - without a receiver - with Ruby >= 2.7 - when parent is a numblock in a macro scope - is expected to be macro - when parent is a method definition - is expected not to be macro - when parent is a begin without a parent - 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 parent is a singleton class - is expected to be macro - when parent is a block not in a macro scope - is expected not to be macro - when in an if - is expected to be macro - when parent is a class - is expected to be macro - when parent is a keyword begin inside of an class - is expected to be macro - without a parent - is expected to be macro - when parent is a class constructor - is expected 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 - #def_modifier - with a block containing a method definition - is expected to be nil - with a prefixed def modifier - is expected to eq :bar - with several prefixed def modifiers - is expected to eq :qux - with call with no argument - is expected to be nil - #arithmetic_operation? - with a unary numeric operation - is expected not to be arithmetic operation - with a regular method call - is expected not to be arithmetic operation - with a binary arithmetic operation - is expected to be arithmetic operation - #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 - #nonmutating_hash_method? - with a mutating Hash method - is expected not to be nonmutating hash method - with a nonmutating Hash method - is expected to be nonmutating hash method - with a regular method - is expected not to be nonmutating hash method - #block_literal? - with no block - is expected not to be block literal - with a block argument - is expected not to be block literal - with Ruby >= 2.7 - with a numblock literal - is expected to be block literal - with a block literal - is expected to be block literal - #arguments - with multiple literal arguments - is expected to eq 2 - with no arguments - is expected to be empty - with a single splat argument - is expected to eq 1 - with multiple mixed arguments - is expected to eq 2 - with a single literal argument - is expected to eq 1 - #negation_method? - with prefix bang - is expected to be negation method - with a non-negated method - is expected not to be negation method - with suffix `not` - is expected not to be negation method - with prefix `not` - is expected to be negation method - #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 - #assignment_method? - with a bracket assignment method - is expected to be assignment method - with a regular method - is expected not to be assignment method - with a comparison method - is expected not to be assignment method - with an assignment method - is expected to be assignment method - #predicate_method? - with a regular method - is expected not to be predicate method - with a bang method - is expected not to be predicate method - with a predicate method - is expected to be predicate method - #nonmutating_operator_method? - with a mutating binary operator method - is expected not to be nonmutating operator method - with a regular method - is expected not to be nonmutating operator method - with a nonmutating binary operator method - is expected to be nonmutating operator method - with a nonmutating unary operator method - is expected to be nonmutating operator method - #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 - #binary_operation?? - with an implicit call method - is expected not to be binary operation - with a unary operation - is expected not to be binary operation - with a binary operation - is expected to be binary operation - with a regular method call - is expected not to be binary operation - #const_receiver? - with a self receiver - is expected not to be const receiver - with a non-constant receiver - is expected not to be const receiver - with a constant receiver - is expected to be const receiver - #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 + is expected to be sym type #method? when message does not match - when argument is a string - is expected not to be method "foo" when argument is a symbol is expected not to be method :foo + when 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 + is expected to be method :super when argument is a string - is expected to be method "bar" - #method_name - with a setter method - is expected to eq :bar= - with an operator method - is expected to eq :== - with a plain method - is expected to eq :bar - with an implicit call method - is expected to eq :call - #self_receiver? - with a self receiver - is expected to be 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 - #splat_argument? - with regular arguments - is expected not to be splat argument - with a splat argument - is expected to be splat argument - with no arguments - is expected not to be splat argument - with mixed arguments - is expected to be splat argument - #access_modifier? - when node is a bare `module_function` - is expected to be access modifier - when node is a non-bare `module_function` - is expected to be access modifier - when node is not an access modifier - is expected not to be bare access modifier - #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 - #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 - with a unary operator method - is expected to be operator method - #loop_keyword? - is expected not to be loop keyword - #block_argument? - with mixed arguments - is expected to be block argument - with no arguments - is expected not to be block argument - with a block argument - is expected to be block argument - with regular arguments - is expected not to be block argument - #bare_access_modifier? - when node is not an access modifier - is expected not to be bare access modifier - when node is a bare `module_function` - is expected to be bare access modifier - when node has an argument - is expected not to be bare access modifier - 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 - #lambda? - with a lambda method - is expected to be lambda - with a non-lambda method - is expected not 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 - #dot? - with a unary method - is expected not to be dot - with a double colon - is expected not to be dot - with a dot - is expected to be dot - without a dot - is expected not to be dot - #unary_operation? - with a unary operation - is expected to be unary operation - with a binary operation - is expected not to be unary operation - with a regular method call - is expected not to be unary operation - with an implicit call method - is expected not to be unary operation - #prefix_bang? - with a non-negated method - is expected not to be prefix bang - with keyword `not` - is expected not to be prefix bang - with a bang method - is expected to be prefix bang - #enumerable_method? - with a regular method - is expected not to be enumerable method - with an enumerable method - is expected to be enumerable method + is expected to be method "super" + #assignment_method? + is expected not to be assignment method + #const_receiver? + is expected not to be const receiver #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 - #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 - #block_node - with a block literal - is expected to be block type - with no block - is expected to be nil - with a block argument - is expected to be nil - with Ruby >= 2.7 - with a numblock literal - is expected to be numblock type + is expected not to be camel case method #setter_method? - with an indexed setter method - is expected to be setter method - with a regular method - is expected not to be setter method - with a setter method - is expected to be setter method - with an operator method - is expected not to be setter method - #comparison_method? - with a negation method - is expected not to be comparison method - with a comparison method - is expected to be comparison method - with a regular method - is expected not to be comparison method + is expected not to be setter method #receiver - with a literal receiver - is expected to be str type - with no receiver - is expected to be nil - with a variable receiver - is expected to be send type - #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 - #prefix_not? - with keyword `not` - is expected to be prefix not - with a bang method - is expected not to be prefix not - with a non-negated method - is expected not to be prefix not - -RuboCop::AST::DefNode - #const_receiver? - with a class method definition - is expected not to be const receiver - with an instance method definition - is expected not to be const receiver - with a singleton method definition - is expected to be const receiver - #body - with no body - is expected to be nil - with a multi-expression body - is expected to be begin type - with a single expression body - is expected to be send type - #operator_method? - with a binary operator method - is expected to be operator method - with a regular method - is expected not to be operator method - with a unary operator method - is expected to be operator method - with a setter method - is expected not to be operator method - #method_name - with a setter method - is expected to eq :foo= - with a plain method - is expected to eq :foo - with a unary method - is expected to eq :-@ - with an operator method - is expected to eq :== - #arguments? - with a single regular argument - is expected to be arguments - with a single rest argument - is expected to be arguments - with multiple regular arguments - 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 keyword argument - is expected to be arguments - #first_argument - 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 - with multiple mixed arguments - is expected to be arg type - #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 - #method? - when message matches - when argument is a symbol - is expected to be method :bar - when argument is a string - is expected to be method "bar" - when message does not match - when argument is a string - is expected not to be method "foo" - when argument is a symbol - is expected not to be method :foo - #endless? - with endless method definition - is expected to be endless - with standard method definition - is expected not to be endless - #block_argument? - with no arguments - is expected not to be block argument - with regular arguments - is expected not to be block argument - with mixed arguments - is expected to be block argument + is expected to be nil + #block_literal? + with a block literal + is expected to be block literal with a block argument - is expected to be block argument - #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 - #rest_argument? - with mixed arguments - is expected to be rest argument - with regular arguments - is expected not to be rest argument - with a rest argument - is expected to be rest argument - with no arguments - is expected not to be rest argument - #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 - #void_context? - with a regular method - is expected not to be void context - with an initializer method - is expected to be void context - with a regular assignment method - is expected to be void context - with a bracket assignment method - is expected to be void context - with a comparison method - is expected not to be void context - #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 - when using Ruby 2.7 or newer - #argument_forwarding? - is expected to be argument forwarding - #assignment_method? - with a bracket assignment method - is expected to be assignment method - with a regular method - is expected not to be assignment method - with an assignment method - is expected to be assignment method - with a comparison method - is expected not to be assignment method - #arguments - with a single rest argument - is expected to eq 1 - with a single regular argument - is expected to eq 1 - with multiple regular arguments - is expected to eq 2 - with argument forwarding - is expected to eq 1 - with multiple mixed arguments - is expected to eq 2 - with no arguments - is expected to be empty - .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 - #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 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 - #self_receiver? - with a singleton method definition - is expected not to be self receiver - with an instance method definition - is expected not to be self receiver - with a class method definition - is expected to be self receiver + is expected not to be block literal + with no block + is expected not to be block literal #comparison_method? - with a regular method - is expected not to be comparison method - with a comparison method - is expected to be comparison method - -RuboCop::AST::DefinedNode - #arguments - is expected to all be sym type - is expected to eq 1 - #receiver - is expected to be nil - .new - with a defined? node - is expected to be a kind of RuboCop::AST::DefinedNode - #method_name - is expected to eq :defined? - -RuboCop::AST::AliasNode - .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::ForNode - .new - is expected to be a kind of RuboCop::AST::ForNode - #collection - is expected to be sym type - #post_condition_loop? - is expected not to be post condition loop - #loop_keyword? - is expected to be loop keyword - #do? - with a do keyword - is expected to be do - without a do keyword - is expected not to be do - #void_context? - with a do keyword - is expected to be void context - without a do keyword - is expected to be void context - #body - is expected to be sym type - #keyword - is expected to eq "for" - #variable - is expected to be lvasgn type - -RuboCop::AST::Node - #pure? - for an array literal - with only literal children - returns true - which contains a method call - returns false - for an integer literal - returns true - for a module definition - returns false - for a regexp - with options - returns true - with no interpolation - returns true - with interpolated segments - returns false - for a class definition - returns false - for a method call - returns false - for an lvar assignment - returns false - for a cvar assignment - returns false - for a gvar 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 a hash literal - with only literal children - returns true - which contains a method call - returns false - #parent_module_name - when node on class in singleton class - is expected to eq "Foo::#::Bar" - when node nested in a class << exp - is expected to be nil - when node on module - is expected to eq "Foo" - when node on top level - is expected to eq "Object" - when node nested in an unknown block - is expected to be nil - when node on singleton class - is expected to eq "Foo::#" - #class_definition? - namespaced class - matches - with Class.new - matches - when using numbered parameter - matches - without inheritance - matches - constant defined as Struct without block - does not match - with Struct - matches - when using numbered parameter - matches - with ::ClassName - matches - with object singleton class - matches - with inheritance - matches - with self singleton class - matches - #class_constructor? - class definition on outer scope - matches - class definition with a block - matches - class definition - does not match - module definition with a block - matches - #value_used? - within a module definition node - is always true - within an if...else..end node - nested in a method call - is always true - at the top level - is true only for the condition - within a class definition node - is always true - at the top level - is false - at the end of a block - is always true - within a while node - is true only for the condition - within an array literal - assigned to an ivar - is always true - at the top level - is always false - within a singleton class node - is always true - within a method call node - is always true - #conditional? - when `if` node - is true - when `case` node - is true - when post condition loop node - is false - when `while` node - is true - when `until` node - is true - when `case_match` node - is true - #module_definition? - nested modules - matches - with Module.new - matches - when using numbered parameter - matches - namespaced modules - matches - with ::ModuleName - matches - included module definition - matches - prepend Module.new - matches - using module keyword - matches - #recursive_basic_literal? - behaves like literal - returns true for `'str'` - behaves like literal - returns true for `false` - 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 or true)` - behaves like non literal - returns false for `{ some_method_call => :sym }` - behaves like literal - returns true for `(false && true)` - behaves like literal - returns true for `(1)` - behaves like non literal - returns false for `{ :sym => some_method_call }` - behaves like literal - returns true for `1` - behaves like literal - returns true for `{ a: 1, b: 2 }` - behaves like non literal - returns false for `(x == false)` - behaves like literal - returns true for `1.0` - behaves like literal - returns true for `/./` - behaves like non literal - returns false for `%r{abx#{foo}}ixo` - behaves like non literal - returns false for `some_method_call` - behaves like non literal - returns false for `/.#{some_method_call}/` - behaves like literal - returns true for `!true` - behaves like literal - returns true for `{ :a => 1, :b => 2 }` - behaves like literal - returns true for `nil` - behaves like non literal - returns false for `(x or false)` - behaves like literal - returns true for `[1, 2, 3]` - 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 `"#{2}"` - behaves like non literal - returns false for `[some_method_call]` - #numeric_type? - when string literal - is true - when rational literal - is true - when complex literal whose imaginary part is a rational - is true - when float literal - is true - when complex literal - is true - when integer literal - is true - 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 - #argument_type? - method arguments - returns true for all argument types - block arguments - returns true for all argument types - #struct_constructor? - ::Struct - matches - struct definition with a block - matches - struct definition without block - does not match - -RuboCop::AST::RescueNode - #else_branch - with an else statement - is expected to be send type - without an else statement - is expected to be nil - #branches - when there is an else - returns all the bodies - with an empty else - returns all the bodies - when there is no else keyword - returns only then rescue bodies - #resbody_branches - is expected to all be resbody type - is expected to eq 2 - #body - is expected to be send 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 - -RuboCop::AST::AndNode - #rhs - with a semantic and node - is expected to be int type - with a logical and node - is expected to be int type - #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 - .new - with a logical and node - is expected to be a kind of RuboCop::AST::AndNode - with a semantic and node - is expected to be a kind of RuboCop::AST::AndNode - #lhs - with a semantic and node - is expected to be sym type - with a logical and node - is expected to be sym type - #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 semantic and node - is expected to eq "or" - with a logical and node - is expected to eq "||" - #operator - with a logical and node - is expected to eq "&&" - with a semantic and node - is expected to eq "and" - #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 - -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 - .new - with a semantic or node - is expected to be a kind of RuboCop::AST::OrNode - with a logical or node - is expected to be a kind of RuboCop::AST::OrNode - #lhs - with a logical or node - is expected to be sym type - with a semantic or node - is expected to be sym type - #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 - #operator - with a semantic or node - is expected to eq "or" - with a logical or node - is expected to eq "||" - #alternate_operator - with a logical or node - is expected to eq "or" - with a semantic 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" - #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 - -RuboCop::AST::EnsureNode - #body - is expected to be sym type - .new - is expected to be a kind of RuboCop::AST::EnsureNode - -RuboCop::AST::LambdaNode - #method_name - is expected to eq :lambda - #receiver - is expected to be nil - #arguments - is expected to eq 2 - -RuboCop::AST::Ext::Range - #line_span - returns the range of lines a range occupies - accepts an `exclude_end` keyword argument - -RuboCop::AST::NodePattern::Lexer - provides tokens via next_token - with $type+ - is parsed as `$ int + x` - when given a regexp /test/ - round trips - when given a regexp /back\\slash/ - round trips - when given arithmetic symbols - is parsed as `:&` - when given a regexp ending with a backslash - does not lexes it properly - when given node types and constants - distinguishes them - when given a regexp /[abc]+\/()?/x - round trips - -RuboCop::AST::DstrNode - #value - with a multiline string - is expected to eq "this is a multiline string" - with implicit concatenation - is expected to eq "foo bar baz" - with interpolation - is expected to eq "foo \#{bar} baz" - -RuboCop::AST::ReturnNode - behaves like wrapped arguments node - #arguments - with no arguments and braces - is expected to be empty - with a single argument and braces - is expected to eq 1 - with multiple literal arguments - is expected to eq 2 - with 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 - .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 - -RuboCop::AST::ArrayNode - .new - is expected to be a kind of RuboCop::AST::ArrayNode - #values - with an array of variables - is expected to eq 2 - is expected to all be send type - with an empty array - is expected to be empty - with an array of literals - is expected to all be literal - is expected to eq 3 - #percent_literal? - with a string percent literal - is expected not to be percent literal :symbol - is expected to be percent literal :string - is expected to be percent literal - 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 symbol percent literal - is expected to be percent literal - is expected not to be percent literal :string - is expected to be percent literal :symbol - #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 - #square_brackets? - with a percent literal - is expected not to be square brackets - with square brackets - is expected to be square brackets - #bracketed? - with square brackets - is expected to be bracketed - with a percent literal - is expected to be bracketed - unbracketed - is expected to be nil - -RuboCop::AST::CaseMatchNode - when using Ruby 2.7 or newer - #keyword - is expected to eq "case" - #each_in_pattern - when passed a block - yields all the conditions - when not passed a block - is expected to be a kind of Enumerator - #else_branch - #else? - with an empty else statement - is expected to be empty else type - without an else statement - is expected to be nil - with an else statement - is expected to be sym type - #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 - #branches - when there is no else keyword - returns only then when bodies - when there is an else - with empty else - returns all the bodies - with else body - returns all the bodies - .new - is expected to be a kind of RuboCop::AST::CaseMatchNode - -RuboCop::AST::NodePattern::Sets - is expected to eq "::RuboCop::AST::NodePattern::Sets::SET_1_2_3_ETC" - creates a constant with the right value - is expected not to eq "::RuboCop::AST::NodePattern::Sets::SET_1_2_3_ETC_2" - is expected to eq "::RuboCop::AST::NodePattern::Sets::SET_1_2_3_ETC" - -RuboCop::AST::ProcessedSource - .from_file - raises a Errno::ENOENT when the file does not exist - when the file exists - sets the file path to the instance's #path - returns an instance of ProcessedSource - #blank? - with source of no content - returns true - with source with content - returns false - #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 - #preceding_line - returns source of line before token - valid_syntax? - when the source itself is valid encoding but includes strange encoding literals that are accepted by MRI - returns true - when the source is invalid - returns false - when a line starts with an integer literal - tokenizes the source correctly - when the source is completely valid - returns true - when the source is valid but has some warning diagnostics - returns true - when the source could not be parsed due to encoding error - returns false - #[] - when start index and length are passed - returns the array of lines - when a range is passed - returns the array of lines - when an index is passed - returns the line - #file_path - returns file path - #parser_error - when the source was properly parsed - is nil - when the source lacks encoding comment and is really utf-8 encoded but has been read as US-ASCII - is nil - when the source could not be parsed due to encoding error - returns the error - #tokens - has an array of tokens - 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 - #lines - is an array - has same number of elements as line count - contains lines as string without linefeed - #comments - is an array of comments - when the source is invalid - returns [] - #last_token_of - accepts Node as an argument - returns last token for node - #first_token_of - returns first token for node - accepts Node as an argument - #buffer - is a source buffer - #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 heredoc node - returns tokens for node after heredoc - returns tokens for node before heredoc - with heavily commented source - #line_with_comment? - returns false for lines without comments - returns true for lines with comments - #each_comment - yields all comments - #comments_before_line - returns comments on or before given line - #each_comment_in_lines - yields the 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 with comment - is expected to equal true - provided source_range on comment line - is expected to equal true - provided a multiline source_range with at least one line with comment - is expected to equal true - provided source_range on line without comment - is expected to equal false - #following_line - returns source of line after token - -RuboCop::AST::InPatternNode - when using Ruby 2.7 or newer - .new - is expected to be a kind of RuboCop::AST::InPatternNode - #pattern - with a variable pattern - is expected to be match var type - 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 an alternative pattern - is expected to be match alt type - with a value pattern - is expected to be int type - with an as pattern - is expected to be match as type - #body - with a then keyword - is expected to be sym type - without a then keyword - is expected to be array type - #branch_index - is expected to eq 0 - is expected to eq 2 - is expected to eq 1 - #then? - with a then keyword - is expected to be then - without a then keyword - is expected not to be then + is expected not to be comparison method RuboCop::AST::NodePattern - node type - in seq head - on a node with the same type - is expected to match code s(:ivar, :@ivar), :+, and s(:int, 2) - on a child with a different type - behaves like nonmatching - doesn't match - for a child - on a child with the same type - is expected to match code s(:send, nil, :foo) and :bar - on a child with a different type - behaves like nonmatching - doesn't match - on a child litteral - behaves like nonmatching - doesn't match - unions - at the top level - containing multiple [] - on a node which meets all requirements of the first [] - is expected to match code 3 - on a node which meets all requirements of the second [] - is expected to match code 2.4 - on a node which meets some requirements but not all - behaves like nonmatching - doesn't match - containing mixed node and literals - is expected to match code nil and :obj - containing integer literals - is expected to match code s(:int, 10) and :abs - containing string literals - is expected to match code s(:str, "a") and :upcase - containing symbol literals - when the AST does not have a matching symbol - behaves like nonmatching - doesn't match - when the AST has a matching symbol - is expected to match code s(:send, nil, :obj) and :b - with a nested sequence - is expected to match code s(:const, nil, :Const) and :method - nested inside a sequence - is expected to match code s(:const, nil, :Const) and :method - variadic - with fixed terms - works for cases with variadic terms after union - works for cases with variadic terms before and after union - works for cases with fixed arity before and after union - multiple - works for complex cases - 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 - simple sequence - 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 - on a node with a different type - behaves like nonmatching - doesn't match - with a nested sequence in non-head position - is expected to match code s(:send, - s(:send, nil, :obj), :a) and :b - on a node with the same type and non-matching children - with non-matching selector - behaves like nonmatching - doesn't match - with non-matching receiver type - behaves like nonmatching - doesn't match - on a node with the same type and matching children - is expected to match code s(:int, 1), :+, and s(:int, 1) ellipsis with a wildcard at the end, but no remaining child to match it behaves like nonmatching doesn't match - at the very beginning of a sequence - is expected to match code s(:int, 10), :*, and s(:int, 1) - preceding a capture - behaves like single capture - yields captured value(s) and returns true if there is a block - returns captured values if there is no block - with a set at the end, but no remaining child to match it - behaves like nonmatching - doesn't match preceding multiple captures behaves like multiple capture - yields captured value(s) and returns true if there is a block returns captured values if there is no block - with a nested sequence at the end, but no remaining child + yields captured value(s) and returns true if there is a block + with [] at the end, but no remaining child to match it behaves like nonmatching doesn't match - with [] at the end, but no remaining child to match it + with a set at the end, but no remaining child to match it behaves like nonmatching doesn't match with a nodetype at the end, but no remaining child to match it behaves like nonmatching doesn't match + preceding a capture + behaves like single capture + returns captured values if there is no block + yields captured value(s) and returns true if there is a block + with a nested sequence at the end, but no remaining child + behaves like nonmatching + doesn't match + at the very beginning of a sequence + is expected to match code s(:int, 10), :*, and s(:int, 1) + caret (ascend) + repeated twice + is expected to match code 1 + within sequence + in head + is expected to match code 1 + of a sequence + is expected to match code 1 + not in head + is expected to match code s(:int, 1) and :inc + of a sequence + is expected to match code s(:int, 1) and :inc + inside a union + is expected to match code "abc" + inside an intersection + is expected to match code 1 + 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 matches + is expected to match code 1 + which doesn't match + behaves like nonmatching + doesn't match bad syntax - with empty parentheses + with unmatched closing curly + 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 + with negated closing curly behaves like invalid is invalid - with unmatched opening paren + with unmatched opening curly behaves like invalid is invalid - with negated closing paren + with empty intersection behaves like invalid is invalid - with unmatched closing curly + with empty union behaves like invalid is invalid with doubled ellipsis @@ -4693,158 +4864,42 @@ with unmatched opening paren and `...` behaves like invalid is invalid - with unmatched opening curly + with empty parentheses behaves like invalid is invalid - with doubled comma in arg list + with unmatched closing paren behaves like invalid is invalid - with leading comma in arg list + with negated closing paren behaves like invalid is invalid - with negated closing curly + with negated ellipsis behaves like invalid is invalid - with empty intersection + with leading comma in arg list behaves like invalid is invalid with empty union subsequence in seq head behaves like invalid is invalid - with empty union - behaves like invalid - is invalid - with unsupported subsequence in seq head within union - behaves like invalid - is invalid - with unmatched closing paren + with unmatched opening paren behaves like invalid is invalid - captures within union - 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 - with a different number of captures in each branch + with doubled comma in arg list behaves like invalid is invalid - on simple subpatterns - behaves like single capture - yields captured value(s) and returns true if there is a block - returns captured values if there is no block - with complex nesting - behaves like multiple capture - yields captured value(s) and returns true if there is a block - returns captured values if there is no block - captures on ... - with remaining patterns at the end - behaves like single capture - yields captured value(s) and returns true if there is a block - returns captured values if there is no block - with a remaining 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 - behaves like single capture - returns captured values if there is no block - yields captured value(s) and returns true if there is a block - with a remaining literal at the end - behaves like single capture - yields captured value(s) and returns true if there is a block - returns captured values if there is no block - after a child - behaves like single capture - returns captured values if there is no block - yields captured value(s) and returns true if there is a block - with no remaining pattern at the end - behaves like single capture - yields captured value(s) and returns true if there is a block - returns captured values if there is no block - with a remaining 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 [] at the end - behaves like single capture - returns captured values if there is no block - yields captured value(s) and returns true if there is a block - with a remaining sequence at the end - behaves like single capture - returns captured values if there is no block - yields captured value(s) and returns true if there is a block - with a remaining set at the end - behaves like single capture - returns captured values if there is no block - yields captured value(s) and returns true if there is a block - 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 - caret (ascend) - inside an intersection - is expected to match code 1 - used with a node type - which doesn't match - behaves like nonmatching - doesn't match - which matches - is expected to match code 1 - repeated twice - 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 - 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 - regexp - matches symbols or strings - captures on a wildcard - in head position in a sequence against literal (bug #5470) - behaves like nonmatching - doesn't match - 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 - 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 - 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 - 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 - 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 sequence with trailing ... on a node with a different type behaves like nonmatching doesn't match + on a node with the same type and fewer children + behaves like nonmatching + doesn't match on a node with non-matching children 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 fewer children, with a wildcard preceding behaves like nonmatching doesn't match @@ -4853,146 +4908,152 @@ is expected to match code s(:int, 1), :blah, and s(:int, 1) with 2 children more is expected to match code s(:int, 1), :blah, s(:int, 1), and s(:sym, :something) - on a node with the same type and fewer children + params + when negated, with a nonmatching value + is expected to match code s(:const, + s(:const, nil, :Namespace), :B) and :A + in a nested sequence + is expected to match code s(:send, + s(:send, + s(:int, 5), :dec), :inc), :inc, and :dec + without explicit number + is expected to match code s(:const, + s(:const, nil, :Namespace), :A), :A, and s(:const, nil, :Namespace) + when inside a union, with a nonmatching value 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 - 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 the given argument if it is not a Node - yields all children depth first - bare node type - #pattern - returns the pattern - on a node with a different type + as named parameters + when provided as argument to match + is expected to match code s(:int, 10) and {:foo=>#} + when not provided + raises an ArgumentError + when extra are provided + raises an ArgumentError + in root position + is expected to match code s(:int, 10) and s(:int, 10) + in root position + is expected to match code s(:int, 10) and # + when inside a union, with a matching value + is expected to match code s(:int, 10) and 10 + when inside an intersection + is expected to match code s(:int, 20), 10, and 20 + param number zero + in a position which does not match original target node + behaves like nonmatching + doesn't match + in a position which matches original target node + is expected to match code 1 + when 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 + when captured + behaves like single capture + returns captured values if there is no block + yields captured value(s) and returns true if there is a block + when preceded by ... + is expected to match code s(:send, + s(:int, 1), :+, + s(:int, 10)) and s(:int, 10) + when negated, with a matching value behaves like nonmatching doesn't match - marshal compatibility - is expected to match code s(:send, nil, :obj) and :method - on a node with a matching, hyphenated type - is expected to match code s(:lvasgn, :a), :+, and s(:int, 1) - #to_s - is instructive - #dup - is expected to match code s(:send, nil, :obj) and :method - #== - 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 + 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 in any order - with a captured ellipsis - matching all children - behaves like single capture + invalid + with an ellipsis inside and outside + behaves like multiple capture yields captured value(s) and returns true if there is a block returns captured values if there is no block nested + behaves like invalid + is invalid + doubled with ellipsis in wrong order + behaves like nonmatching + doesn't match + containing ellipsis not at the end + behaves like invalid + is invalid + at the beginning of a sequence + behaves like invalid + is invalid + doubled with ellipsis behaves like multiple capture returns captured values if there is no block yields captured value(s) and returns true if there is a block - matching non sequential children - behaves like single capture - yields captured value(s) and returns true if there is a block - returns captured values if there is no block - with 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 + doubled + separated by an ellipsis + behaves like multiple capture returns captured values if there is no block yields captured value(s) and returns true if there is a block - 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 without ellipsis with matching children behaves like multiple capture - yields captured value(s) and returns true if there is a block returns captured values if there is no block + 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 - invalid - with an ellipsis inside and outside + with a captured ellipsis + 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 + 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 - containing ellipsis not at the end - behaves like invalid - is invalid - doubled with ellipsis - behaves like multiple capture + matching all children + behaves like single capture returns captured values if there is no block yields captured value(s) and returns true if there is a block - at the beginning of a sequence - behaves like invalid - is invalid - nested - behaves like invalid - is invalid - doubled with ellipsis in wrong order - behaves like nonmatching - doesn't match - captures which also perform a match - 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 + 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 - on a set + captured + without ellipsis + behaves like single capture + returns captured values if there is no block + yields captured value(s) and returns true if there is a block + captures which also perform a match + on [] behaves like single capture returns captured values if there is no block yields captured value(s) and returns true if there is a block - 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 literal + on a sequence behaves like single capture yields captured value(s) and returns true if there is a block returns captured values if there is no block on a 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 - descend - 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 - without match - behaves like nonmatching - doesn't match - with a match multiple levels, depth first + on a set behaves like single capture - yields captured value(s) and returns true if there is a block returns captured values if there is no block - with an immediate match + yields captured value(s) and returns true if there is a block + on a literal behaves like single capture returns captured values if there is no block yields captured value(s) and returns true if there is a block + when nested + behaves like multiple capture + yields captured value(s) and returns true if there is a block + returns captured values if there is no block + regexp + matches symbols or strings + descend with a literal match is expected to match code s(:int, 1) and s(:array, s(:array, @@ -5002,60 +5063,128 @@ s(:array, s(:int, 5)))), s(:int, 4)) - 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 + 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 an immediate match + behaves like single capture + returns captured values if there is no block + yields captured value(s) and returns true if there is a block + with a match multiple levels, depth first + behaves like single capture + returns captured values if there is no block + yields captured value(s) and returns true if there is a block + without match behaves like nonmatching doesn't match - nil literals - is expected to match code - literals - double quoted string literals - is expected to match code "foo" - single quoted string literals - is expected to match code "foo" - symbol literals - is expected to match code :foo - negative integer literals - is expected to match code -100 - positive float literals - is expected to match code 1.0 - negative float literals - is expected to match code -2.5 - bare literal - on a node + macros + with a pattern with a constant + is expected to match code :hello + when the value is not in the set behaves like nonmatching doesn't match - on a matching literal - is expected to match code :bar - 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 - repeated - using ? - with too many matching children + 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 zero match - behaves like single capture - yields captured value(s) and returns true if there is a block - returns captured values if there is no block + with a pattern without captures + def_node_matcher + returns the method name + when called on non-matching code + behaves like nonmatching + doesn't match + when it errors + raises an error with the right location + when called on matching code + is expected to match code :hello + def_node_search + returns the method name + 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 + without a predicate name + when called on non-matching code + returns an enumerator yielding nothing + when it errors + raises an error with the right location + when called on matching code + returns an enumerator yielding the matches + with a pattern with captures + def_node_search + without a predicate name + when it errors + raises an error with the right location + when called on non-matching code + returns an enumerator yielding nothing + 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 + 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 + 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 + commas + with commas randomly strewn around + behaves like invalid + is invalid + bare node type + #to_s + is instructive + on a node with a matching, hyphenated type + is expected to match code s(:lvasgn, :a), :+, and s(:int, 1) + #== + returns true iff the patterns are similar + on a node with a different type + behaves like nonmatching + doesn't match + on a node with the same type + is expected to match code s(:send, nil, :obj) and :method + #dup + is expected to match code s(:send, nil, :obj) and :method + marshal compatibility + is expected to match code s(:send, nil, :obj) and :method + #pattern + returns the pattern + yaml compatibility + is expected to match code s(:send, nil, :obj) and :method + repeated + using + behaves like repeated pattern + at beginning of sequence + behaves like invalid + is invalid with one match behaves like single capture returns captured values if there is no block yields captured value(s) and returns true if there is a block - 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 + with matching children behaves like single capture yields captured value(s) and returns true if there is a block @@ -5063,114 +5192,342 @@ with zero match behaves like nonmatching doesn't match + using ? behaves like repeated pattern - at beginning of sequence - behaves like invalid - is invalid with an ellipsis in the same sequence is expected to match code "[:hello, 1, 2, 3]" with one match behaves like single capture - yields captured value(s) and returns true if there is a block returns captured values if there is no block + 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 + yields captured value(s) and returns true if there is a block + returns captured values if there is no block + with too many matching children + behaves like nonmatching + doesn't match using * + 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) - nested with multiple subcaptures - behaves like multiple capture - returns captured values if there is no block - yields captured value(s) and returns true if there is a block - with multiple subcaptures - behaves like multiple capture - 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 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 an ellipsis in the same sequence - is expected to match code "[:hello, 1, 2, 3]" with one match behaves like single capture yields captured value(s) and returns true if there is a block returns captured values if there is no block - with matching children + with zero match behaves like single capture + yields captured value(s) and returns true if there is a block + returns captured values if there is no block + with 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 - with zero match + with matching children behaves like single capture + returns captured values if there is no block yields captured value(s) and returns true if there is a block + 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 + 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 + on a sequence + with a matching node + behaves like nonmatching + doesn't match + with a node with non-matching children + is expected to match code :@b and s(:int, 1) + with a node of different type + is expected to match code :@@a and s(:int, 1) 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 symbol - with a non-matching symbol, but too many children + on a set + with a non-matching value + is expected to match code :@a and s(:int, 3) + with a matching value behaves like nonmatching doesn't match - with a matching symbol + on square brackets + with a node which meets all requirements of [] behaves like nonmatching doesn't match - with a non-matching symbol - is expected to match code s(:send, nil, :obj) and :xyz + with a node which meets only 1 requirement of [] + is expected to match code 1 when nested in complex ways with (send int :- int) is expected to match code s(:int, 1), :-, and s(:int, 1) - with (send str :<< str) - behaves like nonmatching - doesn't match with (send str :+ (send str :to_i)) is expected to match code s(:str, "abc"), :+, and s(:send, s(:str, "1"), :to_i) - on square brackets - with a node which meets all requirements of [] + with (send str :<< str) behaves like nonmatching doesn't match - with a node which meets only 1 requirement of [] - is expected to match code 1 - on a sequence - with a node with non-matching children - is expected to match code :@b and s(:int, 1) - with a matching node + on a symbol + with a non-matching symbol + is expected to match code s(:send, nil, :obj) and :xyz + with a non-matching symbol, but too many children behaves like nonmatching doesn't match - with a node of different type - is expected to match code :@@a and s(:int, 1) - on a set - with a matching value + with a matching symbol behaves like nonmatching doesn't match - with a non-matching value - is expected to match code :@a and s(:int, 3) + .descend + yields the given argument if it is not a Node + yields all children depth first + node type + for a child + on a child with a different type + behaves like nonmatching + doesn't match + on a child litteral + behaves like nonmatching + doesn't match + on a child with the same type + is expected to match code s(:send, nil, :foo) and :bar + 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 + funcalls + 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) + with one argument + is expected to match code s(:str, "foo") and "foo" + captures on ... + with a remaining sequence at the end + behaves like single capture + yields captured value(s) and returns true if there is a block + returns captured values if there is no block + with a remaining wildcard at the end + behaves like single capture + yields captured value(s) and returns true if there is a block + returns captured values if there is no block + with a remaining capture at the end + behaves like multiple capture + returns captured values if there is no block + yields captured value(s) and returns true if there is a block + with a remaining literal at the end + behaves like single capture + returns captured values if there is no block + yields captured value(s) and returns true if there is a block + with a remaining set at the end + behaves like single capture + returns captured values if there is no block + yields captured value(s) and returns true if there is a 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 + at the very beginning of a sequence + behaves like single capture + yields captured value(s) and returns true if there is a block + returns captured values if there is no block + with 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 + after a child + behaves like single capture + yields captured value(s) and returns true if there is a block + returns captured values if there is no block + with a remaining node type at the end + behaves like single capture + returns captured values if there is no block + yields captured value(s) and returns true if there is a block + with remaining patterns at the end + behaves like single capture + yields captured value(s) and returns true if there is a block + returns captured values if there is no block + captures within union + with a different number of captures in each branch + behaves like invalid + is invalid + 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 + with complex nesting + behaves like multiple capture + yields captured value(s) and returns true if there is a block + returns captured values if there is no block + on simple subpatterns + behaves like single capture + returns captured values if there is no block + yields captured value(s) and returns true if there is a block + unions + variadic + 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 + with variadic terms + works for cases with fixed arity before and after union + works for cases with variadic terms before and after union + works for cases with variadic terms after union + multiple + works for complex cases + at the top level + containing string literals + is expected to match code s(:str, "a") and :upcase + containing symbol literals + when the AST does not have a matching symbol + behaves like nonmatching + doesn't match + when the AST has a matching symbol + is expected to match code s(:send, nil, :obj) and :b + containing multiple [] + on a node which meets some requirements but not all + behaves like nonmatching + doesn't match + on a node which meets all requirements of the second [] + is expected to match code 2.4 + on a node which meets all requirements of the first [] + is expected to match code 3 + containing mixed node and literals + is expected to match code nil and :obj + containing integer literals + is expected to match code s(:int, 10) and :abs + nested inside a sequence + is expected to match code s(:const, nil, :Const) and :method + with a nested sequence + is expected to match code s(:const, nil, :Const) and :method + literals + negative integer literals + is expected to match code -100 + bare literal + on a matching literal + is expected to match code :bar + on a node + behaves like nonmatching + doesn't match + single quoted string literals + is expected to match code "foo" + positive float literals + is expected to match code 1.0 + negative float literals + is expected to match code -2.5 + symbol literals + is expected to match code :foo + double quoted string literals + is expected to match code "foo" + simple sequence + with a nested sequence in non-head position + is expected to match code s(:send, + s(:send, nil, :obj), :a) and :b + with a nested sequence in head position + behaves like invalid + is invalid + on a node with the same type and non-matching children + with non-matching selector + behaves like nonmatching + doesn't match + with non-matching receiver type + behaves like nonmatching + doesn't match + on a node with the same type and matching children + is expected to match code s(:int, 1), :+, and s(:int, 1) + on a node with too many children + behaves like nonmatching + doesn't match + on a node with a different type + behaves like nonmatching + doesn't match + captures on a wildcard + in head position in a sequence + behaves like single capture + yields captured value(s) and returns true if there is a block + returns captured values if there is no block + in head position in a sequence against literal (bug #5470) + behaves like nonmatching + doesn't match + nested in any child + behaves like multiple capture + returns captured values if there is no block + yields captured value(s) and returns true if there is a block + at the root level + behaves like single capture + yields captured value(s) and returns true if there is a block + returns captured values if there is no block + in head position in a sequence against nil (bug #5470) + behaves like nonmatching + doesn't match + 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 + in non-head position in a sequence + behaves like single capture + yields captured value(s) and returns true if there is a block + returns captured values if there is no block wildcards named wildcards + within a sequence with other patterns intervening + is expected to match code :@abc and s(:int, 22) at the root level is expected to match code s(:sclass, s(:self), s(:def, :something, s(:args), s(:int, 1))) and :freeze - within a sequence with other patterns intervening - is expected to match code :@abc and s(:int, 22) within a sequence + with values which cannot be unified + behaves like nonmatching + doesn't match 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 - in head position of a sequence - is expected to match code s(:int, 1), :+, and s(:send, nil, :a) within a union + confined to the union + with partial unification + matching the unified branch + is expected to match code s(:int, 5) and s(:int, 5) + matching the free branch + is expected to match code s(:int, 2) and s(:int, 1) + that can not be unified + behaves like nonmatching + doesn't match + without unification + is expected to match code s(:int, 2) and s(:int, 1) + with a preceding unifying constraint + 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 with a succeeding unifying constraint with branches without the wildcard encountered after @@ -5184,1404 +5541,1083 @@ 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 matching another branch is expected to match code s(:array, s(:int, 2), s(:int, 1)) and s(:int, 2) - confined to the union - without unification - is expected to match code s(:int, 2) and s(:int, 1) - with partial unification - matching the free branch - is expected to match code s(:int, 2) and s(:int, 1) - matching the unified branch - is expected to match code s(:int, 5) and s(:int, 5) that can not be unified behaves like nonmatching doesn't match - with a preceding unifying constraint - matching a branch - is expected to match code s(:int, 2) and s(:array, - s(:int, 2), - s(:int, 1)) - that can not be unified - behaves like nonmatching - doesn't match + in head position of a sequence + is expected to match code s(:int, 1), :+, and s(:send, nil, :a) 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 with other patterns intervening + is expected to match code :@abc and s(:int, 22) within a sequence is expected to match code nil and :Const - negated - behaves like nonmatching - doesn't match at the root level is expected to match code s(:sclass, s(:self), s(:def, :something, s(:args), s(:int, 1))) and :freeze - macros - with a pattern with a constant - is expected to match code :hello - when the value is not in the set - behaves like nonmatching - doesn't match - with a pattern with a namespaced call - is expected to match code :hello - when the value is not in the set + negated behaves like nonmatching doesn't match - 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 called on non-matching code - behaves like nonmatching - doesn't match - when it errors - raises an error with the right location - def_node_matcher - when called on non-matching code - behaves like nonmatching - doesn't match - when it errors - raises an error with the right location - when called on matching code - is expected to eq :hello - with a pattern without captures - def_node_matcher - returns the method name - when it errors - raises an error with the right location - when called on matching code - is expected to match code :hello - when called on non-matching code - behaves like nonmatching - doesn't match - 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 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) - commas - with commas randomly strewn around - behaves like invalid - is invalid predicates - when negated - is expected to match code s(:int, 1) and :inc - in root position + at head position of a sequence 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 true - is expected to match code s(:int, 2), :+, and s(:float, 2.0) - for which the predicate is false - behaves like nonmatching - doesn't match - with a constant argument - for which the predicate is true - is expected to match code s(:int, 1), :+, and s(:int, 2) + applied to an integer for which the predicate is false + behaves like nonmatching + doesn't match + with one extra argument for which the predicate is false behaves like nonmatching doesn't match - with a named argument - when not given - raises an error for which the predicate is true is expected to match code s(:send, s(:int, 1), :+, - s(:int, 2)) and {:param=>1} - with extra arguments - raises an error + s(:int, 2)) and 1 + with a constant argument for which the predicate is false behaves like nonmatching doesn't match - with one extra argument for which the predicate is true - is expected to match code s(:send, - s(:int, 1), :+, - s(:int, 2)) and 1 + is expected to match code s(:int, 1), :+, and s(:int, 2) + when negated + is expected to match code s(:int, 1) and :inc + with multiple arguments for which the predicate is false behaves like nonmatching doesn't match - with multiple arguments for which the predicate is true is expected to match code s(:str, "c"), "a", and "d" - for which the predicate is false - behaves like nonmatching - doesn't match - 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 - behaves like nonmatching - doesn't match - when in last-child position, but all children have already been matched - behaves like nonmatching - doesn't match when captured behaves like single capture - yields captured value(s) and returns true if there is a block returns captured values if there is no block - at head position of a sequence + yields captured value(s) and returns true if there is a block + applied to an integer for which the predicate is true is expected to match code s(:int, 1) and :inc - params - when negated, with a matching value - behaves like nonmatching - doesn't match - when inside a union, with a nonmatching value + when in last-child position, but all children have already been matched 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 - 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 + with a named argument + with extra arguments + raises an error + for which the predicate is true + is expected to match code s(:send, + s(:int, 1), :+, + s(:int, 2)) and {:param=>1} + when not given + raises an error + for which the predicate is false behaves like nonmatching doesn't match - when preceded by $... - behaves like single capture - returns captured values if there is no block - yields captured value(s) and returns true if there is a block - when inside an intersection - is expected to match code s(:int, 20), 10, and 20 - 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 + with an expression argument + for which the predicate is false + behaves like nonmatching + doesn't match + for which the predicate is true + is expected to match code s(:int, 2), :+, and s(:float, 2.0) in root position - is expected to match code s(:int, 10) and s(:int, 10) - in root position - is expected to match code s(:int, 10) and # - without explicit number - is expected to match code s(:const, - s(:const, nil, :Namespace), :A), :A, and s(:const, nil, :Namespace) - in a nested sequence - is expected to match code s(:send, - s(:send, - s(:int, 5), :dec), :inc), :inc, and :dec - when preceded by ... - is expected to match code s(:send, - s(:int, 1), :+, - s(:int, 10)) and s(:int, 10) - 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 + 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 -RuboCop::AST::ArgsNode +RuboCop::AST::NodePattern::Sets + is expected not to eq "::RuboCop::AST::NodePattern::Sets::SET_1_2_3_ETC_2" + is expected to eq "::RuboCop::AST::NodePattern::Sets::SET_1_2_3_ETC" + creates a constant with the right value + is expected to eq "::RuboCop::AST::NodePattern::Sets::SET_1_2_3_ETC" + +RuboCop::AST::Token + type predicates + #comment? + returns true for comment tokens + returns false for non comment tokens + #right_bracket? + returns true for all right_bracket tokens + returns false for non right_bracket tokens + #left_ref_bracket? + returns false for non left_ref_bracket tokens + returns true for left_ref_bracket tokens + #left_brace? + returns false for non right_bracket tokens + returns true for right_bracket tokens + #equals_sign? + returns true for equals sign tokens + returns false for non equals sign tokens + #left_bracket? + returns false for non left_bracket tokens + returns true for all left_bracket tokens + #dot? + returns false for non dot tokens + returns true for dot tokens + #rescue_modifier? + returns true for rescue modifier tokens + returns false for non rescue modifier tokens + #new_line? + returns false for non new line tokens + returns true for new line tokens + #left_array_bracket? + returns false for non left_array_bracket tokens + returns true for left_array_bracket tokens + #comma? + returns false for non comma tokens + returns true for comma tokens + #end? + returns false for non end tokens + returns true for end tokens + #regexp_dots? + returns false for non comma tokens + returns true for regexp tokens + with braces & parens + #left_brace? + returns true for left hash brace tokens + returns false for non left hash brace tokens + #left_parens? + returns false for non left parens tokens + returns true for left parens tokens + #right_curly_brace? + returns true for all right brace tokens + returns false for non right brace tokens + #left_curly_brace? + returns false for non left block brace tokens + returns true for left block brace tokens + #right_parens? + returns true for right parens tokens + returns false for non right parens tokens + #semicolon? + returns false for non semicolon tokens + returns true for semicolon tokens + #space_before + returns nil when there is not a space before token + returns nil when it is on the first line + returns truthy MatchData when there is a space before token + #end_pos + returns index of last char in token range of entire source + #line + returns line of token + .from_parser_token + sets parser token's text to rubocop token's text + sets parser token's type to rubocop token's type + returns a #to_s useful for debugging + sets parser token's range to rubocop token's pos + #space_after + returns nil when there is not a space after token + returns truthy MatchData when there is a space after token + #to_s + returns string of token data + #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::OrNode + #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 + #lhs + with a logical or node + is expected to be sym type + with a semantic or node + is expected to be sym type + #inverse_operator + with a logical or node + is expected to eq "&&" + with a semantic or node + is expected to eq "and" .new - with a lambda literal - is expected to be a kind of RuboCop::AST::ArgsNode - with a method definition - is expected to be a kind of RuboCop::AST::ArgsNode - with a block - is expected to be a kind of RuboCop::AST::ArgsNode - #empty_and_without_delimiters? - with delimiters - with a block - is expected to equal false - with a lambda literal - is expected to equal false - with a method definition - is expected to equal false - with empty arguments - with a 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 method definition - is expected to equal false - with a lambda literal - is expected to equal false - #argument_list - is expected to eq [s(:arg, :a), s(:optarg, :b, - s(:int, 42)), s(:arg, :c), s(:restarg, :d), s(:kwarg, :e), s(:kwoptarg, :f, - s(:int, 42)), s(:kwrestarg, :g), s(:blockarg, :h), s(:shadowarg, :i)] - when using Ruby 2.7 or newer - with argument forwarding - is expected to eq [s(:forward_arg)] + 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 logical or node + is expected to be int type + with a semantic or node + is expected to be int 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 + #operator + with a logical or node + is expected to eq "||" + with a semantic or node + is expected to eq "or" + #alternate_operator + with a logical or node + is expected to eq "or" + with a semantic or node + is expected to eq "||" -RuboCop::AST::CaseNode - #when_branches - is expected to eq 3 - is expected to all be when type - #branches - when there is no else keyword - returns only then when bodies - when compared to an IfNode - returns the same - when there is an else - returns all the bodies - with an empty else - returns all the bodies - #each_when - when passed a block - yields all the conditions - when not passed a block - is expected to be a kind of Enumerator - #else_branch - #else? - 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? - without an else statement - is expected not to be else - with an else statement - is expected to be else +RuboCop::AST::WhileNode + #loop_keyword? + with a modifier while + is expected to be loop keyword + with a statement while + is expected to be loop keyword + #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 "case" + is expected to eq "while" + #post_condition_loop? + with a statement while + is expected not to be post condition loop + with a modifier while + is expected to be post condition loop + #inverse_keyword + is expected to eq "until" .new - is expected to be a kind of RuboCop::AST::CaseNode + with a statement while + is expected to be a kind of RuboCop::AST::WhileNode + with a modifier while + is expected to be a kind of RuboCop::AST::WhileNode + +RuboCop::AST::ConstNode + #relative? + with a non-namespaced constant + is expected to be relative + #each_path + yields all parts of the namespace + #short_name + is expected to eq :BAZ + #absolute? + is expected to be absolute + with a constant not starting with :: + is expected not to be absolute + with a non-namespaced constant + is expected not to be absolute + #module_name? + is expected not to be module name + with a constant with a lowercase letter + is expected to be module name + #namespace + is expected to eq "::Foo::Bar" + +Set#=== + tests for inclusion + +RuboCop::AST::OpAsgnNode + #expression + is expected to eq s(:send, nil, :value) + #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 :% + #assignment_node + is expected to be a kind of RuboCop::AST::AsgnNode + .new + with an `op_asgn_node` node + is expected to be a kind of RuboCop::AST::OpAsgnNode + #name + is expected to eq :var + +RuboCop::AST::EnsureNode + .new + is expected to be a kind of RuboCop::AST::EnsureNode + #body + is expected to be sym type RuboCop::AST::BreakNode behaves like wrapped arguments node #arguments - with a single argument and braces + with a single 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 + with a single argument and braces is expected to eq 1 with no arguments is expected to be empty + with no arguments and braces + is expected to be empty .new without arguments is expected to be a kind of RuboCop::AST::BreakNode with arguments is expected to be a kind of RuboCop::AST::BreakNode -RuboCop::AST::PairNode - #colon? - when using a hash rocket delimiter - is expected not to be colon - when using a colon delimiter - is expected to be colon - #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 hash rocket delimiter - is expected to eq "=>" - is expected to eq " => " - when using a colon delimiter - is expected to eq ": " - is expected to eq ":" - #value - is expected to be int type - #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 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 behind - when second pair is a keyword splat - is expected to eq 0 - when both pairs are reail pairs - is expected to eq -2 - when both keys are on the same line - when second pair is a keyword splat - is expected to eq 0 - when both pairs are explicit pairs - is expected to eq 0 - when keys are aligned - when second pair is a keyword splat - is expected to eq 0 - when both pairs are explicit pairs - is expected to eq 0 - when using hash rocket delimiters - when both keys are on the same line - when second pair is a keyword splat - is expected to eq 0 - when both pairs are explicit pairs - is expected to eq 0 - when receiver key is ahead - when second pair is a keyword splat - is expected to eq 0 - when both pairs are explicit pairs - is expected to eq 2 - 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 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 receiver key is behind - when second pair is a keyword splat - is expected to eq -2 - when both pairs are explicit pairs - is expected to eq -2 - when receiver key is ahead - when both pairs are explicit pairs - is expected to eq 2 - when second pair is a keyword splat - is expected to eq 2 - when both keys are on the same line - when second pair is a keyword splat - is expected to eq 0 - when both pairs are explicit pairs - is expected to eq 0 - when keys are aligned - when both keys are explicit keys - is expected to eq 0 - when second key is a keyword splat - is expected to eq 0 - when using colon delimiters - when receiver key is behind - when both pairs are reail pairs - is expected to eq -2 - when second pair is a keyword splat - is expected to eq -2 - when receiver key is ahead - when both pairs are explicit pairs - is expected to eq 2 - when second pair is a keyword splat - is expected to eq 2 - when keys are aligned - when both pairs are explicit pairs - is expected to eq 0 - when second pair is a keyword splat - is expected to eq 0 - when both keys are on the same line - when second pair is a keyword splat - is expected to eq 0 - when both pairs are explicit pairs - is expected to eq 0 - #value_omission? - when not using hash value omission - is expected not to be value omission - when using hash value omission - is expected to be value omission - #value_on_new_line? - when pair is on a single line - is expected not to be value on new line - when value starts on a new line - is expected to be value on new line - when value spans multiple lines - is expected not to be value on new line - #hash_rocket? - when using a hash rocket delimiter - is expected to be hash rocket - when using a colon delimiter - is expected not to be hash rocket - .new - is expected to be a kind of RuboCop::AST::PairNode - #same_line? - when both pairs are on the same line - when both pairs are explicit pairs - is expected to be same line s(:pair, - s(:sym, :b), - s(:int, 2)) - when both pair is a keyword splat - is expected to be same line s(:kwsplat, - s(:send, nil, :foo)) - when a multiline pair shares the same line - when both pairs are explicit pairs - is expected to be same line s(:pair, - s(:sym, :b), - s(:int, 2)) - is expected to be same line s(:pair, - s(:sym, :a), - s(:begin)) - when 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 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)) - #value_delta - when using hash rocket delimiters - when receiver value is ahead - is expected to eq 2 - when both pairs are on the same line - is expected to eq 0 - when receiver value is behind - 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 using colon delimiters - when receiver value is behind - is expected to eq -2 - when receiver value is ahead - is expected to eq 2 - when both pairs are on the same line - is expected to eq 0 - 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 - -RuboCop::AST::BlockNode - #arguments - with a single splat argument - is expected to eq 1 - with no arguments - is expected to be empty - with a single literal argument - is expected to eq 1 - >= Ruby 2.7 - using numbered parameters - is expected to be empty - with destructured arguments - is expected to eq 2 - with multiple mixed arguments - is expected to eq 2 - #delimiters - when enclosed in braces - is expected to eq ["{", "}"] - when enclosed in do-end keywords - is expected to eq ["do", "end"] - #multiline? - when block is on a single line - is expected not to be multiline - when block is on several lines - is expected to be multiline - #arguments? - with a single argument - is expected to be arguments - >= Ruby 2.7 - using numbered parameters - is expected not to be arguments - with destructuring arguments - is expected to be arguments - 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 - #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 - #receiver - with dot operator call - is expected to eq "foo" - with safe navigation operator call - is expected to eq "foo" - #keywords? - when enclosed in do-end keywords - is expected to be keywords - when enclosed in braces - is expected not to be keywords - #braces? - when enclosed in braces - is expected to be braces - when enclosed in do-end keywords - is expected not to be braces - #lambda? - when block belongs to a non-lambda method - is expected not to be lambda - when block belongs to a stabby lambda - is expected to be lambda - when block belongs to a method lambda - is expected to be lambda - #single_line? - when block is on a single line - is expected to be single line - when block is on several lines - is expected not to be single line - #closing_delimiter - when enclosed in do-end keywords - is expected to eq "end" - when enclosed in braces - is expected to eq "}" - .new - is expected to be a kind of RuboCop::AST::BlockNode - #opening_delimiter - when enclosed in braces - is expected to eq "{" - when enclosed in do-end keywords - is expected to eq "do" - #argument_list - with no arguments - is expected to be empty - all argument types - is expected to eq [:a, :b, :c, :d, :e, :f, :g, :h, :i] - >= Ruby 2.7 - using numbered parameters - with skipped params - is expected to eq [:_1, :_2, :_3, :_4, :_5, :_6, :_7] - with sequential params - is expected to eq [:_1, :_2] - -RuboCop::AST::AsgnNode - #expression - with a `cvasgn` node - is expected to eq s(:send, nil, :value) - 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 `lvasgn` node - is expected to eq s(:send, nil, :value) - .new - with a `ivasgn` node - is expected to be a kind of RuboCop::AST::AsgnNode - with a `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 - #name - with a `gvasgn` node - is expected to eq :$var - with a `cvasgn` node - is expected to eq :@@var - with a `lvasgn` node - is expected to eq :var - with a `ivasgn` node - is expected to eq :@var - -RuboCop::AST::ClassNode - #body - with an empty body - is expected to be nil - with a multi-expression body - is expected to be begin type - with a single expression body - is expected to be send type - #identifier - is expected to be const type - #parent_class - when no parent class is specified - is expected to be nil - when a parent class is specified - is expected to be const type - .new - is expected to be a kind of RuboCop::AST::ClassNode - -RuboCop::AST::CasgnNode - .new - with a `casgn` node - is expected to be a kind of RuboCop::AST::CasgnNode - #expression - is expected to eq s(:send, nil, :value) - #name - is expected to eq :VAR - #namespace - when the parent is a `const` - is expected to eq s(:const, nil, :FOO) - when there is no parent - is expected to be nil - when the parent is a `cbase` - is expected to eq s(:cbase) - -RuboCop::AST::IfNode - #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 - #elsif_conditional? - with one elsif conditional - is expected to be elsif conditional - with multiple elsif conditionals - is expected to be elsif conditional - with nested conditionals in else clause - is expected not to be elsif conditional - with nested conditionals in if clause - is expected not to be elsif conditional - with nested ternary operators - when nested in the falsey branch - is expected not to be elsif conditional - when nested in the truthy branch - is expected not to be elsif conditional - #if? - with an unless statement - is expected not to be if - with an if statement - is expected to be if - with a ternary operator - is expected not to be if - #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 elsif statement - is expected to all be literal - is expected to eq 3 - with an else statement - is expected to all be literal - is expected to eq 2 - with an unless statement - is expected to all be literal - is expected to eq 1 - #keyword - with an unless statement - is expected to eq "unless" - with a ternary operator - is expected to eq "" - with an if statement - is expected to eq "if" - #each_branch - when not passed a block - is expected to be a kind of Enumerator - when passed a block - yields all the branches - #unless? - with an unless statement - is expected to be unless - with a ternary operator - is expected not to be unless - with an if statement - is expected not to be unless - .new - with a modifier statement - is expected to be a kind of RuboCop::AST::IfNode - with a regular if statement - is expected to be a kind of RuboCop::AST::IfNode - with a ternary operator - is expected to be a kind of RuboCop::AST::IfNode - #modifier_form? - with a non-modifier if statement - is expected not to be 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 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 "" - #ternary? - with a ternary operator - is expected to be ternary - with an unless statement - is expected not to be ternary - with an if statement - is expected not to be ternary - #else? - without an else statement - is expected not to be elsif - with an elsif statement - is expected to be else - #nested_conditional? - with nested conditionals in elsif 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 else clause - is expected to be nested conditional - with no nested conditionals - is expected not to be nested conditional - with nested conditionals in if clause - is expected to be nested conditional - #if_branch - with a ternary operator - is expected to be sym type - with an unless statement - is expected to be sym type - with an if statement - is expected to be sym type - #else_branch - with an if statement - is expected to be int type - with a ternary operator - is expected to be int type - with an unless statement - is expected to be int type - -RuboCop::AST::FloatNode - #value - is expected to eq 1.5 - .new - is expected to be a kind of RuboCop::AST::FloatNode - #sign? - explicit positive float - is expected to be sign - explicit negative float - is expected to be sign - -RuboCop::AST::HashNode - #pairs - with a hash of literals - is expected to all be pair type - is expected to eq 3 - with an empty hash - is expected to be empty - with a hash of variables - is expected to all be pair type - is expected to eq 2 - #each_value - when not passed a block - is expected to be a kind of Enumerator - when passed a block - yields all the pairs - .new - is expected to be a kind of RuboCop::AST::HashNode - #keys - with a hash with string keys - is expected to all be str type - is expected to eq 2 - with a hash with symbol keys - is expected to all be sym type - is expected to eq 3 - with an empty hash - is expected to be empty - #each_key - when not passed a block - is expected to be a kind of Enumerator - when passed a block - yields all the pairs - #braces? - with braces - is expected to be braces - as an argument with braces - is expected to be braces - as an argument with no braces - is expected not to be braces - #mixed_delimiters? - when all pairs are using a colon delimiter - is expected not to be mixed delimiters - when pairs are using different delimiters - is expected to be mixed delimiters - when all pairs are using a hash rocket delimiter - is expected not to be mixed delimiters - #each_pair - when passed a block - yields all the pairs - when not passed a block - is expected to be a kind of Enumerator - #pairs_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 - #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 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 - with a hash with string keys - is expected to eq 2 - is expected to all be send type - -RuboCop::AST::IntNode - #sign? - explicit positive int - is expected to be sign - explicit negative int - is expected to be sign - #value - is expected to eq 10 - .new - is expected to be a kind of RuboCop::AST::IntNode - -RuboCop::AST::KeywordSplatNode - #hash_rocket? - is expected not to be hash rocket - #key_delta - with alignment set to :left - when using colon delimiters - when keyword splat is ahead - is expected to eq 2 - when keyword splat is on the same line - is expected to eq 0 - when keyword splat is behind - is expected to eq -2 - when keyword splat is aligned - is expected to eq 0 - when using hash rocket delimiters - when keyword splat is aligned - is expected to eq 0 - when keyword splat is ahead - is expected to eq 2 - when keyword splat is on the same line - is expected to eq 0 - when keyword splat is behind - is expected to eq -2 - with alignment set to :right - when using colon delimiters - when keyword splat is behind - is expected to eq 0 - when keyword splat is aligned - is expected to eq 0 - when keyword splat is ahead - is expected to eq 0 - when keyword splat is on the same line - is expected to eq 0 - when using hash rocket delimiters - when keyword splat is behind - is expected to eq 0 - 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 0 - #value_delta - when using hash rocket delimiters - when keyword splat is left aligned - is expected to eq 0 - when keyword splat is ahead - is expected to eq 0 - when keyword splat is on the same line - is expected to eq 0 - when keyword splat is behind - is expected to eq 0 - when using colon delimiters - when keyword splat is behind - is expected to eq 0 - when keyword splat is on the same line - is expected to eq 0 - when keyword splat is ahead - is expected to eq 0 - when keyword splat is left aligned - is expected to eq 0 - #key - is expected to eq s(:kwsplat, - s(:send, nil, :foo)) - #colon? - is expected not to be colon - #value - is expected to eq s(:kwsplat, - s(:send, nil, :foo)) - #same_line? - when pairs are on separate lines - is expected not to be same line s(:kwsplat, - s(:send, nil, :foo)) - when a multiline pair shares the same line - is expected to be same line s(:pair, - s(:sym, :a), - s(:begin)) - is expected to be same line s(:kwsplat, - s(:send, nil, :foo)) - when both pairs are on the same line - is expected to be same line s(:kwsplat, - s(:send, nil, :foo)) - .new - is expected to be a kind of RuboCop::AST::KeywordSplatNode - #operator - is expected to eq "**" - -RuboCop::AST::OrAsgnNode - .new - is expected to be a kind of RuboCop::AST::OrAsgnNode - #name - is expected to eq :var - #operator - is expected to eq :"||" - #expression - is expected to eq s(:send, nil, :value) - #assignment_node - is expected to be a kind of RuboCop::AST::AsgnNode - RuboCop::AST::RegexpNode - #interpolation? - with regexp quote - is expected to be interpolation - with direct variable interpoation - is expected to be interpolation - with no interpolation returns false - is expected not to be interpolation - #no_encoding? - with n and other options - is expected to be no encoding - with other options - is expected not to be no encoding + #percent_r_literal? + with multi-line %r{-delimiters + is expected to be percent r literal + with %r{-delimiters + is expected to be percent r literal + with %r/-delimiters + is expected to be percent r literal + with %r<-delimiters + is expected to be percent r literal + with /-delimiters + is expected not to be percent r literal + #fixed_encoding? + with u and other options + is expected to be fixed encoding with no options - is expected not to be no encoding - with only n option - is expected to be no encoding - #options - 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 - with a regexp with single option - is expected to eq 1 - with a regexp with "o" option - is expected to eq 0 - #single_interpolation? - with o and other options - is expected to be single interpolation + is expected not to be fixed encoding + with only u option + is expected to be fixed encoding with other options - is expected not to be single interpolation - with no options - is expected not to be single interpolation - with only o option - is expected to be single interpolation - #content - with a multi-line regexp with option - is expected to eq "\n.+\n" - with an empty regexp - is expected to eq "" - with a regexp with option - is expected to eq ".+" - with an empty regexp with option - is expected to eq "" - with a multi-line regexp without option - is expected to eq "\n.+\n" - with a regexp without option - is expected to eq ".+" + is expected not to be fixed encoding #to_regexp - with a regexp with option - is expected to eq /.+/mix with an empty regexp with option is expected to eq //ix - with a regexp without option - is expected to eq /.+/ - with a regexp with an "n" option - is expected to eq "/abc/n" - with an empty regexp - is expected to eq // - with a regexp with an "u" option - is expected to eq "/abc/" - with a multi-line regexp without option + with a multi-line regexp with option is expected to eq / .+ -/ +/ix with a regexp with an "o" option is expected to eq "/abc/i" - with a multi-line regexp with option + with a multi-line regexp without option is expected to eq / .+ -/ix - #ignore_case? - with i and other options - is expected to be ignore case - with only i option - is expected to be ignore case - with no options - is expected not to be ignore case - with other options - is expected not to be ignore case - #slash_literal? - with /-delimiters - is expected to be slash literal - with %r{-delimiters - is expected not to be slash literal - with %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 an empty regexp + is expected to eq // + with a regexp with an "u" option + is expected to eq "/abc/" + with a regexp with an "n" option + is expected to eq "/abc/n" + with a regexp without option + is expected to eq /.+/ + with a regexp with option + is expected to eq /.+/mix #extended? + with other options + is expected not to be extended + with no options + is expected not to be extended with only x option is expected to be extended with x and other options is expected to be extended - with no options - is expected not to be extended - with other options - is expected not to be extended + #options + with a regexp without option + is expected to eq 0 + with a regexp with "o" option + is expected to eq 0 + with an empty regexp + is expected to eq 0 + with a regexp with single option + is expected to eq 1 + with a regexp with multiple options + is expected to eq 3 #delimiter? - with %r<-delimiters - 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{" - 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" - with /-delimiters is expected to be delimiter "/" + is expected not to be delimiter "%" is expected not to be delimiter "{" + is expected not to be delimiter "%r" + is expected not to be delimiter "%r/" + is expected not to be delimiter "r" with multi-line %r{-delimiters + is expected not to be delimiter "%r" is expected to be delimiter "{" - is expected not to be delimiter "%r{" is expected not to be delimiter "r" - is expected not to be delimiter "%r/" - is expected not to be delimiter "%r" is expected to be delimiter "}" - is expected not to be delimiter "/" is expected not to be delimiter "%" + is expected not to be delimiter "/" + is expected not to be delimiter "%r/" + is expected not to be delimiter "%r{" 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 to be delimiter "{" is expected not to be delimiter "%r{" is expected to be delimiter "}" - is expected not to be delimiter "%" is expected not to be delimiter "%r/" - is expected not to be delimiter "%r" - with %r/-delimiters + is expected not to be delimiter "%" + with %r<-delimiters + 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 "/" 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 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" - #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 + with /-delimiters + is expected to be delimiter "/" + is expected not to be delimiter "{" #delimiters + with %r{-delimiters + is expected to eq ["{", "}"] with multi-line %r{-delimiters is expected to eq ["{", "}"] with %r<-delimiters is expected to eq ["<", ">"] - with /-delimiters - is expected to eq ["/", "/"] with %r/-delimiters is expected to eq ["/", "/"] - with %r{-delimiters - is expected to eq ["{", "}"] + with /-delimiters + is expected to eq ["/", "/"] + #ignore_case? + with other options + is expected not to be ignore case + with no options + is expected not to be ignore case + with only i option + is expected to be ignore case + with i and other options + is expected to be ignore case + #interpolation? + with regexp quote + is expected to be interpolation + with no interpolation returns false + is expected not to be interpolation + with direct variable interpoation + is expected to be interpolation #multiline_mode? - with m and other options - is expected to be multiline mode + with no options + is expected not to be multiline mode + with other options + is expected not to be multiline mode with only m option is expected to be multiline mode + with m and other options + is expected to be multiline mode + #content + with a multi-line regexp without option + is expected to eq "\n.+\n" + with a regexp with option + is expected to eq ".+" + with a regexp without option + is expected to eq ".+" + with an empty regexp with option + is expected to eq "" + with an empty regexp + is expected to eq "" + with a multi-line regexp with option + is expected to eq "\n.+\n" + #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 + #no_encoding? + with no options + is expected not to be no encoding + with n and other options + is expected to be no encoding with other options - is expected not to be multiline mode + is expected not to be no encoding + with only n option + is expected to be no encoding + #single_interpolation? with no options - is expected not to be multiline mode + is expected not to be single interpolation + with o and other options + is expected to be single interpolation + with only o option + is expected to be single interpolation + with other options + is expected not to be single interpolation #regopt - with a regexp with option - is expected to be regopt type - is expected to eq [:i, :m, :x] - with a multi-line regexp without option - is expected to be regopt type - is expected to be empty - with an empty regexp with option - is expected to eq [:i, :x] - is expected to be regopt type with an empty regexp is expected to be regopt type is expected to be empty with a multi-line regexp with option + is expected to be regopt type is expected to eq [:i, :m, :x] + with a regexp with option + is expected to eq [:i, :m, :x] + is expected to be regopt type + with a multi-line regexp without option + is expected to be empty is expected to be regopt type with a regexp without option + is expected to be regopt type is expected to be empty + with an empty regexp with option is expected to be regopt type - #percent_r_literal? - with /-delimiters - is expected not to be percent r literal - with %r<-delimiters - is expected to be percent r literal - with %r/-delimiters - is expected to be percent r literal - with multi-line %r{-delimiters - is expected to be percent r literal - with %r{-delimiters - is expected to be percent r literal + is expected to eq [:i, :x] .new is expected to be a kind of RuboCop::AST::RegexpNode -RuboCop::AST::NextNode +RuboCop::AST::ForwardArgsNode + when using Ruby 2.7 or newer + #to_a + is expected to contain exactly (be forward arg type) + +RuboCop::AST::RangeNode + .new + with an infinite range + is expected to be range type + is expected to be a kind of RuboCop::AST::RangeNode + with a beignless 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 exclusive range + is expected to be a kind of RuboCop::AST::RangeNode + is expected to be range type + +RuboCop::AST::ReturnNode behaves like wrapped arguments node .new without arguments - is expected to be a kind of RuboCop::AST::NextNode + is expected to be a kind of RuboCop::AST::ReturnNode with arguments - is expected to be a kind of RuboCop::AST::NextNode + is expected to be a kind of RuboCop::AST::ReturnNode #arguments - with no arguments - is expected to be empty + with a single argument and braces + is expected to eq 1 with no arguments and braces is expected to be empty + with no arguments + 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 multiple literal arguments is expected to eq 2 + +RuboCop::AST::NextNode + behaves like wrapped arguments node + #arguments + with no arguments and braces + is expected to be empty + with a single argument + is expected to eq 1 + with no arguments + is expected to be empty with a single splat argument is expected to eq 1 with a single argument and braces is expected to eq 1 + with multiple literal arguments + is expected to eq 2 + .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::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::RangeNode +RuboCop::AST::CaseNode .new - with a beignless range - is expected to be a kind of RuboCop::AST::RangeNode - is expected to be range type - with an infinite range - is expected to be 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 + is expected to be a kind of RuboCop::AST::CaseNode + #else? + without an else statement + is expected not to be else + with an else statement + is expected to be else + #else_branch + #else? + with an 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 + #keyword + is expected to eq "case" + #when_branches + is expected to all be when type + is expected to eq 3 + #branches + when compared to an IfNode + returns the same + when there is no else keyword + returns only then when bodies + when there is an else + returns all the bodies + with an empty else + returns all the bodies + #each_when + when not passed a block + is expected to be a kind of Enumerator + when passed a block + yields all the conditions -RuboCop::AST::OpAsgnNode - #expression - is expected to eq s(:send, nil, :value) - #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 :% - #name - is expected to eq :var +RuboCop::AST::IfNode + #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 one elsif conditional + is expected 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 + with nested conditionals in if clause + is expected not to be elsif conditional + #ternary? + with an if statement + is expected not to be ternary + with a ternary operator + is expected to be ternary + with an unless statement + is expected not to be ternary .new - with an `op_asgn_node` node - is expected to be a kind of RuboCop::AST::OpAsgnNode - #assignment_node - is expected to be a kind of RuboCop::AST::AsgnNode + with a ternary operator + is expected to be a kind of RuboCop::AST::IfNode + with a regular if statement + is expected to be a kind of RuboCop::AST::IfNode + with a modifier statement + is expected to be a kind of RuboCop::AST::IfNode + #elsif? + without an elsif statement + is expected not to be elsif + with an if statement comtaining an elsif + is expected not to be elsif + with an elsif statement + is expected to be elsif + #unless? + with an if statement + is expected not to be unless + with an unless statement + is expected to be unless + with a ternary operator + is expected not to be unless + #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 + #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 "" + #if_branch + with an unless statement + is expected to be sym type + with an if statement + is expected to be sym type + with a ternary operator + is expected to be sym type + #else? + with an elsif statement + is expected to be else + without an else statement + is expected not to be elsif + #branches + with a ternary operator + is expected to eq 2 + is expected to all be literal + with an else statement + is expected to all be literal + is expected to eq 2 + with an elsif statement + is expected to eq 3 + is expected to all be literal + with an unless statement + is expected to eq 1 + is expected to all be literal + with an if statement + is expected to all be literal + is expected to eq 1 + #each_branch + when not passed a block + is expected to be a kind of Enumerator + when passed a block + yields all the branches + #keyword + with an unless statement + is expected to eq "unless" + with a ternary operator + is expected to eq "" + with an if statement + is expected to eq "if" + #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 modifier if statement + is expected to be modifier form + with a modifier unless statement + is expected to be modifier form + with a non-modifier unless statement + is expected not to be modifier form + #if? + with a ternary operator + is expected not to be if + with an unless statement + is expected not to be if + with an if statement + is expected to be if + #nested_conditional? + with nested ternary operators + when nested in the falsey branch + is expected to be nested conditional + when nested in the truthy branch + is expected to be nested conditional + with nested conditionals in elsif clause + is expected to be nested conditional + with no nested conditionals + is expected not to be nested conditional + with nested conditionals in if clause + is expected to be nested conditional + with nested conditionals in else clause + is expected to be nested conditional -RuboCop::AST::StrNode - #character_literal? - with a normal string literal - is expected not to be character literal - with a character literal - is expected to be character literal - with a heredoc - is expected not to be character literal +RuboCop::AST::ModuleNode .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 - #heredoc? - with a normal string - is expected not to be heredoc - with a heredoc - is expected to be heredoc - with a string with interpolation - is expected not to be heredoc - -RuboCop::AST::ForwardArgsNode - when using Ruby 2.7 or newer - #to_a - is expected to contain exactly (be forward arg type) - -RuboCop::AST::SelfClassNode + is expected to be a kind of RuboCop::AST::ModuleNode + #identifier + is expected to be const type #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 - #identifier - is expected to be self type + with a multi-expression body + is expected to be begin type + +RuboCop::AST::InPatternNode + when using Ruby 2.7 or newer + #body + without a then keyword + is expected to be array type + with a then keyword + is expected to be sym type + #branch_index + is expected to eq 0 + is expected to eq 2 + is expected to eq 1 + #then? + without a then keyword + is expected not to be then + with a then keyword + is expected to be then + .new + is expected to be a kind of RuboCop::AST::InPatternNode + #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 variable pattern + is expected to be match var type + with an alternative pattern + is expected to be match alt type + with a value pattern + is expected to be int type + with an as pattern + is expected to be match as type + with a pin operator + is expected to be pin type + +RuboCop::AST::ProcessedSource + #start_with? + with present source + returns false when passed string that does not start source + returns true when passed string that starts source + with blank source + returns false + #[] + 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 + #lines + contains lines as string without linefeed + has same number of elements as line count + is an array + #file_path + returns file path + .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 + #buffer + is a source buffer + #first_token_of + returns first token for node + accepts Node as an argument + valid_syntax? + when the source is valid but has some warning diagnostics + returns true + when the source itself is valid encoding but includes strange encoding literals that are accepted by MRI + returns true + when the source is invalid + returns false + when the source could not be parsed due to encoding error + returns false + when a line starts with an integer literal + tokenizes the source correctly + when the source is completely valid + returns true + #blank? + with source with content + returns false + with source of no content + returns true + #parser_error + when the source was properly parsed + is nil + when the source could not be parsed due to encoding error + returns the error + when the source lacks encoding comment and is really utf-8 encoded but has been read as US-ASCII + is nil + #path + is the path passed to .new + token enumerables + #each_token + yields all tokens + #find_token + yields correct token + yields nil when there is no match + #tokens_within + returns tokens for node + accepts Node as an argument + when heredoc as argument is present + returns tokens for node after heredoc + returns tokens for node before heredoc + returns tokens for heredoc node + #comments + is an array of comments + when the source is invalid + returns [] + #tokens + has an array of tokens + #preceding_line + returns source of line before token + #following_line + returns source of line after token + #ast + is the root node of AST + with heavily commented source + #find_comment + yields nil when there is no match + yields correct comment + #comment_at_line + returns the comment at the given line number + returns nil if line has no comment + #contains_comment? + provided a multiline source_range with at least one line with comment + is expected to equal true + provided source_range on line with comment + is expected to equal true + provided source_range on comment line + is expected to equal true + provided source_range on line without comment + is expected to equal false + #comments_before_line + returns comments on or before given line + #each_comment_in_lines + yields the comments + #each_comment + yields all comments + #line_with_comment? + returns false for lines without comments + returns true for lines with comments + #last_token_of + returns last token for node + accepts Node as an argument + +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 + #operator + with a logical and node + is expected to eq "&&" + with a semantic and node + is expected to eq "and" + #rhs + with a semantic and node + is expected to be int type + with a logical and node + is expected to be int type .new - is expected to be a kind of RuboCop::AST::SelfClassNode + with a logical and node + is expected to be a kind of RuboCop::AST::AndNode + with a semantic and node + is expected to be a kind of RuboCop::AST::AndNode + #lhs + with a 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 + #inverse_operator + with a semantic and node + is expected to eq "or" + with a logical and node + is expected to eq "||" + #alternate_operator + with a logical and node + is expected to eq "and" + with a semantic and node + is expected to eq "&&" + +RuboCop::AST::NodePattern::Parser + sequences + generates specialized nodes + parses function calls + parses unions of literals as a set + 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 + #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 + #each_in_pattern + when not passed a block + is expected to be a kind of Enumerator + when passed a block + yields all the conditions + #else? + with an else statement + is expected to be else + without an else statement + is expected not to be else + #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 + .new + is expected to be a kind of RuboCop::AST::CaseMatchNode + #in_pattern_branches + is expected to all be in pattern type + is expected to eq 3 + #keyword + is expected to eq "case" RuboCop::AST::WhenNode - #then? - with a then keyword - is expected to be then - without a then keyword - is expected not to be then #each_condition - when not passed a block - is expected to be a kind of Enumerator when passed a block yields all the conditions + when not passed a block + is expected to be a kind of Enumerator #conditions - with a single condition - is expected to all be literal - is expected to eq 1 with a multiple conditions is expected to all be literal is expected to eq 3 + with a single condition + is expected to all be literal + is expected to eq 1 #branch_index is expected to eq 1 - is expected to eq 2 is expected to eq 0 - #body - with a then keyword - is expected to be sym type + is expected to eq 2 + #then? without a then keyword - is expected to be array type + is expected not to be then + with a then keyword + is expected to be then .new is expected to be a kind of RuboCop::AST::WhenNode + #body + without a then keyword + is expected to be array type + with a then keyword + is expected to be sym type -RuboCop::AST::WhileNode +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::IntNode .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? - with a do keyword - is expected to be do - without a do keyword - is expected not to be do - #post_condition_loop? - with a statement while - is expected not to be post condition loop - with a modifier while - is expected to be post condition loop - #inverse_keyword - is expected to eq "until" - #keyword - is expected to eq "while" - #loop_keyword? - with a statement while - is expected to be loop keyword - with a modifier while - is expected to be loop keyword + is expected to be a kind of RuboCop::AST::IntNode + #sign? + explicit negative int + is expected to be sign + explicit positive int + is expected to be sign + #value + is expected to eq 10 -RuboCop::AST::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 +RuboCop::AST::ResbodyNode .new - with a modifier until - is expected to be a kind of RuboCop::AST::UntilNode - with a statement until - is expected to be a kind of RuboCop::AST::UntilNode - #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" - #loop_keyword? - with a modifier until - is expected to be loop keyword - with a statement until - is expected to be loop keyword + is expected to be a kind of RuboCop::AST::ResbodyNode + #body + is expected to be sym type + #exceptions + with a single exception + is expected to all be const type + is expected to eq 1 + with multiple exceptions + is expected to all be const type + is expected to eq 2 + without exception + is expected to eq 0 + #exception_variable + when an exception variable is not given + is expected to be nil + for an explicit rescue + is expected to eq "ex" + for an implicit rescue + is expected to eq "ex" + #branch_index + is expected to eq 0 + is expected to eq 1 + is expected to eq 2 -Finished in 3.37 seconds (files took 1.32 seconds to load) +Finished in 9.22 seconds (files took 3.73 seconds to load) 2392 examples, 0 failures -Randomized with seed 22326 +Randomized with seed 29460 ┌──────────────────────────────────────────────────────────────────────────────┐ @@ -6616,12 +6652,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/8405/tmp/hooks/B01_cleanup starting +I: user script /srv/workspace/pbuilder/8405/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/102872 and its subdirectories -I: Current time: Fri Jan 30 22:06:56 -12 2026 -I: pbuilder-time-stamp: 1769854016 +I: removing directory /srv/workspace/pbuilder/8405 and its subdirectories +I: Current time: Sun Dec 29 17:47:46 +14 2024 +I: pbuilder-time-stamp: 1735444066