mixlib-shellout 3.2.8 → 3.3.4

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: a15c2e90bbfd59704b7937e4b28cb46579f55b1f98a28a2b752002f9e8d05f2a
4
- data.tar.gz: ceddbac62cc7505044d34310ec89c0c9cc5e663a6681d34d7a2bee50ef49f4e2
3
+ metadata.gz: 49b9ac59dc9b686824b628b2cc5e616cdcca707ec3d60dc87b025fb8ae18d4dd
4
+ data.tar.gz: 18d6456f265caa913d37a8ffedc2c66514e381e090cc0a1c8d32b5cf8c4adee3
5
5
  SHA512:
6
- metadata.gz: 5d53cd0b6d622eb4aac19f3cdb140b4de04b65786499653771245578baf007641c999e04cfd9468348dcf5a97ed7840a7cbba3a83e4911171d0aea918cda3dad
7
- data.tar.gz: 130c34af750fc00204641001a3375735fba96cd956b65cc6e7ec402c46d2473f531f9602ff09aab560ae21aed7bb63951c44928fcb63d2d01c77c2488b0c2c60
6
+ metadata.gz: 1b24be2169c4086dd2de0d26c54b89ffae4474513b2ec55f9957fb446aa2ce0f03a4464f3e735869c35820a91b6d7e3823fa5780e11efe4e7947ea2820ab448c
7
+ data.tar.gz: 8e683c0a522719a7b3ede0e9d33f93906ba58cacf79d4b4d834a225815c762f2492c41b99ed3577b326728b6386ac949b7a25da694def49aacae0f1d1e34830a
@@ -141,9 +141,39 @@ module Mixlib
141
141
  args.flatten.compact.map(&:to_s)
142
142
  end
143
143
 
144
+ # Join arguments into a string.
145
+ #
146
+ # Strips leading/trailing spaces from each argument. If an argument contains
147
+ # a space, it is quoted. Join into a single string with spaces between each argument.
148
+ #
149
+ # @param args [String] variable number of string arguments
150
+ # @return [String] merged string
151
+ #
152
+ def __join_whitespace(*args)
153
+ args.flatten.map do |arg|
154
+ arg.strip!
155
+ arg.include?(" ") ? sprintf('"%s"', arg) : arg
156
+ end.join(" ")
157
+ end
158
+
144
159
  def __shell_out_command(*args, **options)
145
160
  if __transport_connection
146
- FakeShellOut.new(args, options, __transport_connection.run_command(args.join(" "))) # FIXME: train should accept run_command(*args)
161
+ command = __join_whitespace(args)
162
+ unless ChefUtils.windows?
163
+ if options[:cwd]
164
+ # as `timeout` is used, commands need to be executed in a subshell
165
+ command = "sh -c 'cd #{options[:cwd]}; #{command}'"
166
+ end
167
+
168
+ if options[:input]
169
+ command.concat "<<'COMMANDINPUT'\n"
170
+ command.concat __join_whitespace(options[:input])
171
+ command.concat "COMMANDINPUT\n"
172
+ end
173
+ end
174
+
175
+ # FIXME: train should accept run_command(*args)
176
+ FakeShellOut.new(args, options, __transport_connection.run_command(command, options))
147
177
  else
148
178
  cmd = if options.empty?
149
179
  Mixlib::ShellOut.new(*args)
@@ -181,15 +211,16 @@ module Mixlib
181
211
  @stdout = result.stdout
182
212
  @stderr = result.stderr
183
213
  @exitstatus = result.exit_status
184
- @status = OpenStruct.new(success?: ( exitstatus == 0 ))
214
+ @valid_exit_codes = Array(options[:returns] || 0)
215
+ @status = OpenStruct.new(success?: (@valid_exit_codes.include? exitstatus))
185
216
  end
186
217
 
187
218
  def error?
188
- exitstatus != 0
219
+ @valid_exit_codes.none?(exitstatus)
189
220
  end
190
221
 
191
222
  def error!
192
- raise Mixlib::ShellOut::ShellCommandFailed, "Unexpected exit status of #{exitstatus} running #{@args}" if error?
223
+ raise Mixlib::ShellOut::ShellCommandFailed, "Unexpected exit status of #{exitstatus} running #{@args}: #{stderr}" if error?
193
224
  end
194
225
  end
195
226
  end
@@ -20,11 +20,6 @@ module Mixlib
20
20
  class ShellOut
21
21
  module Unix
22
22
 
23
- # "1.8.7" as a frozen string. We use this with a hack that disables GC to
24
- # avoid segfaults on Ruby 1.8.7, so we need to allocate the fewest
25
- # objects we possibly can.
26
- ONE_DOT_EIGHT_DOT_SEVEN = "1.8.7".freeze
27
-
28
23
  # Option validation that is unix specific
29
24
  def validate_options(opts)
30
25
  if opts[:elevated]
@@ -99,12 +94,6 @@ module Mixlib
99
94
 
100
95
  configure_parent_process_file_descriptors
101
96
 
102
- # Ruby 1.8.7 and 1.8.6 from mid 2009 try to allocate objects during GC
103
- # when calling IO.select and IO#read. Disabling GC works around the
104
- # segfault, but obviously it's a bad workaround. We no longer support
105
- # 1.8.6 so we only need this hack for 1.8.7.
106
- GC.disable if RUBY_VERSION == ONE_DOT_EIGHT_DOT_SEVEN
107
-
108
97
  # CHEF-3390: Marshall.load on Ruby < 1.8.7p369 also has a GC bug related
109
98
  # to Marshall.load, so try disabling GC first.
110
99
  propagate_pre_exec_failure
@@ -1,5 +1,5 @@
1
1
  module Mixlib
2
2
  class ShellOut
3
- VERSION = "3.2.8".freeze
3
+ VERSION = "3.3.4".freeze
4
4
  end
5
5
  end
@@ -60,6 +60,7 @@ module Mixlib
60
60
  stderr_read, stderr_write = IO.pipe
61
61
  stdin_read, stdin_write = IO.pipe
62
62
  open_streams = [ stdout_read, stderr_read ]
63
+ @execution_time = 0
63
64
 
64
65
  begin
65
66
 
@@ -105,6 +106,8 @@ module Mixlib
105
106
  wait_status = WaitForSingleObject(process.process_handle, 0)
106
107
  case wait_status
107
108
  when WAIT_OBJECT_0
109
+ # Save the execution time
110
+ @execution_time = Time.now - start_wait
108
111
  # Get process exit code
109
112
  exit_code = [0].pack("l")
110
113
  unless GetExitCodeProcess(process.process_handle, exit_code)
@@ -127,6 +130,9 @@ module Mixlib
127
130
  logger&.warn("Failed to kill timed out process #{process.process_id}")
128
131
  end
129
132
 
133
+ # Save the execution time
134
+ @execution_time = Time.now - start_wait
135
+
130
136
  raise Mixlib::ShellOut::CommandTimeout, [
131
137
  "command timed out:",
132
138
  format_for_exception,
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: mixlib-shellout
3
3
  version: !ruby/object:Gem::Version
4
- version: 3.2.8
4
+ version: 3.3.4
5
5
  platform: ruby
6
6
  authors:
7
7
  - Chef Software Inc.
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2024-06-08 00:00:00.000000000 Z
11
+ date: 2024-10-29 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: chef-utils