2022-10-30 17:14:11 +00:00
|
|
|
require "../../../spec_helper"
|
|
|
|
|
|
|
|
module Ameba::Rule::Lint
|
|
|
|
subject = NotNil.new
|
|
|
|
|
|
|
|
describe NotNil do
|
|
|
|
it "passes for valid cases" do
|
|
|
|
expect_no_issues subject, <<-CRYSTAL
|
|
|
|
(1..3).first?.not_nil!(:foo)
|
|
|
|
not_nil!
|
|
|
|
CRYSTAL
|
|
|
|
end
|
|
|
|
|
|
|
|
it "reports if there is a `not_nil!` call" do
|
|
|
|
expect_issue subject, <<-CRYSTAL
|
|
|
|
(1..3).first?.not_nil!
|
|
|
|
# ^^^^^^^^ error: Avoid using `not_nil!`
|
|
|
|
CRYSTAL
|
|
|
|
end
|
|
|
|
|
2022-12-08 13:07:10 +00:00
|
|
|
it "reports if there is a `not_nil!` call in the middle of the call-chain" do
|
|
|
|
expect_issue subject, <<-CRYSTAL
|
|
|
|
(1..3).first?.not_nil!.to_s
|
|
|
|
# ^^^^^^^^ error: Avoid using `not_nil!`
|
|
|
|
CRYSTAL
|
|
|
|
end
|
|
|
|
|
2022-10-30 17:14:11 +00:00
|
|
|
context "macro" do
|
|
|
|
it "doesn't report in macro scope" do
|
|
|
|
expect_no_issues subject, <<-CRYSTAL
|
|
|
|
{{ [1, 2, 3].first.not_nil! }}
|
|
|
|
CRYSTAL
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|