brew/Library/Homebrew/test/error_during_execution_spec.rb

67 lines
1.8 KiB
Ruby
Raw Normal View History

# frozen_string_literal: true
RSpec.describe ErrorDuringExecution do
2018-07-19 13:31:48 +02:00
subject(:error) { described_class.new(command, status: status, output: output) }
2018-09-20 09:07:56 +01:00
2018-07-19 13:31:48 +02:00
let(:command) { ["false"] }
let(:status) { instance_double(Process::Status, exitstatus: exitstatus, termsig: nil) }
2018-07-19 13:31:48 +02:00
let(:exitstatus) { 1 }
let(:output) { nil }
describe "#initialize" do
it "fails when only given a command" do
expect do
2018-07-19 13:31:48 +02:00
described_class.new(command)
end.to raise_error(ArgumentError)
2018-07-19 13:31:48 +02:00
end
it "fails when only given a status" do
expect do
2018-07-19 13:31:48 +02:00
described_class.new(status: status)
end.to raise_error(ArgumentError)
2018-07-19 13:31:48 +02:00
end
it "does not raise an error when given both a command and a status" do
expect do
2018-07-19 13:31:48 +02:00
described_class.new(command, status: status)
end.not_to raise_error
2018-07-19 13:31:48 +02:00
end
end
describe "#to_s" do
context "when only given a command and a status" do
its(:to_s) { is_expected.to eq "Failure while executing; `false` exited with 1." }
end
context "when additionally given the output" do
let(:output) do
2018-07-19 13:31:48 +02:00
[
[:stdout, "This still worked.\n"],
[:stderr, "Here something went wrong.\n"],
]
end
2018-07-19 13:31:48 +02:00
before do
allow($stdout).to receive(:tty?).and_return(true)
end
its(:to_s) do
expect(error.to_s).to eq <<~EOS
2018-07-19 13:31:48 +02:00
Failure while executing; `false` exited with 1. Here's the output:
This still worked.
#{Formatter.error("Here something went wrong.\n")}
EOS
end
2018-07-19 13:31:48 +02:00
end
context "when command arguments contain special characters" do
let(:command) { ["env", "PATH=/bin", "cat", "with spaces"] }
its(:to_s) do
expect(error.to_s)
.to eq 'Failure while executing; `env PATH=/bin cat with\ spaces` exited with 1.'
end
2018-07-19 13:31:48 +02:00
end
end
end