brew/Library/Homebrew/test/utils/popen_spec.rb
Misty De Meo 847897fdac Popen spec: ensure Rubocop is happy
These were introduced in #10305 but only started going red
after that PR was merged.
2021-01-13 11:21:10 -08:00

104 lines
3.0 KiB
Ruby

# typed: false
# frozen_string_literal: true
require "utils/popen"
describe Utils do
describe "::popen_read" do
it "reads the standard output of a given command" do
expect(described_class.popen_read("sh", "-c", "echo success").chomp).to eq("success")
expect($CHILD_STATUS).to be_a_success
end
it "can be given a block to manually read from the pipe" do
expect(
described_class.popen_read("sh", "-c", "echo success") do |pipe|
pipe.read.chomp
end,
).to eq("success")
expect($CHILD_STATUS).to be_a_success
end
it "fails when the command does not exist" do
expect(described_class.popen_read("./nonexistent", err: :out))
.to eq("brew: command not found: ./nonexistent\n")
expect($CHILD_STATUS).to be_a_failure
end
end
describe "::popen_write" do
let(:foo) { mktmpdir/"foo" }
before { foo.write "Foo\n" }
it "supports writing to a command's standard input" do
described_class.popen_write("grep", "-q", "success") do |pipe|
pipe.write "success\n"
end
expect($CHILD_STATUS).to be_a_success
end
it "returns the command's standard output before writing" do
child_stdout = described_class.popen_write("cat", foo, "-") do |pipe|
pipe.write "Bar\n"
end
expect($CHILD_STATUS).to be_a_success
expect(child_stdout).to eq <<~EOS
Foo
Bar
EOS
end
it "returns the command's standard output after writing" do
child_stdout = described_class.popen_write("cat", "-", foo) do |pipe|
pipe.write "Bar\n"
end
expect($CHILD_STATUS).to be_a_success
expect(child_stdout).to eq <<~EOS
Bar
Foo
EOS
end
it "supports interleaved writing between two reads" do
child_stdout = described_class.popen_write("cat", foo, "-", foo) do |pipe|
pipe.write "Bar\n"
end
expect($CHILD_STATUS).to be_a_success
expect(child_stdout).to eq <<~EOS
Foo
Bar
Foo
EOS
end
end
describe "::safe_popen_read" do
it "does not raise an error if the command succeeds" do
expect(described_class.safe_popen_read("sh", "-c", "true")).to eq("")
expect($CHILD_STATUS).to be_a_success
end
it "raises an error if the command fails" do
expect { described_class.safe_popen_read("sh", "-c", "false") }.to raise_error(ErrorDuringExecution)
expect($CHILD_STATUS).to be_a_failure
end
end
describe "::safe_popen_write" do
it "does not raise an error if the command succeeds" do
expect(
described_class.safe_popen_write("grep", "success") { |pipe| pipe.write "success\n" }.chomp,
).to eq("success")
expect($CHILD_STATUS).to be_a_success
end
it "raises an error if the command fails" do
expect {
described_class.safe_popen_write("grep", "success") { |pipe| pipe.write "failure\n" }
}.to raise_error(ErrorDuringExecution)
expect($CHILD_STATUS).to be_a_failure
end
end
end