mirror of
https://gitea.invidious.io/iv-org/shard-ameba.git
synced 2024-08-15 00:53:29 +00:00
Add Lint/DebugCalls
rule
This commit is contained in:
parent
f288cc3c4f
commit
66ee7642cf
2 changed files with 75 additions and 0 deletions
43
spec/ameba/rule/lint/debug_calls_spec.cr
Normal file
43
spec/ameba/rule/lint/debug_calls_spec.cr
Normal file
|
@ -0,0 +1,43 @@
|
|||
require "../../../spec_helper"
|
||||
|
||||
module Ameba::Rule::Lint
|
||||
subject = DebugCalls.new
|
||||
|
||||
describe DebugCalls do
|
||||
it "fails if there is a debug call" do
|
||||
subject.method_names.each do |name|
|
||||
source = expect_issue subject, <<-CRYSTAL, name: name
|
||||
a = 2
|
||||
%{name} a
|
||||
# ^{name} error: Possibly forgotten debug-related `%{name}` call detected
|
||||
a = a + 1
|
||||
CRYSTAL
|
||||
|
||||
expect_no_corrections source
|
||||
end
|
||||
end
|
||||
|
||||
it "passes if there is no debug call" do
|
||||
subject.method_names.each do |name|
|
||||
expect_no_issues subject, <<-CRYSTAL
|
||||
class A
|
||||
def #{name}
|
||||
end
|
||||
end
|
||||
A.new.#{name}
|
||||
CRYSTAL
|
||||
end
|
||||
end
|
||||
|
||||
it "reports rule, pos and message" do
|
||||
s = Source.new "pp! :foo", "source.cr"
|
||||
subject.catch(s).should_not be_valid
|
||||
|
||||
issue = s.issues.first
|
||||
issue.rule.should_not be_nil
|
||||
issue.location.to_s.should eq "source.cr:1:1"
|
||||
issue.end_location.to_s.should eq "source.cr:1:8"
|
||||
issue.message.should eq "Possibly forgotten debug-related `pp!` call detected"
|
||||
end
|
||||
end
|
||||
end
|
32
src/ameba/rule/lint/debug_calls.cr
Normal file
32
src/ameba/rule/lint/debug_calls.cr
Normal file
|
@ -0,0 +1,32 @@
|
|||
module Ameba::Rule::Lint
|
||||
# A rule that disallows calls to debug-related methods.
|
||||
#
|
||||
# This is because we don't want debug calls accidentally being
|
||||
# committed into our codebase.
|
||||
#
|
||||
# YAML configuration example:
|
||||
#
|
||||
# ```
|
||||
# Lint/DebugCalls:
|
||||
# Enabled: true
|
||||
# MethodNames:
|
||||
# - p
|
||||
# - p!
|
||||
# - pp
|
||||
# - pp!
|
||||
# ```
|
||||
class DebugCalls < Base
|
||||
properties do
|
||||
description "Disallows debug-related calls"
|
||||
method_names : Array(String) = %w(p p! pp pp!)
|
||||
end
|
||||
|
||||
MSG = "Possibly forgotten debug-related `%s` call detected"
|
||||
|
||||
def test(source, node : Crystal::Call)
|
||||
return unless node.name.in?(method_names) && node.obj.nil?
|
||||
|
||||
issue_for node, MSG % node.name
|
||||
end
|
||||
end
|
||||
end
|
Loading…
Reference in a new issue