aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMike McQuaid2017-07-07 15:11:41 +0100
committerMike McQuaid2017-07-07 15:11:41 +0100
commit9f6762d958ad8da9941c687ffe949f60267070cf (patch)
treefd44271063147f9fd299b9dec540429aa2a9697a
parent1406f89ac5ded71eac9f4493ad3f9758287aaded (diff)
downloadbrew-9f6762d958ad8da9941c687ffe949f60267070cf.tar.bz2
language/node: general cleanup.
- Avoid using a temporary variable where not necessary - Use fewer, better stubs in the tests to avoid warnings and better test the implemented functionality.
-rw-r--r--Library/Homebrew/language/node.rb3
-rw-r--r--Library/Homebrew/test/language/node_spec.rb12
2 files changed, 4 insertions, 11 deletions
diff --git a/Library/Homebrew/language/node.rb b/Library/Homebrew/language/node.rb
index eaadc54fc..ce9baea21 100644
--- a/Library/Homebrew/language/node.rb
+++ b/Library/Homebrew/language/node.rb
@@ -10,8 +10,7 @@ module Language
# fed to `npm install` only symlinks are created linking back to that
# directory, consequently breaking that assumption. We require a tarball
# because npm install creates a "real" installation when fed a tarball.
- pack_cmd = "npm pack --ignore-scripts"
- output = Utils.popen_read(pack_cmd)
+ output = Utils.popen_read("npm pack --ignore-scripts")
if !$CHILD_STATUS.exitstatus.zero? || output.lines.empty?
raise "npm failed to pack #{Dir.pwd}"
end
diff --git a/Library/Homebrew/test/language/node_spec.rb b/Library/Homebrew/test/language/node_spec.rb
index 5ddbde944..fdc3871af 100644
--- a/Library/Homebrew/test/language/node_spec.rb
+++ b/Library/Homebrew/test/language/node_spec.rb
@@ -26,25 +26,19 @@ describe Language::Node do
npm_pack_cmd = "npm pack --ignore-scripts"
it "raises error with non zero exitstatus" do
- allow(Utils).to receive(:popen_read).with(npm_pack_cmd).and_return("error msg")
- allow_any_instance_of(Process::Status).to receive(:exitstatus).and_return(42)
- allow_any_instance_of(nil::NilClass).to receive(:exitstatus).and_return(42)
+ allow(Utils).to receive(:popen_read).with(npm_pack_cmd) { `false` }
expect { subject.std_npm_install_args(npm_install_arg) }.to \
raise_error("npm failed to pack #{Dir.pwd}")
end
it "raises error with empty npm pack output" do
- allow(Utils).to receive(:popen_read).with(npm_pack_cmd).and_return("")
- allow_any_instance_of(Process::Status).to receive(:exitstatus).and_return(0)
- allow_any_instance_of(nil::NilClass).to receive(:exitstatus).and_return(0)
+ allow(Utils).to receive(:popen_read).with(npm_pack_cmd) { `true` }
expect { subject.std_npm_install_args(npm_install_arg) }.to \
raise_error("npm failed to pack #{Dir.pwd}")
end
it "does not raise error with a zero exitstatus" do
- allow(Utils).to receive(:popen_read).with(npm_pack_cmd).and_return("pack.tgz")
- allow_any_instance_of(Process::Status).to receive(:exitstatus).and_return(0)
- allow_any_instance_of(nil::NilClass).to receive(:exitstatus).and_return(0)
+ allow(Utils).to receive(:popen_read).with(npm_pack_cmd) { `echo pack.tgz` }
resp = subject.std_npm_install_args(npm_install_arg)
expect(resp).to include("--prefix=#{npm_install_arg}", "#{Dir.pwd}/pack.tgz")
end