Make InlineComments::COMMENT_DIRECTIVE_REGEX more strict (#146)

This commit is contained in:
Sijawusz Pur Rahnama 2020-04-11 08:55:41 +02:00 committed by GitHub
parent 458c492730
commit 1a25583036
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
4 changed files with 22 additions and 17 deletions

View file

@ -6,17 +6,22 @@ module Ameba
subject = InlineComments::COMMENT_DIRECTIVE_REGEX subject = InlineComments::COMMENT_DIRECTIVE_REGEX
it "allows to parse action and rule name" do it "allows to parse action and rule name" do
result = subject.match("#ameba:enable Group/RuleName") result = subject.match("# ameba:enable Group/RuleName")
result.should_not be_nil result = result.should_not be_nil
result.not_nil![1].should eq "enable" result["action"].should eq "enable"
result.not_nil![2].should eq "Group/RuleName" result["rules"].should eq "Group/RuleName"
end end
it "ignores the repeatable spaces" do it "parses multiple rules" do
result = subject.match("# ameba:enable Group/RuleName, OtherRule, Foo/Bar")
result = result.should_not be_nil
result["action"].should eq "enable"
result["rules"].should eq "Group/RuleName, OtherRule, Foo/Bar"
end
it "fails to parse directives with spaces" do
result = subject.match("# ameba : enable Group/RuleName") result = subject.match("# ameba : enable Group/RuleName")
result.should_not be_nil result.should be_nil
result.not_nil![1].should eq "enable"
result.not_nil![2].should eq "Group/RuleName"
end end
end end

View file

@ -28,7 +28,7 @@ module Ameba::Rule::Lint
it "reports if there are incorrect rule names" do it "reports if there are incorrect rule names" do
s = Source.new %( s = Source.new %(
# ameba:enable BadRule1,BadRule2 # ameba:enable BadRule1, BadRule2
), "source.cr" ), "source.cr"
subject.catch(s).should_not be_valid subject.catch(s).should_not be_valid
s.issues.size.should eq 1 s.issues.size.should eq 1

View file

@ -1,7 +1,7 @@
module Ameba module Ameba
# A module that utilizes inline comments parsing and processing logic. # A module that utilizes inline comments parsing and processing logic.
module InlineComments module InlineComments
COMMENT_DIRECTIVE_REGEX = Regex.new "# ameba : (\\w+) ([\\w/, ]*)".gsub(" ", "\\s*") COMMENT_DIRECTIVE_REGEX = /# ameba:(?<action>\w+) (?<rules>\w+(?:\/\w+)?(?:,? \w+(?:\/\w+)?)*)/
# Available actions in the inline comments # Available actions in the inline comments
enum Action enum Action
@ -68,10 +68,10 @@ module Ameba
# #
def parse_inline_directive(line) def parse_inline_directive(line)
if directive = COMMENT_DIRECTIVE_REGEX.match(line) if directive = COMMENT_DIRECTIVE_REGEX.match(line)
return if commented_out?(line.gsub directive[0], "") return if commented_out?(line.gsub(directive[0], ""))
{ {
action: directive[1], action: directive["action"],
rules: directive[2].split(/[\s,]/, remove_empty: true), rules: directive["rules"].split(/[\s,]/, remove_empty: true),
} }
end end
end end
@ -83,8 +83,8 @@ module Ameba
end end
end end
private def comment?(line) private def comment?(line : String)
return true if line.lstrip.starts_with? '#' line.lstrip.starts_with? '#'
end end
private def line_disabled?(line, rule) private def line_disabled?(line, rule)
@ -96,7 +96,7 @@ module Ameba
private def commented_out?(line) private def commented_out?(line)
commented = false commented = false
lexer = Crystal::Lexer.new(line).tap { |l| l.comments_enabled = true } lexer = Crystal::Lexer.new(line).tap(&.comments_enabled = true)
Tokenizer.new(lexer).run { |t| commented = true if t.type == :COMMENT } Tokenizer.new(lexer).run { |t| commented = true if t.type == :COMMENT }
commented commented
end end

View file

@ -48,7 +48,7 @@ module Ameba::Rule::Lint
private def check_rules(source, token, rules) private def check_rules(source, token, rules)
bad_names = rules - ALL_RULE_NAMES - ALL_GROUP_NAMES bad_names = rules - ALL_RULE_NAMES - ALL_GROUP_NAMES
issue_for token, "Such rules do not exist: %s" % bad_names.join(", ") if bad_names.any? issue_for token, "Such rules do not exist: %s" % bad_names.join(", ") unless bad_names.empty?
end end
end end
end end