reek 4.7.3 → 5.0.0
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.
- checksums.yaml +4 -4
- data/.codeclimate.yml +17 -12
- data/.rubocop.yml +18 -3
- data/.simplecov +1 -0
- data/.travis.yml +3 -4
- data/.yardopts +1 -1
- data/CHANGELOG.md +45 -0
- data/Gemfile +4 -4
- data/README.md +134 -104
- data/Rakefile +16 -3
- data/bin/reek +1 -3
- data/docs/API.md +2 -9
- data/docs/Basic-Smell-Options.md +51 -11
- data/docs/Code-Smells.md +1 -1
- data/docs/Command-Line-Options.md +14 -4
- data/docs/Duplicate-Method-Call.md +49 -1
- data/docs/Feature-Envy.md +44 -0
- data/docs/How-To-Write-New-Detectors.md +2 -3
- data/docs/Instance-Variable-Assumption.md +1 -1
- data/docs/{Prima-Donna-Method.md → Missing-Safe-Method.md} +11 -9
- data/docs/Rake-Task.md +1 -1
- data/docs/Reek-4-to-Reek-5-migration.md +193 -0
- data/docs/Reek-Driven-Development.md +1 -1
- data/docs/Uncommunicative-Method-Name.md +45 -6
- data/docs/Uncommunicative-Module-Name.md +49 -7
- data/docs/Uncommunicative-Parameter-Name.md +43 -5
- data/docs/Uncommunicative-Variable-Name.md +73 -2
- data/docs/Unused-Private-Method.md +2 -2
- data/docs/defaults.reek.yml +129 -0
- data/docs/yard_plugin.rb +1 -0
- data/features/command_line_interface/basic_usage.feature +2 -2
- data/features/command_line_interface/options.feature +46 -4
- data/features/command_line_interface/show_progress.feature +4 -4
- data/features/command_line_interface/smell_selection.feature +1 -1
- data/features/command_line_interface/smells_count.feature +6 -6
- data/features/command_line_interface/stdin.feature +30 -8
- data/features/configuration_files/accept_setting.feature +45 -28
- data/features/configuration_files/directory_specific_directives.feature +78 -73
- data/features/configuration_files/exclude_directives.feature +11 -10
- data/features/configuration_files/exclude_paths_directives.feature +4 -4
- data/features/configuration_files/masking_smells.feature +38 -9
- data/features/configuration_files/mix_accept_reject_setting.feature +31 -28
- data/features/configuration_files/reject_setting.feature +52 -41
- data/features/configuration_files/schema_validation.feature +59 -0
- data/features/configuration_files/unused_private_method.feature +18 -16
- data/features/configuration_loading.feature +53 -10
- data/features/configuration_via_source_comments/erroneous_source_comments.feature +2 -2
- data/features/configuration_via_source_comments/well_formed_source_comments.feature +2 -2
- data/features/locales.feature +2 -2
- data/features/rake_task/rake_task.feature +15 -15
- data/features/reports/json.feature +3 -3
- data/features/reports/reports.feature +34 -34
- data/features/reports/yaml.feature +3 -3
- data/features/rspec_matcher.feature +9 -1
- data/features/samples.feature +287 -287
- data/features/step_definitions/reek_steps.rb +4 -0
- data/features/step_definitions/sample_file_steps.rb +9 -4
- data/features/support/env.rb +2 -2
- data/features/todo_list.feature +26 -23
- data/lib/reek/ast/node.rb +40 -55
- data/lib/reek/ast/object_refs.rb +1 -1
- data/lib/reek/ast/reference_collector.rb +2 -4
- data/lib/reek/ast/sexp_extensions/case.rb +1 -1
- data/lib/reek/ast/sexp_extensions/if.rb +8 -1
- data/lib/reek/ast/sexp_extensions/logical_operators.rb +1 -1
- data/lib/reek/ast/sexp_extensions/methods.rb +4 -6
- data/lib/reek/cli/application.rb +4 -3
- data/lib/reek/cli/command/report_command.rb +1 -2
- data/lib/reek/cli/command/todo_list_command.rb +8 -8
- data/lib/reek/cli/options.rb +29 -14
- data/lib/reek/cli/silencer.rb +14 -3
- data/lib/reek/code_comment.rb +14 -16
- data/lib/reek/configuration/app_configuration.rb +32 -28
- data/lib/reek/configuration/configuration_converter.rb +110 -0
- data/lib/reek/configuration/configuration_file_finder.rb +15 -40
- data/lib/reek/configuration/configuration_validator.rb +12 -23
- data/lib/reek/configuration/default_directive.rb +17 -3
- data/lib/reek/configuration/directory_directives.rb +17 -11
- data/lib/reek/configuration/excluded_paths.rb +1 -1
- data/lib/reek/configuration/rake_task_converter.rb +29 -0
- data/lib/reek/configuration/schema.yml +210 -0
- data/lib/reek/configuration/schema_validator.rb +38 -0
- data/lib/reek/context/attribute_context.rb +1 -1
- data/lib/reek/context/code_context.rb +8 -11
- data/lib/reek/context/method_context.rb +7 -12
- data/lib/reek/context/module_context.rb +4 -4
- data/lib/reek/context_builder.rb +11 -11
- data/lib/reek/detector_repository.rb +6 -0
- data/lib/reek/documentation_link.rb +28 -0
- data/lib/reek/errors/bad_detector_configuration_key_in_comment_error.rb +13 -12
- data/lib/reek/errors/bad_detector_in_comment_error.rb +11 -10
- data/lib/reek/errors/base_error.rb +3 -0
- data/lib/reek/errors/config_file_error.rb +11 -0
- data/lib/reek/errors/encoding_error.rb +16 -11
- data/lib/reek/errors/garbage_detector_configuration_in_comment_error.rb +11 -10
- data/lib/reek/errors/incomprehensible_source_error.rb +20 -22
- data/lib/reek/errors/syntax_error.rb +41 -0
- data/lib/reek/examiner.rb +19 -25
- data/lib/reek/logging_error_handler.rb +7 -5
- data/lib/reek/rake/task.rb +3 -3
- data/lib/reek/report/base_report.rb +8 -12
- data/lib/reek/report/code_climate/code_climate_configuration.rb +1 -1
- data/lib/reek/report/code_climate/code_climate_configuration.yml +6 -10
- data/lib/reek/report/documentation_link_warning_formatter.rb +17 -0
- data/lib/reek/report/heading_formatter.rb +54 -0
- data/lib/reek/report/json_report.rb +1 -1
- data/lib/reek/report/location_formatter.rb +40 -0
- data/lib/reek/report/progress_formatter.rb +79 -0
- data/lib/reek/report/simple_warning_formatter.rb +34 -0
- data/lib/reek/report/text_report.rb +1 -2
- data/lib/reek/report/xml_report.rb +3 -3
- data/lib/reek/report/yaml_report.rb +1 -1
- data/lib/reek/report.rb +15 -10
- data/lib/reek/smell_configuration.rb +2 -2
- data/lib/reek/smell_detectors/attribute.rb +0 -1
- data/lib/reek/smell_detectors/base_detector.rb +9 -12
- data/lib/reek/smell_detectors/boolean_parameter.rb +0 -1
- data/lib/reek/smell_detectors/class_variable.rb +3 -11
- data/lib/reek/smell_detectors/control_parameter.rb +17 -32
- data/lib/reek/smell_detectors/data_clump.rb +3 -4
- data/lib/reek/smell_detectors/duplicate_method_call.rb +6 -7
- data/lib/reek/smell_detectors/feature_envy.rb +1 -1
- data/lib/reek/smell_detectors/instance_variable_assumption.rb +1 -10
- data/lib/reek/smell_detectors/irresponsible_module.rb +0 -1
- data/lib/reek/smell_detectors/long_parameter_list.rb +1 -2
- data/lib/reek/smell_detectors/long_yield_list.rb +2 -3
- data/lib/reek/smell_detectors/manual_dispatch.rb +3 -3
- data/lib/reek/smell_detectors/{prima_donna_method.rb → missing_safe_method.rb} +6 -7
- data/lib/reek/smell_detectors/module_initialize.rb +1 -2
- data/lib/reek/smell_detectors/nested_iterators.rb +6 -6
- data/lib/reek/smell_detectors/nil_check.rb +0 -1
- data/lib/reek/smell_detectors/repeated_conditional.rb +3 -4
- data/lib/reek/smell_detectors/subclassed_from_core_class.rb +0 -1
- data/lib/reek/smell_detectors/too_many_constants.rb +2 -3
- data/lib/reek/smell_detectors/too_many_instance_variables.rb +1 -2
- data/lib/reek/smell_detectors/too_many_methods.rb +1 -2
- data/lib/reek/smell_detectors/too_many_statements.rb +1 -2
- data/lib/reek/smell_detectors/uncommunicative_method_name.rb +2 -3
- data/lib/reek/smell_detectors/uncommunicative_module_name.rb +2 -3
- data/lib/reek/smell_detectors/uncommunicative_parameter_name.rb +2 -3
- data/lib/reek/smell_detectors/uncommunicative_variable_name.rb +6 -7
- data/lib/reek/smell_detectors/unused_parameters.rb +0 -1
- data/lib/reek/smell_detectors/unused_private_method.rb +0 -1
- data/lib/reek/smell_detectors/utility_function.rb +2 -3
- data/lib/reek/smell_detectors.rb +1 -2
- data/lib/reek/smell_warning.rb +15 -8
- data/lib/reek/source/source_code.rb +50 -72
- data/lib/reek/source/source_locator.rb +7 -7
- data/lib/reek/spec/should_reek.rb +2 -2
- data/lib/reek/spec/should_reek_of.rb +9 -16
- data/lib/reek/spec/should_reek_only_of.rb +4 -4
- data/lib/reek/spec.rb +6 -6
- data/lib/reek/tree_dresser.rb +5 -5
- data/lib/reek/version.rb +1 -1
- data/reek.gemspec +5 -5
- data/samples/checkstyle.xml +1 -1
- data/samples/configuration/accepts_rejects_and_excludes_for_detectors.reek.yml +29 -0
- data/samples/configuration/accepts_rejects_and_excludes_for_directory_directives.reek.yml +30 -0
- data/samples/configuration/full_configuration.reek +8 -4
- data/samples/configuration/full_mask.reek +5 -4
- data/samples/configuration/partial_mask.reek +3 -2
- data/samples/configuration/regular_configuration/.reek.yml +4 -0
- data/samples/paths.rb +5 -4
- data/samples/source_with_hidden_directories/.hidden/hidden.rb +1 -0
- data/samples/source_with_hidden_directories/not_hidden.rb +1 -0
- data/spec/factories/factories.rb +2 -13
- data/spec/reek/ast/node_spec.rb +103 -10
- data/spec/reek/ast/reference_collector_spec.rb +1 -1
- data/spec/reek/ast/sexp_extensions_spec.rb +2 -2
- data/spec/reek/cli/application_spec.rb +50 -38
- data/spec/reek/cli/command/todo_list_command_spec.rb +6 -4
- data/spec/reek/cli/silencer_spec.rb +28 -0
- data/spec/reek/code_comment_spec.rb +31 -38
- data/spec/reek/configuration/app_configuration_spec.rb +46 -33
- data/spec/reek/configuration/configuration_file_finder_spec.rb +133 -49
- data/spec/reek/configuration/default_directive_spec.rb +1 -1
- data/spec/reek/configuration/directory_directives_spec.rb +6 -7
- data/spec/reek/configuration/excluded_paths_spec.rb +6 -6
- data/spec/reek/configuration/rake_task_converter_spec.rb +33 -0
- data/spec/reek/configuration/schema_validator_spec.rb +165 -0
- data/spec/reek/context/code_context_spec.rb +60 -96
- data/spec/reek/context/ghost_context_spec.rb +1 -1
- data/spec/reek/context/root_context_spec.rb +1 -1
- data/spec/reek/documentation_link_spec.rb +20 -0
- data/spec/reek/errors/base_error_spec.rb +13 -0
- data/spec/reek/examiner_spec.rb +100 -30
- data/spec/reek/report/code_climate/code_climate_fingerprint_spec.rb +82 -80
- data/spec/reek/report/code_climate/code_climate_formatter_spec.rb +6 -6
- data/spec/reek/report/json_report_spec.rb +13 -46
- data/spec/reek/report/{formatter/location_formatter_spec.rb → location_formatter_spec.rb} +5 -5
- data/spec/reek/report/{formatter/progress_formatter_spec.rb → progress_formatter_spec.rb} +4 -4
- data/spec/reek/report/text_report_spec.rb +4 -4
- data/spec/reek/report/xml_report_spec.rb +3 -3
- data/spec/reek/report/yaml_report_spec.rb +9 -38
- data/spec/reek/report_spec.rb +3 -3
- data/spec/reek/smell_detectors/boolean_parameter_spec.rb +2 -2
- data/spec/reek/smell_detectors/class_variable_spec.rb +26 -32
- data/spec/reek/smell_detectors/control_parameter_spec.rb +34 -4
- data/spec/reek/smell_detectors/duplicate_method_call_spec.rb +3 -3
- data/spec/reek/smell_detectors/feature_envy_spec.rb +47 -2
- data/spec/reek/smell_detectors/{prima_donna_method_spec.rb → missing_safe_method_spec.rb} +9 -9
- data/spec/reek/smell_detectors/module_initialize_spec.rb +14 -0
- data/spec/reek/smell_detectors/nested_iterators_spec.rb +1 -1
- data/spec/reek/smell_detectors/too_many_constants_spec.rb +3 -3
- data/spec/reek/smell_detectors/too_many_instance_variables_spec.rb +1 -1
- data/spec/reek/smell_detectors/uncommunicative_method_name_spec.rb +6 -6
- data/spec/reek/smell_detectors/uncommunicative_module_name_spec.rb +6 -4
- data/spec/reek/smell_detectors/uncommunicative_parameter_name_spec.rb +6 -4
- data/spec/reek/smell_detectors/uncommunicative_variable_name_spec.rb +9 -9
- data/spec/reek/smell_detectors/unused_parameters_spec.rb +3 -3
- data/spec/reek/smell_detectors/unused_private_method_spec.rb +10 -10
- data/spec/reek/smell_detectors/utility_function_spec.rb +5 -5
- data/spec/reek/smell_warning_spec.rb +12 -8
- data/spec/reek/source/source_code_spec.rb +17 -43
- data/spec/reek/source/source_locator_spec.rb +17 -17
- data/spec/reek/spec/should_reek_of_spec.rb +7 -11
- data/spec/reek/spec/should_reek_only_of_spec.rb +2 -2
- data/spec/reek/spec/should_reek_spec.rb +3 -3
- data/spec/reek/spec/smell_matcher_spec.rb +3 -3
- data/spec/reek/tree_dresser_spec.rb +12 -17
- data/spec/spec_helper.rb +6 -17
- data/tasks/configuration.rake +8 -5
- metadata +71 -41
- data/defaults.reek +0 -131
- data/features/configuration_files/warn_about_multiple_configuration_files.feature +0 -44
- data/lib/reek/report/formatter/heading_formatter.rb +0 -52
- data/lib/reek/report/formatter/location_formatter.rb +0 -42
- data/lib/reek/report/formatter/progress_formatter.rb +0 -81
- data/lib/reek/report/formatter/simple_warning_formatter.rb +0 -35
- data/lib/reek/report/formatter/wiki_link_warning_formatter.rb +0 -36
- data/lib/reek/report/formatter.rb +0 -33
- data/lib/reek/smell_detectors/syntax.rb +0 -37
- data/samples/configuration/non_public_modifiers_mask.reek +0 -3
- data/samples/smelly_with_inline_mask.rb +0 -8
- data/samples/smelly_with_modifiers.rb +0 -12
- data/samples/source_with_hidden_directories/.hidden/uncommunicative_method_name.rb +0 -5
- data/samples/source_with_non_ruby_files/uncommunicative_parameter_name.rb +0 -6
- data/spec/reek/smell_detectors/syntax_spec.rb +0 -17
- /data/{samples/configuration/more_than_one_configuration_file/regular.reek → .reek.yml} +0 -0
- /data/samples/{clean.rb → clean_source/clean.rb} +0 -0
- /data/samples/{exceptions.reek → configuration/home/home.reek.yml} +0 -0
- /data/samples/configuration/{more_than_one_configuration_file/todo.reek → regular_configuration/empty_sub_directory/.gitignore} +0 -0
- /data/samples/{configuration/single_configuration_file/.reek → no_config_file/.keep} +0 -0
- /data/samples/{inline.rb → smelly_source/inline.rb} +0 -0
- /data/samples/{optparse.rb → smelly_source/optparse.rb} +0 -0
- /data/samples/{redcloth.rb → smelly_source/redcloth.rb} +0 -0
- /data/samples/{smelly.rb → smelly_source/smelly.rb} +0 -0
- /data/samples/{source_with_hidden_directories/uncommunicative_parameter_name.rb → source_with_non_ruby_files/ruby.rb} +0 -0
|
@@ -10,11 +10,11 @@ Feature: Correctly formatted reports
|
|
|
10
10
|
And it reports:
|
|
11
11
|
"""
|
|
12
12
|
smelly/dirty_one.rb -- 2 warnings:
|
|
13
|
-
[4]:UncommunicativeMethodName: Smelly#x has the name 'x'
|
|
14
|
-
[5]:UncommunicativeVariableName: Smelly#x has the variable name 'y'
|
|
13
|
+
[4]:UncommunicativeMethodName: Smelly#x has the name 'x'
|
|
14
|
+
[5]:UncommunicativeVariableName: Smelly#x has the variable name 'y'
|
|
15
15
|
smelly/dirty_two.rb -- 2 warnings:
|
|
16
|
-
[4]:UncommunicativeMethodName: Smelly#x has the name 'x'
|
|
17
|
-
[5]:UncommunicativeVariableName: Smelly#x has the variable name 'y'
|
|
16
|
+
[4]:UncommunicativeMethodName: Smelly#x has the name 'x'
|
|
17
|
+
[5]:UncommunicativeVariableName: Smelly#x has the variable name 'y'
|
|
18
18
|
4 total warnings
|
|
19
19
|
"""
|
|
20
20
|
|
|
@@ -30,11 +30,11 @@ Feature: Correctly formatted reports
|
|
|
30
30
|
And it reports:
|
|
31
31
|
"""
|
|
32
32
|
smelly/dirty_one.rb -- 2 warnings:
|
|
33
|
-
[4]:UncommunicativeMethodName: Smelly#x has the name 'x'
|
|
34
|
-
[5]:UncommunicativeVariableName: Smelly#x has the variable name 'y'
|
|
33
|
+
[4]:UncommunicativeMethodName: Smelly#x has the name 'x'
|
|
34
|
+
[5]:UncommunicativeVariableName: Smelly#x has the variable name 'y'
|
|
35
35
|
smelly/dirty_two.rb -- 2 warnings:
|
|
36
|
-
[4]:UncommunicativeMethodName: Smelly#x has the name 'x'
|
|
37
|
-
[5]:UncommunicativeVariableName: Smelly#x has the variable name 'y'
|
|
36
|
+
[4]:UncommunicativeMethodName: Smelly#x has the name 'x'
|
|
37
|
+
[5]:UncommunicativeVariableName: Smelly#x has the variable name 'y'
|
|
38
38
|
4 total warnings
|
|
39
39
|
"""
|
|
40
40
|
|
|
@@ -51,11 +51,11 @@ Feature: Correctly formatted reports
|
|
|
51
51
|
And it reports:
|
|
52
52
|
"""
|
|
53
53
|
smelly/dirty_two.rb -- 2 warnings:
|
|
54
|
-
[4]:UncommunicativeMethodName: Smelly#x has the name 'x'
|
|
55
|
-
[5]:UncommunicativeVariableName: Smelly#x has the variable name 'y'
|
|
54
|
+
[4]:UncommunicativeMethodName: Smelly#x has the name 'x'
|
|
55
|
+
[5]:UncommunicativeVariableName: Smelly#x has the variable name 'y'
|
|
56
56
|
smelly/dirty_one.rb -- 2 warnings:
|
|
57
|
-
[4]:UncommunicativeMethodName: Smelly#x has the name 'x'
|
|
58
|
-
[5]:UncommunicativeVariableName: Smelly#x has the variable name 'y'
|
|
57
|
+
[4]:UncommunicativeMethodName: Smelly#x has the name 'x'
|
|
58
|
+
[5]:UncommunicativeVariableName: Smelly#x has the variable name 'y'
|
|
59
59
|
4 total warnings
|
|
60
60
|
"""
|
|
61
61
|
|
|
@@ -110,8 +110,8 @@ Feature: Correctly formatted reports
|
|
|
110
110
|
And it reports:
|
|
111
111
|
"""
|
|
112
112
|
smelly.rb -- 2 warnings:
|
|
113
|
-
UncommunicativeMethodName: Smelly#x has the name 'x'
|
|
114
|
-
UncommunicativeVariableName: Smelly#x has the variable name 'y'
|
|
113
|
+
UncommunicativeMethodName: Smelly#x has the name 'x'
|
|
114
|
+
UncommunicativeVariableName: Smelly#x has the variable name 'y'
|
|
115
115
|
"""
|
|
116
116
|
|
|
117
117
|
Examples:
|
|
@@ -127,8 +127,8 @@ Feature: Correctly formatted reports
|
|
|
127
127
|
And it reports:
|
|
128
128
|
"""
|
|
129
129
|
smelly.rb -- 2 warnings:
|
|
130
|
-
[4]:UncommunicativeMethodName: Smelly#x has the name 'x'
|
|
131
|
-
[5]:UncommunicativeVariableName: Smelly#x has the variable name 'y'
|
|
130
|
+
[4]:UncommunicativeMethodName: Smelly#x has the name 'x'
|
|
131
|
+
[5]:UncommunicativeVariableName: Smelly#x has the variable name 'y'
|
|
132
132
|
"""
|
|
133
133
|
|
|
134
134
|
Examples:
|
|
@@ -144,8 +144,8 @@ Feature: Correctly formatted reports
|
|
|
144
144
|
And it reports:
|
|
145
145
|
"""
|
|
146
146
|
smelly.rb -- 2 warnings:
|
|
147
|
-
smelly.rb:4: UncommunicativeMethodName: Smelly#x has the name 'x'
|
|
148
|
-
smelly.rb:5: UncommunicativeVariableName: Smelly#x has the variable name 'y'
|
|
147
|
+
smelly.rb:4: UncommunicativeMethodName: Smelly#x has the name 'x'
|
|
148
|
+
smelly.rb:5: UncommunicativeVariableName: Smelly#x has the variable name 'y'
|
|
149
149
|
"""
|
|
150
150
|
|
|
151
151
|
Examples:
|
|
@@ -162,11 +162,11 @@ Feature: Correctly formatted reports
|
|
|
162
162
|
And it reports:
|
|
163
163
|
"""
|
|
164
164
|
smelly/dirty_one.rb -- 2 warnings:
|
|
165
|
-
[4]:UncommunicativeMethodName: Smelly#x has the name 'x'
|
|
166
|
-
[5]:UncommunicativeVariableName: Smelly#x has the variable name 'y'
|
|
165
|
+
[4]:UncommunicativeMethodName: Smelly#x has the name 'x'
|
|
166
|
+
[5]:UncommunicativeVariableName: Smelly#x has the variable name 'y'
|
|
167
167
|
smelly/dirty_two.rb -- 2 warnings:
|
|
168
|
-
[4]:UncommunicativeMethodName: Smelly#x has the name 'x'
|
|
169
|
-
[5]:UncommunicativeVariableName: Smelly#x has the variable name 'y'
|
|
168
|
+
[4]:UncommunicativeMethodName: Smelly#x has the name 'x'
|
|
169
|
+
[5]:UncommunicativeVariableName: Smelly#x has the variable name 'y'
|
|
170
170
|
4 total warnings
|
|
171
171
|
"""
|
|
172
172
|
|
|
@@ -175,25 +175,25 @@ Feature: Correctly formatted reports
|
|
|
175
175
|
| smelly/ |
|
|
176
176
|
| smelly |
|
|
177
177
|
|
|
178
|
-
Scenario Outline: -U or --
|
|
178
|
+
Scenario Outline: -U or --documentation adds helpful links to smell warnings
|
|
179
179
|
Given the smelly file 'smelly.rb'
|
|
180
180
|
When I run reek <option> smelly.rb
|
|
181
181
|
Then the exit status indicates smells
|
|
182
182
|
And it reports:
|
|
183
183
|
"""
|
|
184
184
|
smelly.rb -- 2 warnings:
|
|
185
|
-
[4]:UncommunicativeMethodName: Smelly#x has the name 'x' [https://github.com/troessner/reek/blob/
|
|
186
|
-
[5]:UncommunicativeVariableName: Smelly#x has the variable name 'y' [https://github.com/troessner/reek/blob/
|
|
185
|
+
[4]:UncommunicativeMethodName: Smelly#x has the name 'x' [https://github.com/troessner/reek/blob/v5.0.0/docs/Uncommunicative-Method-Name.md]
|
|
186
|
+
[5]:UncommunicativeVariableName: Smelly#x has the variable name 'y' [https://github.com/troessner/reek/blob/v5.0.0/docs/Uncommunicative-Variable-Name.md]
|
|
187
187
|
"""
|
|
188
188
|
|
|
189
189
|
Examples:
|
|
190
|
-
| option
|
|
191
|
-
| -U
|
|
192
|
-
| --
|
|
190
|
+
| option |
|
|
191
|
+
| -U |
|
|
192
|
+
| --documentation |
|
|
193
193
|
|
|
194
|
-
Scenario: --no-
|
|
194
|
+
Scenario: --no-documentation drops links from smell warnings
|
|
195
195
|
Given the smelly file 'smelly.rb'
|
|
196
|
-
When I run reek --no-
|
|
196
|
+
When I run reek --no-documentation smelly.rb
|
|
197
197
|
Then the exit status indicates smells
|
|
198
198
|
And it reports:
|
|
199
199
|
"""
|
|
@@ -202,18 +202,18 @@ Feature: Correctly formatted reports
|
|
|
202
202
|
[5]:UncommunicativeVariableName: Smelly#x has the variable name 'y'
|
|
203
203
|
"""
|
|
204
204
|
|
|
205
|
-
Scenario Outline: --
|
|
205
|
+
Scenario Outline: --documentation is independent of --line-numbers
|
|
206
206
|
Given the smelly file 'smelly.rb'
|
|
207
207
|
When I run reek <option> smelly.rb
|
|
208
208
|
Then the exit status indicates smells
|
|
209
209
|
And it reports:
|
|
210
210
|
"""
|
|
211
211
|
smelly.rb -- 2 warnings:
|
|
212
|
-
UncommunicativeMethodName: Smelly#x has the name 'x' [https://github.com/troessner/reek/blob/
|
|
213
|
-
UncommunicativeVariableName: Smelly#x has the variable name 'y' [https://github.com/troessner/reek/blob/
|
|
212
|
+
UncommunicativeMethodName: Smelly#x has the name 'x' [https://github.com/troessner/reek/blob/v5.0.0/docs/Uncommunicative-Method-Name.md]
|
|
213
|
+
UncommunicativeVariableName: Smelly#x has the variable name 'y' [https://github.com/troessner/reek/blob/v5.0.0/docs/Uncommunicative-Variable-Name.md]
|
|
214
214
|
"""
|
|
215
215
|
|
|
216
216
|
Examples:
|
|
217
217
|
| option |
|
|
218
218
|
| --no-line-numbers -U |
|
|
219
|
-
| --no-line-numbers --
|
|
219
|
+
| --no-line-numbers --documentation |
|
|
@@ -25,7 +25,7 @@ Feature: Report smells using simple YAML layout
|
|
|
25
25
|
smell_type: UncommunicativeMethodName
|
|
26
26
|
source: smelly.rb
|
|
27
27
|
name: x
|
|
28
|
-
|
|
28
|
+
documentation_link: https://github.com/troessner/reek/blob/v5.0.0/docs/Uncommunicative-Method-Name.md
|
|
29
29
|
- context: Smelly#x
|
|
30
30
|
lines:
|
|
31
31
|
- 5
|
|
@@ -33,7 +33,7 @@ Feature: Report smells using simple YAML layout
|
|
|
33
33
|
smell_type: UncommunicativeVariableName
|
|
34
34
|
source: smelly.rb
|
|
35
35
|
name: y
|
|
36
|
-
|
|
36
|
+
documentation_link: https://github.com/troessner/reek/blob/v5.0.0/docs/Uncommunicative-Variable-Name.md
|
|
37
37
|
"""
|
|
38
38
|
|
|
39
39
|
Scenario: Indicate smells and print them as yaml when using STDIN
|
|
@@ -48,5 +48,5 @@ Feature: Report smells using simple YAML layout
|
|
|
48
48
|
lines:
|
|
49
49
|
- 1
|
|
50
50
|
message: has no descriptive comment
|
|
51
|
-
|
|
51
|
+
documentation_link: https://github.com/troessner/reek/blob/v5.0.0/docs/Irresponsible-Module.md
|
|
52
52
|
"""
|
|
@@ -24,7 +24,15 @@ Feature: Use reek_of matcher
|
|
|
24
24
|
"""
|
|
25
25
|
|
|
26
26
|
Scenario: Masking smells with a configuration file
|
|
27
|
-
Given a
|
|
27
|
+
Given a file named ".reek.yml" with:
|
|
28
|
+
"""
|
|
29
|
+
---
|
|
30
|
+
detectors:
|
|
31
|
+
UncommunicativeMethodName:
|
|
32
|
+
enabled: false
|
|
33
|
+
UncommunicativeVariableName:
|
|
34
|
+
enabled: false
|
|
35
|
+
"""
|
|
28
36
|
When I run `rspec reek_spec.rb`
|
|
29
37
|
Then stdout should contain:
|
|
30
38
|
"""
|