diff options
author | Samuel Giddins <segiddins@segiddins.me> | 2016-03-28 21:08:13 -0500 |
---|---|---|
committer | Samuel Giddins <segiddins@segiddins.me> | 2016-03-28 21:08:13 -0500 |
commit | e3f278959756d61f966a2f6f4e54b75838d4aa21 (patch) | |
tree | 668f417122e217f6a15a719ab4e94f286db331cd /spec/support/helpers.rb | |
parent | d716a0ada398f53cd0ecf5e1708d10426e3833eb (diff) | |
download | bundler-seg-sys-exec.tar.gz |
Rewrite Spec::Helpers#sys_execseg-sys-exec
In testing, this reduces time spent in sys_exec by ~12%
Diffstat (limited to 'spec/support/helpers.rb')
-rw-r--r-- | spec/support/helpers.rb | 15 |
1 files changed, 4 insertions, 11 deletions
diff --git a/spec/support/helpers.rb b/spec/support/helpers.rb index 60c1c6f42f..0f10f5f677 100644 --- a/spec/support/helpers.rb +++ b/spec/support/helpers.rb @@ -2,9 +2,6 @@ module Spec module Helpers def reset! - @in_p = nil - @out_p = nil - @err_p = nil Dir["#{tmp}/{gems/*,*}"].each do |dir| next if %(base remote1 gems rubygems).include?(File.basename(dir)) if ENV["BUNDLER_SUDO_TESTS"] @@ -152,15 +149,11 @@ module Spec def sys_exec(cmd, expect_err = false) Open3.popen3(cmd.to_s) do |stdin, stdout, stderr, wait_thr| - @in_p = stdin - @out_p = stdout - @err_p = stderr + yield stdin if block_given? + stdin.close - yield @in_p if block_given? - @in_p.close - - @out = @out_p.read_available_bytes.strip - @err = @err_p.read_available_bytes.strip + @out = Thread.new { stdout.read }.value.strip + @err = Thread.new { stderr.read }.value.strip @exitstatus = wait_thr && wait_thr.value.exitstatus end |