2017-12-08 17:40:11 +00:00
|
|
|
require "../../spec_helper"
|
|
|
|
require "../../../src/ameba/cli/cmd"
|
|
|
|
|
|
|
|
module Ameba::Cli
|
|
|
|
describe "Cmd" do
|
|
|
|
describe ".run" do
|
|
|
|
it "runs ameba" do
|
2023-11-17 15:37:27 +00:00
|
|
|
r = Cli.run %w[-f silent -c spec/fixtures/config.yml spec/fixtures/source.cr]
|
2017-12-08 17:40:11 +00:00
|
|
|
r.should be_nil
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe ".parse_args" do
|
2023-11-17 15:37:27 +00:00
|
|
|
%w[-s --silent].each do |flag|
|
2023-11-11 18:03:28 +00:00
|
|
|
it "accepts #{flag} flag" do
|
|
|
|
c = Cli.parse_args [flag]
|
2017-12-08 17:40:11 +00:00
|
|
|
c.formatter.should eq :silent
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2023-11-17 15:37:27 +00:00
|
|
|
%w[-c --config].each do |flag|
|
2023-11-11 18:03:28 +00:00
|
|
|
it "accepts #{flag} flag" do
|
|
|
|
c = Cli.parse_args [flag, "config.yml"]
|
2023-03-06 04:32:55 +00:00
|
|
|
c.config.should eq Path["config.yml"]
|
2017-12-08 17:40:11 +00:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2023-11-17 15:37:27 +00:00
|
|
|
%w[-f --format].each do |flag|
|
2023-11-11 18:03:28 +00:00
|
|
|
it "accepts #{flag} flag" do
|
|
|
|
c = Cli.parse_args [flag, "my-formatter"]
|
2017-12-08 17:40:11 +00:00
|
|
|
c.formatter.should eq "my-formatter"
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
it "accepts --only flag" do
|
|
|
|
c = Cli.parse_args ["--only", "RULE1,RULE2"]
|
2023-11-17 15:37:27 +00:00
|
|
|
c.only.should eq %w[RULE1 RULE2]
|
2017-12-08 17:40:11 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
it "accepts --except flag" do
|
|
|
|
c = Cli.parse_args ["--except", "RULE1,RULE2"]
|
2023-11-17 15:37:27 +00:00
|
|
|
c.except.should eq %w[RULE1 RULE2]
|
2017-12-08 17:40:11 +00:00
|
|
|
end
|
|
|
|
|
2021-01-09 19:48:18 +00:00
|
|
|
it "defaults rules? flag to false" do
|
2023-11-17 15:37:27 +00:00
|
|
|
c = Cli.parse_args %w[spec/fixtures/source.cr]
|
2023-03-09 04:39:25 +00:00
|
|
|
c.rules?.should be_false
|
2021-01-09 19:48:18 +00:00
|
|
|
end
|
|
|
|
|
2023-03-08 18:23:48 +00:00
|
|
|
it "defaults skip_reading_config? flag to false" do
|
2023-11-17 15:37:27 +00:00
|
|
|
c = Cli.parse_args %w[spec/fixtures/source.cr]
|
2023-03-09 04:39:25 +00:00
|
|
|
c.skip_reading_config?.should be_false
|
2023-03-08 18:23:48 +00:00
|
|
|
end
|
|
|
|
|
2021-01-09 19:48:18 +00:00
|
|
|
it "accepts --rules flag" do
|
2023-11-17 15:37:27 +00:00
|
|
|
c = Cli.parse_args %w[--rules]
|
2021-01-09 19:48:18 +00:00
|
|
|
c.rules?.should eq true
|
|
|
|
end
|
|
|
|
|
2018-07-04 12:20:35 +00:00
|
|
|
it "defaults all? flag to false" do
|
2023-11-17 15:37:27 +00:00
|
|
|
c = Cli.parse_args %w[spec/fixtures/source.cr]
|
2023-03-09 04:39:25 +00:00
|
|
|
c.all?.should be_false
|
2018-07-04 12:20:35 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
it "accepts --all flag" do
|
2023-11-17 15:37:27 +00:00
|
|
|
c = Cli.parse_args %w[--all]
|
2018-07-04 12:20:35 +00:00
|
|
|
c.all?.should eq true
|
|
|
|
end
|
|
|
|
|
2017-12-08 17:40:11 +00:00
|
|
|
it "accepts --gen-config flag" do
|
2023-11-17 15:37:27 +00:00
|
|
|
c = Cli.parse_args %w[--gen-config]
|
2017-12-08 17:40:11 +00:00
|
|
|
c.formatter.should eq :todo
|
|
|
|
end
|
|
|
|
|
2018-08-12 21:04:39 +00:00
|
|
|
it "accepts --no-color flag" do
|
2023-11-17 15:37:27 +00:00
|
|
|
c = Cli.parse_args %w[--no-color]
|
2018-08-12 21:04:39 +00:00
|
|
|
c.colors?.should be_false
|
|
|
|
end
|
|
|
|
|
2018-12-12 19:45:00 +00:00
|
|
|
it "accepts --without-affected-code flag" do
|
2023-11-17 15:37:27 +00:00
|
|
|
c = Cli.parse_args %w[--without-affected-code]
|
2018-12-12 19:45:00 +00:00
|
|
|
c.without_affected_code?.should be_true
|
|
|
|
end
|
|
|
|
|
2018-08-12 21:04:39 +00:00
|
|
|
it "doesn't disable colors by default" do
|
2023-11-17 15:37:27 +00:00
|
|
|
c = Cli.parse_args %w[--all]
|
2018-08-12 21:04:39 +00:00
|
|
|
c.colors?.should be_true
|
|
|
|
end
|
|
|
|
|
2023-03-08 13:35:31 +00:00
|
|
|
it "ignores --config if --gen-config flag passed" do
|
2023-11-17 15:37:27 +00:00
|
|
|
c = Cli.parse_args %w[--gen-config --config my_config.yml]
|
2023-03-08 13:35:31 +00:00
|
|
|
c.formatter.should eq :todo
|
|
|
|
c.skip_reading_config?.should be_true
|
|
|
|
end
|
|
|
|
|
2018-12-27 21:34:10 +00:00
|
|
|
describe "-e/--explain" do
|
|
|
|
it "configures file/line/column" do
|
2023-11-17 15:37:27 +00:00
|
|
|
c = Cli.parse_args %w[--explain spec/fixtures/source.cr:3:5]
|
2018-12-27 21:34:10 +00:00
|
|
|
|
2022-10-28 22:03:39 +00:00
|
|
|
location_to_explain = c.location_to_explain.should_not be_nil
|
2023-07-27 08:24:19 +00:00
|
|
|
location_to_explain[:file].should eq "spec/fixtures/source.cr"
|
2018-12-27 21:34:10 +00:00
|
|
|
location_to_explain[:line].should eq 3
|
|
|
|
location_to_explain[:column].should eq 5
|
|
|
|
end
|
|
|
|
|
|
|
|
it "raises an error if location is not valid" do
|
|
|
|
expect_raises(Exception, "location should have PATH:line:column") do
|
2023-11-17 15:37:27 +00:00
|
|
|
Cli.parse_args %w[--explain spec/fixtures/source.cr:3]
|
2018-12-27 21:34:10 +00:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
it "raises an error if line number is not valid" do
|
|
|
|
expect_raises(Exception, "location should have PATH:line:column") do
|
2023-11-17 15:37:27 +00:00
|
|
|
Cli.parse_args %w[--explain spec/fixtures/source.cr:a:3]
|
2018-12-27 21:34:10 +00:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
it "raises an error if column number is not valid" do
|
|
|
|
expect_raises(Exception, "location should have PATH:line:column") do
|
2023-11-17 15:37:27 +00:00
|
|
|
Cli.parse_args %w[--explain spec/fixtures/source.cr:3:&]
|
2018-12-27 21:34:10 +00:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
it "raises an error if line/column are missing" do
|
|
|
|
expect_raises(Exception, "location should have PATH:line:column") do
|
2023-11-17 15:37:27 +00:00
|
|
|
Cli.parse_args %w[--explain spec/fixtures/source.cr]
|
2018-12-27 21:34:10 +00:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2019-04-14 12:57:48 +00:00
|
|
|
context "--fail-level" do
|
2019-05-11 18:17:18 +00:00
|
|
|
it "configures fail level Convention" do
|
2023-11-17 15:37:27 +00:00
|
|
|
c = Cli.parse_args %w[--fail-level convention]
|
2019-05-11 18:17:18 +00:00
|
|
|
c.fail_level.should eq Severity::Convention
|
2019-04-14 12:57:48 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
it "configures fail level Warning" do
|
2023-11-17 15:37:27 +00:00
|
|
|
c = Cli.parse_args %w[--fail-level Warning]
|
2019-04-14 12:57:48 +00:00
|
|
|
c.fail_level.should eq Severity::Warning
|
|
|
|
end
|
|
|
|
|
|
|
|
it "configures fail level Error" do
|
2023-11-17 15:37:27 +00:00
|
|
|
c = Cli.parse_args %w[--fail-level error]
|
2019-04-14 12:57:48 +00:00
|
|
|
c.fail_level.should eq Severity::Error
|
|
|
|
end
|
|
|
|
|
|
|
|
it "raises if fail level is incorrect" do
|
|
|
|
expect_raises(Exception, "Incorrect severity name JohnDoe") do
|
2023-11-17 15:37:27 +00:00
|
|
|
Cli.parse_args %w[--fail-level JohnDoe]
|
2019-04-14 12:57:48 +00:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2019-01-12 21:19:00 +00:00
|
|
|
it "accepts unknown args as globs" do
|
2023-11-17 15:37:27 +00:00
|
|
|
c = Cli.parse_args %w[source1.cr source2.cr]
|
|
|
|
c.globs.should eq %w[source1.cr source2.cr]
|
2017-12-08 17:40:11 +00:00
|
|
|
end
|
|
|
|
|
2018-12-27 21:34:10 +00:00
|
|
|
it "accepts one unknown arg as explain location if it has correct format" do
|
2023-11-17 15:37:27 +00:00
|
|
|
c = Cli.parse_args %w[source.cr:3:22]
|
2018-12-27 21:34:10 +00:00
|
|
|
|
2022-10-28 22:03:39 +00:00
|
|
|
location_to_explain = c.location_to_explain.should_not be_nil
|
2018-12-27 21:34:10 +00:00
|
|
|
location_to_explain[:file].should eq "source.cr"
|
|
|
|
location_to_explain[:line].should eq 3
|
|
|
|
location_to_explain[:column].should eq 22
|
|
|
|
end
|
|
|
|
|
2017-12-08 17:40:11 +00:00
|
|
|
it "allows args to be blank" do
|
|
|
|
c = Cli.parse_args [] of String
|
2018-01-25 14:40:32 +00:00
|
|
|
c.formatter.should be_nil
|
2019-01-12 21:19:00 +00:00
|
|
|
c.globs.should be_nil
|
2017-12-08 17:40:11 +00:00
|
|
|
c.only.should be_nil
|
|
|
|
c.except.should be_nil
|
2023-03-06 04:32:55 +00:00
|
|
|
c.config.should be_nil
|
2017-12-08 17:40:11 +00:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|