reek 6.0.2 → 6.1.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (241) hide show
  1. checksums.yaml +4 -4
  2. data/.github/dependabot.yml +9 -0
  3. data/.github/workflows/ruby.yml +57 -0
  4. data/.rubocop.yml +5 -3
  5. data/.rubocop_todo.yml +6 -4
  6. data/CHANGELOG.md +30 -0
  7. data/CONTRIBUTING.md +3 -0
  8. data/Dockerfile +1 -1
  9. data/Gemfile +7 -7
  10. data/README.md +1 -1
  11. data/bin/code_climate_reek +2 -3
  12. data/lib/reek/ast/ast_node_class_map.rb +1 -1
  13. data/lib/reek/ast/node.rb +1 -1
  14. data/lib/reek/ast/sexp_extensions/arguments.rb +11 -0
  15. data/lib/reek/ast/sexp_extensions/case.rb +1 -1
  16. data/lib/reek/ast/sexp_extensions/if.rb +1 -1
  17. data/lib/reek/ast/sexp_extensions/send.rb +1 -1
  18. data/lib/reek/cli/command/todo_list_command.rb +1 -1
  19. data/lib/reek/cli/options.rb +1 -1
  20. data/lib/reek/code_comment.rb +22 -17
  21. data/lib/reek/configuration/excluded_paths.rb +2 -1
  22. data/lib/reek/context/code_context.rb +1 -1
  23. data/lib/reek/context/module_context.rb +4 -0
  24. data/lib/reek/context/refinement_context.rb +16 -0
  25. data/lib/reek/context/send_context.rb +6 -0
  26. data/lib/reek/context_builder.rb +17 -3
  27. data/lib/reek/rake/task.rb +1 -1
  28. data/lib/reek/report/code_climate/code_climate_formatter.rb +1 -3
  29. data/lib/reek/smell_detectors/base_detector.rb +1 -1
  30. data/lib/reek/smell_detectors/unused_private_method.rb +1 -0
  31. data/lib/reek/smell_warning.rb +1 -1
  32. data/lib/reek/source/source_locator.rb +1 -3
  33. data/lib/reek/spec/should_reek_of.rb +6 -4
  34. data/lib/reek/version.rb +2 -2
  35. data/reek.gemspec +28 -25
  36. metadata +10 -237
  37. data/.travis.yml +0 -40
  38. data/docs/API.md +0 -174
  39. data/docs/Attribute.md +0 -39
  40. data/docs/Basic-Smell-Options.md +0 -85
  41. data/docs/Boolean-Parameter.md +0 -54
  42. data/docs/Class-Variable.md +0 -40
  43. data/docs/Code-Smells.md +0 -39
  44. data/docs/Command-Line-Options.md +0 -119
  45. data/docs/Control-Couple.md +0 -26
  46. data/docs/Control-Parameter.md +0 -32
  47. data/docs/Data-Clump.md +0 -46
  48. data/docs/Duplicate-Method-Call.md +0 -264
  49. data/docs/Feature-Envy.md +0 -93
  50. data/docs/How-To-Write-New-Detectors.md +0 -132
  51. data/docs/How-reek-works-internally.md +0 -114
  52. data/docs/Instance-Variable-Assumption.md +0 -163
  53. data/docs/Irresponsible-Module.md +0 -47
  54. data/docs/Large-Class.md +0 -16
  55. data/docs/Long-Parameter-List.md +0 -39
  56. data/docs/Long-Yield-List.md +0 -37
  57. data/docs/Manual-Dispatch.md +0 -30
  58. data/docs/Missing-Safe-Method.md +0 -92
  59. data/docs/Module-Initialize.md +0 -62
  60. data/docs/Nested-Iterators.md +0 -59
  61. data/docs/Nil-Check.md +0 -47
  62. data/docs/RSpec-matchers.md +0 -129
  63. data/docs/Rake-Task.md +0 -66
  64. data/docs/Reek-4-to-Reek-5-migration.md +0 -188
  65. data/docs/Reek-Driven-Development.md +0 -46
  66. data/docs/Repeated-Conditional.md +0 -47
  67. data/docs/Simulated-Polymorphism.md +0 -16
  68. data/docs/Smell-Suppression.md +0 -96
  69. data/docs/Style-Guide.md +0 -19
  70. data/docs/Subclassed-From-Core-Class.md +0 -79
  71. data/docs/Too-Many-Constants.md +0 -37
  72. data/docs/Too-Many-Instance-Variables.md +0 -43
  73. data/docs/Too-Many-Methods.md +0 -56
  74. data/docs/Too-Many-Statements.md +0 -54
  75. data/docs/Uncommunicative-Method-Name.md +0 -94
  76. data/docs/Uncommunicative-Module-Name.md +0 -92
  77. data/docs/Uncommunicative-Name.md +0 -18
  78. data/docs/Uncommunicative-Parameter-Name.md +0 -90
  79. data/docs/Uncommunicative-Variable-Name.md +0 -96
  80. data/docs/Unused-Parameters.md +0 -28
  81. data/docs/Unused-Private-Method.md +0 -101
  82. data/docs/Utility-Function.md +0 -56
  83. data/docs/Versioning-Policy.md +0 -7
  84. data/docs/YAML-Reports.md +0 -93
  85. data/docs/defaults.reek.yml +0 -129
  86. data/docs/templates/default/docstring/html/public_api_marker.erb +0 -3
  87. data/docs/templates/default/docstring/setup.rb +0 -37
  88. data/docs/templates/default/fulldoc/html/css/common.css +0 -1
  89. data/docs/yard_plugin.rb +0 -17
  90. data/features/command_line_interface/basic_usage.feature +0 -15
  91. data/features/command_line_interface/options.feature +0 -123
  92. data/features/command_line_interface/show_progress.feature +0 -33
  93. data/features/command_line_interface/smell_selection.feature +0 -15
  94. data/features/command_line_interface/smells_count.feature +0 -38
  95. data/features/command_line_interface/stdin.feature +0 -65
  96. data/features/configuration_files/accept_setting.feature +0 -87
  97. data/features/configuration_files/directory_specific_directives.feature +0 -274
  98. data/features/configuration_files/exclude_directives.feature +0 -35
  99. data/features/configuration_files/exclude_paths_directives.feature +0 -42
  100. data/features/configuration_files/masking_smells.feature +0 -94
  101. data/features/configuration_files/mix_accept_reject_setting.feature +0 -84
  102. data/features/configuration_files/reject_setting.feature +0 -89
  103. data/features/configuration_files/schema_validation.feature +0 -59
  104. data/features/configuration_files/show_configuration_file.feature +0 -44
  105. data/features/configuration_files/unused_private_method.feature +0 -68
  106. data/features/configuration_loading.feature +0 -91
  107. data/features/configuration_via_source_comments/erroneous_source_comments.feature +0 -68
  108. data/features/configuration_via_source_comments/well_formed_source_comments.feature +0 -116
  109. data/features/locales.feature +0 -32
  110. data/features/programmatic_access.feature +0 -41
  111. data/features/rake_task/rake_task.feature +0 -138
  112. data/features/reports/codeclimate.feature +0 -59
  113. data/features/reports/json.feature +0 -59
  114. data/features/reports/reports.feature +0 -219
  115. data/features/reports/yaml.feature +0 -52
  116. data/features/rspec_matcher.feature +0 -41
  117. data/features/samples.feature +0 -305
  118. data/features/step_definitions/.rubocop.yml +0 -5
  119. data/features/step_definitions/reek_steps.rb +0 -102
  120. data/features/step_definitions/sample_file_steps.rb +0 -63
  121. data/features/support/env.rb +0 -33
  122. data/features/todo_list.feature +0 -108
  123. data/samples/checkstyle.xml +0 -7
  124. data/samples/clean_source/clean.rb +0 -6
  125. data/samples/configuration/accepts_rejects_and_excludes_for_detectors.reek.yml +0 -29
  126. data/samples/configuration/accepts_rejects_and_excludes_for_directory_directives.reek.yml +0 -30
  127. data/samples/configuration/corrupt.reek +0 -1
  128. data/samples/configuration/empty.reek +0 -0
  129. data/samples/configuration/full_configuration.reek +0 -13
  130. data/samples/configuration/full_mask.reek +0 -6
  131. data/samples/configuration/home/home.reek.yml +0 -4
  132. data/samples/configuration/partial_mask.reek +0 -4
  133. data/samples/configuration/regular_configuration/.reek.yml +0 -4
  134. data/samples/configuration/regular_configuration/empty_sub_directory/.gitignore +0 -0
  135. data/samples/configuration/with_excluded_paths.reek +0 -5
  136. data/samples/no_config_file/.keep +0 -0
  137. data/samples/paths.rb +0 -5
  138. data/samples/smelly_source/inline.rb +0 -704
  139. data/samples/smelly_source/optparse.rb +0 -1788
  140. data/samples/smelly_source/redcloth.rb +0 -1130
  141. data/samples/smelly_source/ruby.rb +0 -368
  142. data/samples/smelly_source/smelly.rb +0 -7
  143. data/samples/source_with_exclude_paths/ignore_me/uncommunicative_method_name.rb +0 -5
  144. data/samples/source_with_exclude_paths/nested/ignore_me_as_well/irresponsible_module.rb +0 -2
  145. data/samples/source_with_exclude_paths/nested/uncommunicative_parameter_name.rb +0 -6
  146. data/samples/source_with_exclude_paths/nested/uncommunicative_variable_name.rb +0 -6
  147. data/samples/source_with_hidden_directories/.hidden/hidden.rb +0 -1
  148. data/samples/source_with_hidden_directories/not_hidden.rb +0 -1
  149. data/samples/source_with_non_ruby_files/gibberish +0 -1
  150. data/samples/source_with_non_ruby_files/python_source.py +0 -1
  151. data/samples/source_with_non_ruby_files/ruby.rb +0 -6
  152. data/spec/performance/reek/smell_detectors/runtime_speed_spec.rb +0 -15
  153. data/spec/quality/documentation_spec.rb +0 -41
  154. data/spec/quality/reek_source_spec.rb +0 -11
  155. data/spec/reek/ast/node_spec.rb +0 -211
  156. data/spec/reek/ast/object_refs_spec.rb +0 -83
  157. data/spec/reek/ast/reference_collector_spec.rb +0 -47
  158. data/spec/reek/ast/sexp_extensions_spec.rb +0 -498
  159. data/spec/reek/cli/application_spec.rb +0 -168
  160. data/spec/reek/cli/command/report_command_spec.rb +0 -44
  161. data/spec/reek/cli/command/todo_list_command_spec.rb +0 -86
  162. data/spec/reek/cli/options_spec.rb +0 -51
  163. data/spec/reek/cli/silencer_spec.rb +0 -28
  164. data/spec/reek/code_comment_spec.rb +0 -184
  165. data/spec/reek/configuration/app_configuration_spec.rb +0 -195
  166. data/spec/reek/configuration/configuration_file_finder_spec.rb +0 -230
  167. data/spec/reek/configuration/default_directive_spec.rb +0 -13
  168. data/spec/reek/configuration/directory_directives_spec.rb +0 -122
  169. data/spec/reek/configuration/excluded_paths_spec.rb +0 -16
  170. data/spec/reek/configuration/rake_task_converter_spec.rb +0 -33
  171. data/spec/reek/configuration/schema_validator_spec.rb +0 -165
  172. data/spec/reek/context/code_context_spec.rb +0 -192
  173. data/spec/reek/context/ghost_context_spec.rb +0 -60
  174. data/spec/reek/context/method_context_spec.rb +0 -72
  175. data/spec/reek/context/module_context_spec.rb +0 -55
  176. data/spec/reek/context/root_context_spec.rb +0 -12
  177. data/spec/reek/context/statement_counter_spec.rb +0 -24
  178. data/spec/reek/context_builder_spec.rb +0 -457
  179. data/spec/reek/detector_repository_spec.rb +0 -22
  180. data/spec/reek/documentation_link_spec.rb +0 -20
  181. data/spec/reek/errors/base_error_spec.rb +0 -13
  182. data/spec/reek/examiner_spec.rb +0 -309
  183. data/spec/reek/logging_error_handler_spec.rb +0 -24
  184. data/spec/reek/rake/task_spec.rb +0 -56
  185. data/spec/reek/report/code_climate/code_climate_configuration_spec.rb +0 -22
  186. data/spec/reek/report/code_climate/code_climate_fingerprint_spec.rb +0 -126
  187. data/spec/reek/report/code_climate/code_climate_formatter_spec.rb +0 -51
  188. data/spec/reek/report/code_climate/code_climate_report_spec.rb +0 -56
  189. data/spec/reek/report/html_report_spec.rb +0 -19
  190. data/spec/reek/report/json_report_spec.rb +0 -58
  191. data/spec/reek/report/location_formatter_spec.rb +0 -32
  192. data/spec/reek/report/progress_formatter_spec.rb +0 -68
  193. data/spec/reek/report/text_report_spec.rb +0 -89
  194. data/spec/reek/report/xml_report_spec.rb +0 -24
  195. data/spec/reek/report/yaml_report_spec.rb +0 -55
  196. data/spec/reek/report_spec.rb +0 -28
  197. data/spec/reek/smell_configuration_spec.rb +0 -56
  198. data/spec/reek/smell_detectors/attribute_spec.rb +0 -197
  199. data/spec/reek/smell_detectors/base_detector_spec.rb +0 -50
  200. data/spec/reek/smell_detectors/boolean_parameter_spec.rb +0 -93
  201. data/spec/reek/smell_detectors/class_variable_spec.rb +0 -106
  202. data/spec/reek/smell_detectors/control_parameter_spec.rb +0 -300
  203. data/spec/reek/smell_detectors/data_clump_spec.rb +0 -134
  204. data/spec/reek/smell_detectors/duplicate_method_call_spec.rb +0 -211
  205. data/spec/reek/smell_detectors/feature_envy_spec.rb +0 -295
  206. data/spec/reek/smell_detectors/instance_variable_assumption_spec.rb +0 -96
  207. data/spec/reek/smell_detectors/irresponsible_module_spec.rb +0 -226
  208. data/spec/reek/smell_detectors/long_parameter_list_spec.rb +0 -61
  209. data/spec/reek/smell_detectors/long_yield_list_spec.rb +0 -49
  210. data/spec/reek/smell_detectors/manual_dispatch_spec.rb +0 -75
  211. data/spec/reek/smell_detectors/missing_safe_method_spec.rb +0 -68
  212. data/spec/reek/smell_detectors/module_initialize_spec.rb +0 -77
  213. data/spec/reek/smell_detectors/nested_iterators_spec.rb +0 -333
  214. data/spec/reek/smell_detectors/nil_check_spec.rb +0 -100
  215. data/spec/reek/smell_detectors/repeated_conditional_spec.rb +0 -100
  216. data/spec/reek/smell_detectors/subclassed_from_core_class_spec.rb +0 -77
  217. data/spec/reek/smell_detectors/too_many_constants_spec.rb +0 -144
  218. data/spec/reek/smell_detectors/too_many_instance_variables_spec.rb +0 -132
  219. data/spec/reek/smell_detectors/too_many_methods_spec.rb +0 -54
  220. data/spec/reek/smell_detectors/too_many_statements_spec.rb +0 -90
  221. data/spec/reek/smell_detectors/uncommunicative_method_name_spec.rb +0 -78
  222. data/spec/reek/smell_detectors/uncommunicative_module_name_spec.rb +0 -78
  223. data/spec/reek/smell_detectors/uncommunicative_parameter_name_spec.rb +0 -147
  224. data/spec/reek/smell_detectors/uncommunicative_variable_name_spec.rb +0 -201
  225. data/spec/reek/smell_detectors/unused_parameters_spec.rb +0 -114
  226. data/spec/reek/smell_detectors/unused_private_method_spec.rb +0 -205
  227. data/spec/reek/smell_detectors/utility_function_spec.rb +0 -293
  228. data/spec/reek/smell_warning_spec.rb +0 -137
  229. data/spec/reek/source/source_code_spec.rb +0 -79
  230. data/spec/reek/source/source_locator_spec.rb +0 -166
  231. data/spec/reek/spec/should_reek_of_spec.rb +0 -153
  232. data/spec/reek/spec/should_reek_only_of_spec.rb +0 -91
  233. data/spec/reek/spec/should_reek_spec.rb +0 -52
  234. data/spec/reek/spec/smell_matcher_spec.rb +0 -87
  235. data/spec/reek/tree_dresser_spec.rb +0 -46
  236. data/spec/spec_helper.rb +0 -110
  237. data/tasks/configuration.rake +0 -18
  238. data/tasks/console.rake +0 -5
  239. data/tasks/reek.rake +0 -6
  240. data/tasks/rubocop.rake +0 -11
  241. data/tasks/test.rake +0 -32
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 83760bf0344db6b8f65cd5bbb6e57f90ee4e1b54c10edb3920821a517e6649cd
4
- data.tar.gz: 258214d9022fda0ecbe287c4313719472c30f056c1ff6ffd4f7ff023b255b199
3
+ metadata.gz: 2e1e79296b4eb0b93d7b6d7bc7b13704b6831765416cab19c729473d2fe135ea
4
+ data.tar.gz: f9a49ffd6ad47e308a617bafb0901d438617c863ff5279c867d5db8e9148c0e4
5
5
  SHA512:
6
- metadata.gz: 56c12a16cc200dd475d84a543fd9edf2ce888f550a5d4d22cbe813c3439ed0915263340d7c02654417666bcd728ee5e9ba976670cae46098293b58595589f36c
7
- data.tar.gz: 0f012f16ec237bdece4f797ea2977c0db5fa083df32ac86ce57b14911777eec0d832aff8e861df67c5cc80b847b0c3caf801a157b759724cc9f858ae4236ace9
6
+ metadata.gz: 3ea8856c9c0f32543af3bb336790d9875cdf385ed45d2609af219f1857931d1b15de7802386954caff9c68f5753657f138e2eb304ef4ae94edc0e7a0e7e4e070
7
+ data.tar.gz: 407628086e04a8d2972f1343a34d299e77d462b0236f18e8b4570a9b9dfcd290dc6d690be56c67e06c0fff95326e764254b70c127962f5a90914a73bae115aed
@@ -0,0 +1,9 @@
1
+ # Documentation for all configuration options:
2
+ # https://help.github.com/github/administering-a-repository/configuration-options-for-dependency-updates
3
+
4
+ version: 2
5
+ updates:
6
+ - package-ecosystem: "bundler"
7
+ directory: "/"
8
+ schedule:
9
+ interval: "daily"
@@ -0,0 +1,57 @@
1
+ # This workflow will download a prebuilt Ruby version, install dependencies and
2
+ # run tests with Rake
3
+ # For more information see: https://github.com/marketplace/actions/setup-ruby-jruby-and-truffleruby
4
+
5
+ name: CI
6
+
7
+ on:
8
+ push:
9
+ branches: [ master ]
10
+ pull_request:
11
+ branches: [ master ]
12
+ schedule:
13
+ - cron: '16 4 12 * *'
14
+
15
+ env:
16
+ CUCUMBER_PUBLISH_QUIET: true
17
+ RUBYOPTS: "--disable-did-you-mean"
18
+ jobs:
19
+ test:
20
+
21
+ runs-on: ubuntu-latest
22
+
23
+ strategy:
24
+ matrix:
25
+ ruby: [2.6, 2.7, "3.0", "3.1", jruby-9.3]
26
+
27
+ steps:
28
+ - uses: actions/checkout@v2
29
+ - name: Set up Ruby
30
+ uses: ruby/setup-ruby@v1
31
+ with:
32
+ ruby-version: ${{ matrix.ruby }}
33
+ bundler-cache: true
34
+ - name: Run specs
35
+ run: bundle exec rake test:spec
36
+ - name: Run performance tests
37
+ run: bundle exec rake test:performance
38
+ - name: Update default configuration
39
+ run: bundle exec rake configuration:update_default_configuration
40
+ - name: Run cucumber features
41
+ run: bundle exec rake test:features
42
+ - name: Run code quality specs
43
+ run: bundle exec rake test:quality
44
+
45
+ rubocop:
46
+
47
+ runs-on: ubuntu-latest
48
+
49
+ steps:
50
+ - uses: actions/checkout@v2
51
+ - name: Set up Ruby
52
+ uses: ruby/setup-ruby@v1
53
+ with:
54
+ ruby-version: 2.7
55
+ bundler-cache: true
56
+ - name: Run RuboCop
57
+ run: bundle exec rubocop -P
data/.rubocop.yml CHANGED
@@ -1,5 +1,9 @@
1
1
  inherit_from: .rubocop_todo.yml
2
2
 
3
+ inherit_mode:
4
+ merge:
5
+ - Exclude
6
+
3
7
  require:
4
8
  - rubocop-rspec
5
9
  - rubocop-performance
@@ -7,10 +11,8 @@ require:
7
11
  AllCops:
8
12
  Exclude:
9
13
  - 'samples/**/*'
10
- - 'tmp/**/*'
11
- - 'vendor/**/*'
12
14
  NewCops: enable
13
- TargetRubyVersion: 2.4
15
+ TargetRubyVersion: 2.6
14
16
 
15
17
  # Tables are nice
16
18
  Layout/HashAlignment:
data/.rubocop_todo.yml CHANGED
@@ -1,6 +1,6 @@
1
1
  # This configuration was generated by
2
2
  # `rubocop --auto-gen-config`
3
- # on 2020-08-19 19:02:50 UTC using RuboCop version 0.89.1.
3
+ # on 2021-01-03 18:17:11 UTC using RuboCop version 1.7.0.
4
4
  # The point is for the user to remove these configuration records
5
5
  # one by one as the offenses are removed from the code base.
6
6
  # Note that changes in the inspected code, or installation of new
@@ -13,22 +13,24 @@ Lint/MissingSuper:
13
13
  - 'lib/reek/smell_detectors/base_detector.rb'
14
14
 
15
15
  # Offense count: 2
16
+ # Configuration parameters: IgnoredPatterns.
17
+ # IgnoredPatterns: (?-mix:(exactly|at_least|at_most)\(\d+\)\.times)
16
18
  Lint/UnreachableLoop:
17
19
  Exclude:
18
20
  - 'spec/reek/ast/node_spec.rb'
19
21
 
20
22
  # Offense count: 2
21
- # Configuration parameters: IgnoredMethods.
23
+ # Configuration parameters: IgnoredMethods, CountRepeatedAttributes.
22
24
  Metrics/AbcSize:
23
25
  Max: 21
24
26
 
25
27
  # Offense count: 1
26
28
  # Configuration parameters: CountComments, CountAsOne.
27
29
  Metrics/ClassLength:
28
- Max: 161
30
+ Max: 170
29
31
 
30
32
  # Offense count: 13
31
- # Configuration parameters: CountComments, CountAsOne, ExcludedMethods.
33
+ # Configuration parameters: CountComments, CountAsOne, ExcludedMethods, IgnoredMethods.
32
34
  Metrics/MethodLength:
33
35
  Max: 16
34
36
 
data/CHANGELOG.md CHANGED
@@ -1,5 +1,35 @@
1
1
  # Change log
2
2
 
3
+ ## 6.1.1 (2022-04-20)
4
+
5
+ * (ydah) UnusedPrivateMethod to be detect use of methods via `Method#to_proc`
6
+
7
+ ## 6.1.0 (2022-01-14)
8
+
9
+ * (mvz) Drop support for Ruby 2.4 and 2.5
10
+ * (mvz) Support Ruby 3.0 and 3.1
11
+ * (mvz) Support argument forwarding after regular arguments
12
+
13
+ ## 6.0.6 (2021-08-12)
14
+
15
+ * (mvz) Remove explicit dependency on psych. This fixes an issue where
16
+ installing Reek would unintentionally pull in psych 4.0
17
+
18
+ ## 6.0.5 (2021-08-01)
19
+
20
+ * (dependabot) Loosen dependency on psych
21
+ * (Nicolás Ferrari) Fix bugs when used by codeclimate
22
+
23
+ ## 6.0.4 (2021-04-27)
24
+
25
+ * (Nicolás Ferrari) Add build-base to Dockerfile
26
+ * (Masataka Pocke Kuwabara and Daniel Santos Dantas) Reduce gem package size
27
+
28
+ ## 6.0.3 (2021-01-11)
29
+
30
+ * (mvz) Require parser 3.0
31
+ * (mvz) In a refinement, assign smells to the refined module or class
32
+
3
33
  ## 6.0.2 (2020-10-17)
4
34
 
5
35
  * (mvz) Loosen dependency on psych. This should resolve installation problems on
data/CONTRIBUTING.md CHANGED
@@ -27,6 +27,9 @@ version, Ruby platform (MRI, JRuby, etc.), operating system.
27
27
  Try to provide a minimal example that reproduces the issue.
28
28
  Extra kudos if you can write it as a failing test. :)
29
29
 
30
+ Make sure any code examples and output are properly formatted
31
+ using [code blocks](https://github.github.com/gfm/#fenced-code-blocks).
32
+
30
33
  ## Contributing features, bugfixes, documentation
31
34
 
32
35
  ### Getting started
data/Dockerfile CHANGED
@@ -11,7 +11,7 @@ ENV code_dir /code
11
11
  ENV app_dir /usr/src/app
12
12
  ENV user app
13
13
 
14
- RUN apk --update add git
14
+ RUN apk --update add git build-base
15
15
  ADD . ${app_dir}
16
16
 
17
17
  RUN adduser -u 9000 -D ${user}
data/Gemfile CHANGED
@@ -5,18 +5,18 @@ gemspec
5
5
  ruby RUBY_VERSION
6
6
 
7
7
  group :development do
8
- gem 'aruba', '~> 1.0'
8
+ gem 'aruba', '~> 2.0'
9
9
  gem 'codeclimate-engine-rb', '~> 0.4.0'
10
- gem 'cucumber', ['>= 4.0', '< 6.0']
10
+ gem 'cucumber', '>= 4.0', '< 8.0'
11
11
  gem 'kramdown', '~> 2.1'
12
12
  gem 'kramdown-parser-gfm', '~> 1.0'
13
13
  gem 'rake', '~> 13.0'
14
14
  gem 'rspec', '~> 3.0'
15
15
  gem 'rspec-benchmark', '~> 0.6.0'
16
- gem 'rubocop', '~> 0.93.0'
17
- gem 'rubocop-performance', '~> 1.8.0'
18
- gem 'rubocop-rspec', '~> 1.43.1'
19
- gem 'simplecov', ['>= 0.18.0', '< 0.20.0']
16
+ gem 'rubocop', '~> 1.27.0'
17
+ gem 'rubocop-performance', '~> 1.13.1'
18
+ gem 'rubocop-rspec', '~> 2.9.0'
19
+ gem 'simplecov', ['>= 0.18.0', '< 0.22.0']
20
20
  gem 'yard', '~> 0.9.5'
21
21
 
22
22
  platforms :mri do
@@ -25,5 +25,5 @@ group :development do
25
25
  end
26
26
 
27
27
  group :debugging do
28
- gem 'pry', '~> 0.13.0'
28
+ gem 'pry', '~> 0.14.0'
29
29
  end
data/README.md CHANGED
@@ -94,7 +94,7 @@ demo.rb -- 2 warnings:
94
94
 
95
95
  ## Supported Ruby versions
96
96
 
97
- Reek is officially supported for CRuby 2.4 to 2.7 and for JRuby 9.2.
97
+ Reek is officially supported for CRuby 2.6 through 3.1 and for JRuby 9.3.
98
98
  Other Ruby implementations (like Rubinius) are not officially supported but
99
99
  should work as well.
100
100
 
@@ -14,15 +14,14 @@ class CodeClimateToReek
14
14
  # we have to exit with a zero for both failure and success.
15
15
  ENGINE_CONFIGURATION = [
16
16
  '--failure-exit-code', '0',
17
- '--success-exit-code', '0',
18
- '.'
17
+ '--success-exit-code', '0'
19
18
  ].freeze
20
19
 
21
20
  attr_reader :configuration_file_path, :include_paths_key, :include_paths_default
22
21
 
23
22
  def initialize(configuration_file_path: '/config.json',
24
23
  include_paths_key: 'include_paths',
25
- include_paths_default: [])
24
+ include_paths_default: ['.'])
26
25
  @configuration_file_path = configuration_file_path
27
26
  @include_paths_key = include_paths_key
28
27
  @include_paths_default = include_paths_default
@@ -30,7 +30,7 @@ module Reek
30
30
  SexpExtensions.const_get(const)
31
31
  ]
32
32
  end
33
- Hash[assoc]
33
+ assoc.to_h
34
34
  end
35
35
  end
36
36
 
data/lib/reek/ast/node.rb CHANGED
@@ -60,7 +60,7 @@ module Reek
60
60
  #
61
61
  # Returns an array with all matching nodes.
62
62
  def each_node(target_types, ignoring = [], &blk)
63
- return enum_for(:each_node, target_types, ignoring) unless block_given?
63
+ return enum_for(:each_node, target_types, ignoring) unless blk
64
64
 
65
65
  look_for(Array(target_types), ignoring, &blk)
66
66
  end
@@ -104,6 +104,17 @@ module Reek
104
104
  end
105
105
  end
106
106
  # rubocop:enable Naming/ClassAndModuleCamelCase
107
+
108
+ # Utility methods for :forward_arg nodes.
109
+ # rubocop:disable Naming/ClassAndModuleCamelCase
110
+ module Forward_ArgNode
111
+ include ArgNodeBase
112
+
113
+ def anonymous_splat?
114
+ true
115
+ end
116
+ end
117
+ # rubocop:enable Naming/ClassAndModuleCamelCase
107
118
  end
108
119
  end
109
120
  end
@@ -10,7 +10,7 @@ module Reek
10
10
  end
11
11
 
12
12
  def body_nodes(type, ignoring = [])
13
- children[1..-1].compact.flat_map do |child|
13
+ children[1..].compact.flat_map do |child|
14
14
  child.each_node(type, ignoring | type).to_a
15
15
  end
16
16
  end
@@ -31,7 +31,7 @@ module Reek
31
31
 
32
32
  # @quality :reek:FeatureEnvy
33
33
  def body_nodes(type, ignoring = [])
34
- children[1..-1].compact.flat_map do |child|
34
+ children[1..].compact.flat_map do |child|
35
35
  if ignoring.include? child.type
36
36
  []
37
37
  else
@@ -16,7 +16,7 @@ module Reek
16
16
  end
17
17
 
18
18
  def args
19
- children[2..-1]
19
+ children[2..]
20
20
  end
21
21
 
22
22
  def participants
@@ -24,7 +24,7 @@ module Reek
24
24
  else
25
25
  write_to_file
26
26
  puts "\n'#{DEFAULT_CONFIGURATION_FILE_NAME}' generated! "\
27
- 'You can now use this as a starting point.'
27
+ 'You can now use this as a starting point.'
28
28
  end
29
29
  options.success_exit_code
30
30
  end
@@ -232,7 +232,7 @@ module Reek
232
232
  puts "All available smell detectors:\n\n"
233
233
  puts DetectorRepository.available_detector_names
234
234
  puts "\nCheck out #{DocumentationLink.build('Code Smells')} "\
235
- 'for a details on each detector'
235
+ 'for a details on each detector'
236
236
  exit
237
237
  end
238
238
  parser.on_tail('-v', '--version', 'Show version') do
@@ -39,13 +39,13 @@ module Reek
39
39
 
40
40
  @original_comment.scan(CONFIGURATION_REGEX) do |detector_name, separator, options|
41
41
  escalate_legacy_separator separator
42
- CodeCommentValidator.new(detector_name: detector_name,
43
- original_comment: original_comment,
44
- line: line,
45
- source: source,
46
- options: options).validate
47
- @config.merge! detector_name => YAML.safe_load(options || DISABLE_DETECTOR_CONFIGURATION,
48
- permitted_classes: [Regexp])
42
+ validator = CodeCommentValidator.new(detector_name: detector_name,
43
+ original_comment: original_comment,
44
+ line: line,
45
+ source: source,
46
+ options: options)
47
+ validator.validate
48
+ @config.merge! detector_name => validator.parsed_options
49
49
  end
50
50
  end
51
51
 
@@ -115,6 +115,21 @@ module Reek
115
115
  escalate_unknown_configuration_key
116
116
  end
117
117
 
118
+ def parsed_options
119
+ @parsed_options ||=
120
+ if Psych::VERSION < '3.1.0'
121
+ YAML.safe_load(options || CodeComment::DISABLE_DETECTOR_CONFIGURATION, [Regexp])
122
+ else
123
+ YAML.safe_load(options || CodeComment::DISABLE_DETECTOR_CONFIGURATION,
124
+ permitted_classes: [Regexp])
125
+ end
126
+ rescue Psych::SyntaxError
127
+ raise Errors::GarbageDetectorConfigurationInCommentError.new(detector_name: detector_name,
128
+ original_comment: original_comment,
129
+ source: source,
130
+ line: line)
131
+ end
132
+
118
133
  private
119
134
 
120
135
  attr_reader :detector_name,
@@ -124,16 +139,6 @@ module Reek
124
139
  :separator,
125
140
  :options
126
141
 
127
- def parsed_options
128
- @parsed_options ||= YAML.safe_load(options || CodeComment::DISABLE_DETECTOR_CONFIGURATION,
129
- permitted_classes: [Regexp])
130
- rescue Psych::SyntaxError
131
- raise Errors::GarbageDetectorConfigurationInCommentError.new(detector_name: detector_name,
132
- original_comment: original_comment,
133
- source: source,
134
- line: line)
135
- end
136
-
137
142
  def escalate_unknown_configuration_key
138
143
  return if given_keys_legit?
139
144
 
@@ -14,7 +14,8 @@ module Reek
14
14
  # @param paths [String]
15
15
  # @return [undefined]
16
16
  def add(paths)
17
- paths.each { |path| self << Pathname(path) }
17
+ paths.flat_map { |path| Dir[path] }.
18
+ each { |path| self << Pathname(path) }
18
19
  end
19
20
  end
20
21
  end
@@ -51,7 +51,7 @@ module Reek
51
51
  # @return [Enumerator]
52
52
  #
53
53
  def each(&block)
54
- return enum_for(:each) unless block_given?
54
+ return enum_for(:each) unless block
55
55
 
56
56
  yield self
57
57
  children.each do |child|
@@ -55,6 +55,10 @@ module Reek
55
55
  end
56
56
  end
57
57
 
58
+ def instance_method_names_via_to_call
59
+ instance_method_calls.flat_map(&:method_name_called_to_call).compact
60
+ end
61
+
58
62
  #
59
63
  # @deprecated use `defined_instance_methods` instead
60
64
  #
@@ -0,0 +1,16 @@
1
+ # frozen_string_literal: true
2
+
3
+ require_relative 'module_context'
4
+
5
+ module Reek
6
+ module Context
7
+ #
8
+ # A context wrapper for any refinement blocks found in a syntax tree.
9
+ #
10
+ class RefinementContext < ModuleContext
11
+ def full_name
12
+ exp.call.args.first.name
13
+ end
14
+ end
15
+ end
16
+ end
@@ -14,6 +14,12 @@ module Reek
14
14
  @name = name
15
15
  super exp
16
16
  end
17
+
18
+ def method_name_called_to_call
19
+ return unless @name == :method
20
+
21
+ local_nodes(:sym).map(&:name)
22
+ end
17
23
  end
18
24
  end
19
25
  end
@@ -5,6 +5,7 @@ require_relative 'context/class_context'
5
5
  require_relative 'context/ghost_context'
6
6
  require_relative 'context/method_context'
7
7
  require_relative 'context/module_context'
8
+ require_relative 'context/refinement_context'
8
9
  require_relative 'context/root_context'
9
10
  require_relative 'context/send_context'
10
11
  require_relative 'context/singleton_attribute_context'
@@ -20,7 +21,7 @@ module Reek
20
21
  # counting. Ideally `ContextBuilder` would only build up the context tree and leave the
21
22
  # statement and reference counting to the contexts.
22
23
  #
23
- # @quality :reek:TooManyMethods { max_methods: 31 }
24
+ # @quality :reek:TooManyMethods { max_methods: 32 }
24
25
  # @quality :reek:UnusedPrivateMethod { exclude: [ !ruby/regexp /process_/ ] }
25
26
  # @quality :reek:DataClump
26
27
  class ContextBuilder
@@ -263,9 +264,16 @@ module Reek
263
264
  #
264
265
  # Counts non-empty blocks as one statement.
265
266
  #
267
+ # A refinement block is handled differently and causes a RefinementContext
268
+ # to be opened.
269
+ #
266
270
  def process_block(exp, _parent)
267
271
  increase_statement_count_by(exp.block)
268
- process(exp)
272
+ if exp.call.name == :refine
273
+ handle_refinement_block(exp)
274
+ else
275
+ process(exp)
276
+ end
269
277
  end
270
278
 
271
279
  # Handles `begin` and `kwbegin` nodes. `begin` nodes are created implicitly
@@ -414,7 +422,7 @@ module Reek
414
422
  # See `process_rescue` for additional reference.
415
423
  #
416
424
  def process_resbody(exp, _parent)
417
- increase_statement_count_by(exp.children[1..-1].compact)
425
+ increase_statement_count_by(exp.children[1..].compact)
418
426
  process(exp)
419
427
  end
420
428
 
@@ -508,6 +516,12 @@ module Reek
508
516
  end
509
517
  end
510
518
 
519
+ def handle_refinement_block(exp)
520
+ inside_new_context(Context::RefinementContext, exp) do
521
+ process(exp)
522
+ end
523
+ end
524
+
511
525
  def handle_send_for_modules(exp)
512
526
  arg_names = exp.args.map { |arg| arg.children.first }
513
527
  current_context.track_visibility(exp.name, arg_names)
@@ -88,7 +88,7 @@ module Reek
88
88
  def source_files=(files)
89
89
  unless files.is_a?(String) || files.is_a?(FileList)
90
90
  raise ArgumentError, 'File list should be a FileList or a String that can contain'\
91
- " a glob pattern, e.g. '{app,lib,spec}/**/*.rb'"
91
+ " a glob pattern, e.g. '{app,lib,spec}/**/*.rb'"
92
92
  end
93
93
  @source_files = FileList[files]
94
94
  end
@@ -57,9 +57,7 @@ module Reek
57
57
  end
58
58
 
59
59
  def configuration
60
- @configuration ||= begin
61
- CodeClimateConfiguration.load
62
- end
60
+ @configuration ||= CodeClimateConfiguration.load
63
61
  end
64
62
  end
65
63
  end
@@ -90,7 +90,7 @@ module Reek
90
90
 
91
91
  class << self
92
92
  def smell_type
93
- @smell_type ||= name.split(/::/).last
93
+ @smell_type ||= name.split('::').last
94
94
  end
95
95
 
96
96
  def contexts
@@ -61,6 +61,7 @@ module Reek
61
61
  def unused_private_methods
62
62
  defined_private_methods = context.defined_instance_methods(visibility: :private)
63
63
  called_method_names = context.instance_method_calls.map(&:name)
64
+ called_method_names.concat(context.instance_method_names_via_to_call)
64
65
 
65
66
  defined_private_methods.reject do |defined_method|
66
67
  called_method_names.include?(defined_method.name)
@@ -59,7 +59,7 @@ module Reek
59
59
 
60
60
  # @public
61
61
  def to_hash
62
- stringified_params = Hash[parameters.map { |key, val| [key.to_s, val] }]
62
+ stringified_params = parameters.transform_keys(&:to_s)
63
63
  base_hash.merge(stringified_params)
64
64
  end
65
65
 
@@ -62,10 +62,8 @@ module Reek
62
62
 
63
63
  false
64
64
  end
65
- elsif path_excluded?(path)
66
- true
67
65
  else
68
- false
66
+ path_excluded?(path)
69
67
  end
70
68
  end
71
69
 
@@ -70,18 +70,20 @@ module Reek
70
70
 
71
71
  def set_failure_messages_for_smell_type
72
72
  self.failure_message = "Expected #{origin} to reek of #{smell_type}, "\
73
- 'but it didn\'t'
73
+ 'but it didn\'t'
74
74
  self.failure_message_when_negated = "Expected #{origin} not to reek "\
75
- "of #{smell_type}, but it did"
75
+ "of #{smell_type}, but it did"
76
76
  end
77
77
 
78
78
  def set_failure_messages_for_smell_details
79
- self.failure_message = "Expected #{origin} to reek of #{smell_type} "\
79
+ self.failure_message =
80
+ "Expected #{origin} to reek of #{smell_type} "\
80
81
  "(which it did) with smell details #{smell_details}, which it didn't.\n"\
81
82
  "The number of smell details I had to compare with the given one was #{matching_smell_types.count} "\
82
83
  "and here they are:\n"\
83
84
  "#{all_relevant_smell_details_formatted}"
84
- self.failure_message_when_negated = "Expected #{origin} not to reek of "\
85
+ self.failure_message_when_negated =
86
+ "Expected #{origin} not to reek of "\
85
87
  "#{smell_type} with smell details #{smell_details}, but it did"
86
88
  end
87
89
 
data/lib/reek/version.rb CHANGED
@@ -3,11 +3,11 @@
3
3
  # @public
4
4
  module Reek
5
5
  #
6
- # This module holds the Reek version informations
6
+ # This module holds the Reek version information
7
7
  #
8
8
  # @public
9
9
  module Version
10
10
  # @public
11
- STRING = '6.0.2'
11
+ STRING = '6.1.1'
12
12
  end
13
13
  end