2017-02-03 14:05:07 +01:00
|
|
|
require "open3"
|
|
|
|
require "rubygems"
|
2016-08-18 22:11:42 +03:00
|
|
|
|
2017-03-06 04:31:16 +01:00
|
|
|
describe Hbc::CLI::Style, :cask do
|
2016-08-18 22:11:42 +03:00
|
|
|
let(:args) { [] }
|
2017-05-20 03:46:52 +02:00
|
|
|
let(:cli) { described_class.new(*args) }
|
2016-08-18 22:11:42 +03:00
|
|
|
|
|
|
|
around do |example|
|
|
|
|
shutup { example.run }
|
|
|
|
end
|
|
|
|
|
|
|
|
describe "#run" do
|
|
|
|
subject { cli.run }
|
|
|
|
|
|
|
|
before do
|
|
|
|
allow(cli).to receive_messages(install_rubocop: nil,
|
|
|
|
system: nil,
|
|
|
|
rubocop_args: nil,
|
|
|
|
cask_paths: nil)
|
|
|
|
allow($CHILD_STATUS).to receive(:success?).and_return(success)
|
|
|
|
end
|
|
|
|
|
|
|
|
context "when rubocop succeeds" do
|
|
|
|
let(:success) { true }
|
|
|
|
it { is_expected.to be_truthy }
|
|
|
|
end
|
|
|
|
|
|
|
|
context "when rubocop fails" do
|
|
|
|
let(:success) { false }
|
2017-05-20 03:46:52 +02:00
|
|
|
|
|
|
|
it "raises an error" do
|
|
|
|
expect { subject }.to raise_error(Hbc::CaskError)
|
|
|
|
end
|
2016-08-18 22:11:42 +03:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe "#install_rubocop" do
|
|
|
|
subject { cli.install_rubocop }
|
|
|
|
|
|
|
|
context "when installation succeeds" do
|
|
|
|
before do
|
2017-05-07 17:28:39 +01:00
|
|
|
allow(Homebrew).to receive(:install_gem_setup_path!)
|
2016-08-18 22:11:42 +03:00
|
|
|
end
|
|
|
|
|
|
|
|
it "exits successfully" do
|
2016-08-27 11:52:14 +02:00
|
|
|
expect { subject }.not_to raise_error
|
2016-08-18 22:11:42 +03:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context "when installation fails" do
|
|
|
|
before do
|
2017-05-07 17:28:39 +01:00
|
|
|
allow(Homebrew).to receive(:install_gem_setup_path!).and_raise(SystemExit)
|
2016-08-18 22:11:42 +03:00
|
|
|
end
|
|
|
|
|
|
|
|
it "raises an error" do
|
|
|
|
expect { subject }.to raise_error(Hbc::CaskError)
|
|
|
|
end
|
|
|
|
end
|
2017-02-03 14:05:07 +01:00
|
|
|
|
|
|
|
context "version" do
|
2017-04-22 12:26:18 +01:00
|
|
|
it "matches `HOMEBREW_RUBOCOP_VERSION`", :needs_network do
|
2017-02-03 14:05:07 +01:00
|
|
|
stdout, status = Open3.capture2("gem", "dependency", "rubocop-cask", "--version", HOMEBREW_RUBOCOP_CASK_VERSION, "--pipe", "--remote")
|
|
|
|
|
|
|
|
expect(status).to be_a_success
|
|
|
|
|
|
|
|
requirement = Gem::Requirement.new(stdout.scan(/rubocop --version '(.*)'/).flatten.first)
|
|
|
|
version = Gem::Version.new(HOMEBREW_RUBOCOP_VERSION)
|
|
|
|
|
|
|
|
expect(requirement).not_to be_none
|
|
|
|
expect(requirement).to be_satisfied_by(version)
|
|
|
|
end
|
|
|
|
end
|
2016-08-18 22:11:42 +03:00
|
|
|
end
|
|
|
|
|
|
|
|
describe "#cask_paths" do
|
|
|
|
subject { cli.cask_paths }
|
|
|
|
|
|
|
|
before do
|
2017-05-21 02:32:46 +02:00
|
|
|
allow(cli).to receive(:args).and_return(tokens)
|
2016-08-18 22:11:42 +03:00
|
|
|
end
|
|
|
|
|
|
|
|
context "when no cask tokens are given" do
|
|
|
|
let(:tokens) { [] }
|
|
|
|
|
|
|
|
before do
|
|
|
|
allow(Hbc).to receive(:all_tapped_cask_dirs).and_return(%w[Casks MoreCasks])
|
|
|
|
end
|
|
|
|
|
|
|
|
it { is_expected.to eq(%w[Casks MoreCasks]) }
|
|
|
|
end
|
|
|
|
|
|
|
|
context "when at least one cask token is a path that exists" do
|
|
|
|
let(:tokens) { ["adium", "Casks/dropbox.rb"] }
|
|
|
|
before do
|
|
|
|
allow(File).to receive(:exist?).and_return(false, true)
|
|
|
|
end
|
|
|
|
|
|
|
|
it "treats all tokens as paths" do
|
|
|
|
expect(subject).to eq(tokens)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context "when no cask tokens are paths that exist" do
|
|
|
|
let(:tokens) { %w[adium dropbox] }
|
|
|
|
before do
|
|
|
|
allow(File).to receive(:exist?).and_return(false)
|
|
|
|
end
|
|
|
|
|
|
|
|
it "tries to find paths for all tokens" do
|
2017-03-13 01:01:17 +01:00
|
|
|
expect(Hbc::CaskLoader).to receive(:path).twice
|
2016-08-18 22:11:42 +03:00
|
|
|
subject
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe "#rubocop_args" do
|
|
|
|
subject { cli.rubocop_args }
|
|
|
|
|
|
|
|
before do
|
|
|
|
allow(cli).to receive(:fix?).and_return(fix)
|
|
|
|
end
|
|
|
|
|
|
|
|
context "when fix? is true" do
|
|
|
|
let(:fix) { true }
|
|
|
|
it { is_expected.to include("--auto-correct") }
|
|
|
|
end
|
|
|
|
|
|
|
|
context "when fix? is false" do
|
|
|
|
let(:fix) { false }
|
|
|
|
it { is_expected.not_to include("--auto-correct") }
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe "#default_args" do
|
|
|
|
subject { cli.default_args }
|
|
|
|
|
2016-10-18 16:10:36 +02:00
|
|
|
it { is_expected.to include("--require", "rubocop-cask", "--format", "simple", "--force-exclusion") }
|
2016-08-18 22:11:42 +03:00
|
|
|
end
|
|
|
|
|
|
|
|
describe "#autocorrect_args" do
|
|
|
|
subject { cli.autocorrect_args }
|
|
|
|
let(:default_args) { ["--format", "simple"] }
|
|
|
|
|
|
|
|
it "should add --auto-correct to default args" do
|
|
|
|
allow(cli).to receive(:default_args).and_return(default_args)
|
|
|
|
expect(subject).to include("--auto-correct", *default_args)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|