puppet 8.6.0-universal-darwin → 8.7.0-universal-darwin
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/Gemfile +6 -2
- data/Gemfile.lock +42 -38
- data/Rakefile +45 -22
- data/examples/hiera/README.md +68 -57
- data/examples/hiera/data/common.yaml +12 -0
- data/examples/hiera/data/dc1.yaml +6 -0
- data/examples/hiera/hiera.yaml +15 -0
- data/examples/hiera/modules/ntp/data/common.yaml +4 -0
- data/examples/hiera/modules/ntp/hiera.yaml +9 -0
- data/examples/hiera/modules/ntp/manifests/config.pp +16 -4
- data/examples/hiera/modules/ntp/templates/ntp.conf.epp +3 -0
- data/examples/hiera/modules/users/manifests/common.pp +7 -2
- data/examples/hiera/modules/users/manifests/dc1.pp +7 -2
- data/examples/hiera/site.pp +1 -1
- data/ext/project_data.yaml +0 -45
- data/lib/puppet/daemon.rb +1 -0
- data/lib/puppet/pops/loader/static_loader.rb +2 -2
- data/lib/puppet/pops/lookup/module_data_provider.rb +9 -9
- data/lib/puppet/provider/aix_object.rb +1 -1
- data/lib/puppet/provider/group/groupadd.rb +30 -9
- data/lib/puppet/provider/package/xbps.rb +127 -0
- data/lib/puppet/scheduler/splay_job.rb +9 -0
- data/lib/puppet/type/exec.rb +8 -0
- data/lib/puppet/util/command_line/trollop.rb +20 -2
- data/lib/puppet/util/rpm_compare.rb +1 -1
- data/lib/puppet/util/windows/com.rb +2 -2
- data/lib/puppet/version.rb +1 -1
- data/locales/puppet.pot +604 -600
- data/man/man5/puppet.conf.5 +2 -2
- data/man/man8/puppet-agent.8 +1 -1
- data/man/man8/puppet-apply.8 +1 -1
- data/man/man8/puppet-catalog.8 +1 -1
- data/man/man8/puppet-config.8 +1 -1
- data/man/man8/puppet-describe.8 +1 -1
- data/man/man8/puppet-device.8 +1 -1
- data/man/man8/puppet-doc.8 +1 -1
- data/man/man8/puppet-epp.8 +1 -1
- data/man/man8/puppet-facts.8 +1 -1
- data/man/man8/puppet-filebucket.8 +1 -1
- data/man/man8/puppet-generate.8 +1 -1
- data/man/man8/puppet-help.8 +1 -1
- data/man/man8/puppet-lookup.8 +1 -1
- data/man/man8/puppet-module.8 +1 -1
- data/man/man8/puppet-node.8 +1 -1
- data/man/man8/puppet-parser.8 +1 -1
- data/man/man8/puppet-plugin.8 +1 -1
- data/man/man8/puppet-report.8 +1 -1
- data/man/man8/puppet-resource.8 +1 -1
- data/man/man8/puppet-script.8 +1 -1
- data/man/man8/puppet-ssl.8 +1 -1
- data/man/man8/puppet.8 +2 -2
- metadata +23 -27
- data/examples/hiera/etc/hiera.yaml +0 -15
- data/examples/hiera/etc/hieradb/common.yaml +0 -3
- data/examples/hiera/etc/hieradb/dc1.yaml +0 -6
- data/examples/hiera/etc/hieradb/development.yaml +0 -2
- data/examples/hiera/etc/puppet.conf +0 -3
- data/examples/hiera/modules/data/manifests/common.pp +0 -4
- data/examples/hiera/modules/ntp/manifests/data.pp +0 -4
- data/examples/hiera/modules/ntp/templates/ntp.conf.erb +0 -3
- data/examples/hiera/modules/users/manifests/development.pp +0 -4
- data/tasks/benchmark.rake +0 -180
- data/tasks/cfpropertylist.rake +0 -15
- data/tasks/ci.rake +0 -24
- data/tasks/generate_ast_model.rake +0 -90
- data/tasks/generate_cert_fixtures.rake +0 -199
- data/tasks/manpages.rake +0 -67
- data/tasks/memwalk.rake +0 -195
- data/tasks/parallel.rake +0 -410
- data/tasks/parser.rake +0 -22
- data/tasks/yard.rake +0 -59
data/tasks/parallel.rake
DELETED
@@ -1,410 +0,0 @@
|
|
1
|
-
# encoding: utf-8
|
2
|
-
|
3
|
-
require 'rubygems'
|
4
|
-
require 'thread'
|
5
|
-
begin
|
6
|
-
require 'rspec'
|
7
|
-
require 'rspec/core/formatters/helpers'
|
8
|
-
require 'etc'
|
9
|
-
rescue LoadError
|
10
|
-
# Don't define the task if we don't have rspec present
|
11
|
-
else
|
12
|
-
module Parallel
|
13
|
-
module RSpec
|
14
|
-
#
|
15
|
-
# Responsible for buffering the output of RSpec's progress formatter.
|
16
|
-
#
|
17
|
-
class ProgressFormatBuffer
|
18
|
-
attr_reader :pending_lines
|
19
|
-
attr_reader :failure_lines
|
20
|
-
attr_reader :examples
|
21
|
-
attr_reader :failures
|
22
|
-
attr_reader :pending
|
23
|
-
attr_reader :failed_example_lines
|
24
|
-
attr_reader :state
|
25
|
-
|
26
|
-
module OutputState
|
27
|
-
HEADER = 1
|
28
|
-
PROGRESS = 2
|
29
|
-
SUMMARY = 3
|
30
|
-
PENDING = 4
|
31
|
-
FAILURES = 5
|
32
|
-
DURATION = 6
|
33
|
-
COUNTS = 7
|
34
|
-
FAILED_EXAMPLES = 8
|
35
|
-
end
|
36
|
-
|
37
|
-
def initialize(io, color)
|
38
|
-
@io = io
|
39
|
-
@color = color
|
40
|
-
@state = OutputState::HEADER
|
41
|
-
@pending_lines = []
|
42
|
-
@failure_lines = []
|
43
|
-
@examples = 0
|
44
|
-
@failures = 0
|
45
|
-
@pending = 0
|
46
|
-
@failed_example_lines = []
|
47
|
-
end
|
48
|
-
|
49
|
-
def color?
|
50
|
-
@color
|
51
|
-
end
|
52
|
-
|
53
|
-
def read
|
54
|
-
# Parse and ignore the one line header
|
55
|
-
if @state == OutputState::HEADER
|
56
|
-
begin
|
57
|
-
@io.readline
|
58
|
-
rescue EOFError
|
59
|
-
return nil
|
60
|
-
end
|
61
|
-
@state = OutputState::PROGRESS
|
62
|
-
return ''
|
63
|
-
end
|
64
|
-
|
65
|
-
# If the progress has been read, parse the summary
|
66
|
-
if @state == OutputState::SUMMARY
|
67
|
-
parse_summary
|
68
|
-
return nil
|
69
|
-
end
|
70
|
-
|
71
|
-
# Read the progress output up to 128 bytes at a time
|
72
|
-
# 128 is a small enough number to show some progress, but not too small that
|
73
|
-
# we're constantly writing synchronized output
|
74
|
-
data = @io.read(128)
|
75
|
-
return nil unless data
|
76
|
-
|
77
|
-
data = @remainder + data if @remainder
|
78
|
-
|
79
|
-
# Check for the end of the progress line
|
80
|
-
if (index = data.index "\n")
|
81
|
-
@state = OutputState::SUMMARY
|
82
|
-
@remainder = data[(index+1)..-1]
|
83
|
-
data = data[0...index]
|
84
|
-
# Check for partial ANSI escape codes in colorized output
|
85
|
-
elsif @color && !data.end_with?("\e[0m") && (index = data.rindex("\e[", -6))
|
86
|
-
@remainder = data[index..-1]
|
87
|
-
data = data[0...index]
|
88
|
-
else
|
89
|
-
@remainder = nil
|
90
|
-
end
|
91
|
-
|
92
|
-
data
|
93
|
-
end
|
94
|
-
|
95
|
-
private
|
96
|
-
|
97
|
-
def parse_summary
|
98
|
-
# If there is a remainder, concat it with the next line and handle each line
|
99
|
-
unless @remainder.empty?
|
100
|
-
lines = @remainder
|
101
|
-
eof = false
|
102
|
-
begin
|
103
|
-
lines += @io.readline
|
104
|
-
rescue EOFError
|
105
|
-
eof = true
|
106
|
-
end
|
107
|
-
lines.each_line do |line|
|
108
|
-
parse_summary_line line
|
109
|
-
end
|
110
|
-
return if eof
|
111
|
-
end
|
112
|
-
|
113
|
-
# Process the rest of the lines
|
114
|
-
begin
|
115
|
-
@io.each_line do |line|
|
116
|
-
parse_summary_line line
|
117
|
-
end
|
118
|
-
rescue EOFError
|
119
|
-
end
|
120
|
-
end
|
121
|
-
|
122
|
-
def parse_summary_line(line)
|
123
|
-
line.chomp!
|
124
|
-
return if line.empty?
|
125
|
-
|
126
|
-
if line == 'Pending:'
|
127
|
-
@status = OutputState::PENDING
|
128
|
-
return
|
129
|
-
elsif line == 'Failures:'
|
130
|
-
@status = OutputState::FAILURES
|
131
|
-
return
|
132
|
-
elsif line == 'Failed examples:'
|
133
|
-
@status = OutputState::FAILED_EXAMPLES
|
134
|
-
return
|
135
|
-
elsif (line.match /^Finished in ((\d+\.?\d*) minutes?)? ?(\d+\.?\d*) seconds?$/)
|
136
|
-
@status = OutputState::DURATION
|
137
|
-
return
|
138
|
-
elsif (match = line.gsub(/\e\[\d+m/, '').match /^(\d+) examples?, (\d+) failures?(, (\d+) pending)?$/)
|
139
|
-
@status = OutputState::COUNTS
|
140
|
-
@examples = match[1].to_i
|
141
|
-
@failures = match[2].to_i
|
142
|
-
@pending = (match[4] || 0).to_i
|
143
|
-
return
|
144
|
-
end
|
145
|
-
|
146
|
-
case @status
|
147
|
-
when OutputState::PENDING
|
148
|
-
@pending_lines << line
|
149
|
-
when OutputState::FAILURES
|
150
|
-
@failure_lines << line
|
151
|
-
when OutputState::FAILED_EXAMPLES
|
152
|
-
@failed_example_lines << line
|
153
|
-
end
|
154
|
-
end
|
155
|
-
end
|
156
|
-
|
157
|
-
#
|
158
|
-
# Responsible for parallelizing spec testing.
|
159
|
-
# Optional options list will be passed to rspec.
|
160
|
-
#
|
161
|
-
class Parallelizer
|
162
|
-
# Number of processes to use
|
163
|
-
attr_reader :process_count
|
164
|
-
# Approximate size of each group of tests
|
165
|
-
attr_reader :group_size
|
166
|
-
# Options list for rspec
|
167
|
-
attr_reader :options
|
168
|
-
|
169
|
-
def initialize(process_count, group_size, color, options = [])
|
170
|
-
@process_count = process_count
|
171
|
-
@group_size = group_size
|
172
|
-
@color = color
|
173
|
-
@options = options
|
174
|
-
end
|
175
|
-
|
176
|
-
def color?
|
177
|
-
@color
|
178
|
-
end
|
179
|
-
|
180
|
-
def run
|
181
|
-
@start_time = Time.now
|
182
|
-
|
183
|
-
groups = group_specs
|
184
|
-
fail red('error: no specs were found') if groups.length == 0
|
185
|
-
|
186
|
-
begin
|
187
|
-
run_specs(groups, options)
|
188
|
-
ensure
|
189
|
-
groups.each do |file|
|
190
|
-
File.unlink(file)
|
191
|
-
end
|
192
|
-
end
|
193
|
-
end
|
194
|
-
|
195
|
-
private
|
196
|
-
|
197
|
-
def group_specs
|
198
|
-
# Spawn the rspec_grouper utility to perform the test grouping
|
199
|
-
# We do this in a separate process to limit this processes' long-running footprint
|
200
|
-
io = IO.popen("ruby util/rspec_grouper #{@group_size}")
|
201
|
-
|
202
|
-
header = true
|
203
|
-
spec_group_files = []
|
204
|
-
io.each_line do |line|
|
205
|
-
line.chomp!
|
206
|
-
header = false if line.empty?
|
207
|
-
next if header || line.empty?
|
208
|
-
spec_group_files << line
|
209
|
-
end
|
210
|
-
|
211
|
-
_, status = Process.waitpid2(io.pid)
|
212
|
-
io.close
|
213
|
-
|
214
|
-
fail red('error: no specs were found.') unless status.success?
|
215
|
-
spec_group_files
|
216
|
-
end
|
217
|
-
|
218
|
-
def run_specs(groups, options)
|
219
|
-
puts "Processing #{groups.length} spec group(s) with #{@process_count} worker(s)"
|
220
|
-
|
221
|
-
interrupted = false
|
222
|
-
success = true
|
223
|
-
worker_threads = []
|
224
|
-
group_index = -1
|
225
|
-
pids = Array.new(@process_count)
|
226
|
-
mutex = Mutex.new
|
227
|
-
|
228
|
-
# Handle SIGINT by killing child processes
|
229
|
-
original_handler = Signal.trap :SIGINT do
|
230
|
-
break if interrupted
|
231
|
-
interrupted = true
|
232
|
-
|
233
|
-
# Can't synchronize in a trap context, so read dirty
|
234
|
-
pids.each do |pid|
|
235
|
-
begin
|
236
|
-
Process.kill(:SIGKILL, pid) if pid
|
237
|
-
rescue Errno::ESRCH
|
238
|
-
end
|
239
|
-
end
|
240
|
-
puts yellow("\nshutting down...")
|
241
|
-
end
|
242
|
-
|
243
|
-
buffers = []
|
244
|
-
|
245
|
-
process_count.times do |thread_id|
|
246
|
-
worker_threads << Thread.new do
|
247
|
-
while !interrupted do
|
248
|
-
# Get the spec file for this rspec run
|
249
|
-
group = mutex.synchronize { if group_index < groups.length then groups[group_index += 1] else nil end }
|
250
|
-
break unless group && !interrupted
|
251
|
-
|
252
|
-
# Spawn the worker process with redirected output
|
253
|
-
options_string = options ? options.join(' ') : ''
|
254
|
-
io = IO.popen("ruby util/rspec_runner #{group} #{options_string}")
|
255
|
-
pids[thread_id] = io.pid
|
256
|
-
|
257
|
-
# TODO: make the buffer pluggable to handle other output formats like documentation
|
258
|
-
buffer = ProgressFormatBuffer.new(io, @color)
|
259
|
-
|
260
|
-
# Process the output
|
261
|
-
while !interrupted
|
262
|
-
output = buffer.read
|
263
|
-
break unless output && !interrupted
|
264
|
-
next if output.empty?
|
265
|
-
mutex.synchronize { print output }
|
266
|
-
end
|
267
|
-
|
268
|
-
# Kill the process if we were interrupted, just to be sure
|
269
|
-
if interrupted
|
270
|
-
begin
|
271
|
-
Process.kill(:SIGKILL, pids[thread_id])
|
272
|
-
rescue Errno::ESRCH
|
273
|
-
end
|
274
|
-
end
|
275
|
-
|
276
|
-
# Reap the process
|
277
|
-
result = Process.waitpid2(pids[thread_id])[1].success?
|
278
|
-
io.close
|
279
|
-
pids[thread_id] = nil
|
280
|
-
mutex.synchronize do
|
281
|
-
buffers << buffer
|
282
|
-
success &= result
|
283
|
-
end
|
284
|
-
end
|
285
|
-
end
|
286
|
-
end
|
287
|
-
|
288
|
-
# Join all worker threads
|
289
|
-
worker_threads.each do |thread|
|
290
|
-
thread.join
|
291
|
-
end
|
292
|
-
|
293
|
-
Signal.trap :SIGINT, original_handler
|
294
|
-
fail yellow('execution was interrupted') if interrupted
|
295
|
-
|
296
|
-
dump_summary buffers
|
297
|
-
success
|
298
|
-
end
|
299
|
-
|
300
|
-
def colorize(text, color_code)
|
301
|
-
if @color
|
302
|
-
"#{color_code}#{text}\e[0m"
|
303
|
-
else
|
304
|
-
text
|
305
|
-
end
|
306
|
-
end
|
307
|
-
|
308
|
-
def red(text)
|
309
|
-
colorize(text, "\e[31m")
|
310
|
-
end
|
311
|
-
|
312
|
-
def green(text)
|
313
|
-
colorize(text, "\e[32m")
|
314
|
-
end
|
315
|
-
|
316
|
-
def yellow(text)
|
317
|
-
colorize(text, "\e[33m")
|
318
|
-
end
|
319
|
-
|
320
|
-
def dump_summary(buffers)
|
321
|
-
puts
|
322
|
-
|
323
|
-
# Print out the pending tests
|
324
|
-
print_header = true
|
325
|
-
buffers.each do |buffer|
|
326
|
-
next if buffer.pending_lines.empty?
|
327
|
-
if print_header
|
328
|
-
puts "\nPending:"
|
329
|
-
print_header = false
|
330
|
-
end
|
331
|
-
puts buffer.pending_lines
|
332
|
-
end
|
333
|
-
|
334
|
-
# Print out the failures
|
335
|
-
print_header = true
|
336
|
-
buffers.each do |buffer|
|
337
|
-
next if buffer.failure_lines.empty?
|
338
|
-
if print_header
|
339
|
-
puts "\nFailures:"
|
340
|
-
print_header = false
|
341
|
-
end
|
342
|
-
puts
|
343
|
-
puts buffer.failure_lines
|
344
|
-
end
|
345
|
-
|
346
|
-
# Print out the run time
|
347
|
-
puts "\nFinished in #{::RSpec::Core::Formatters::Helpers.format_duration(Time.now - @start_time)}"
|
348
|
-
|
349
|
-
# Count all of the examples
|
350
|
-
examples = 0
|
351
|
-
failures = 0
|
352
|
-
pending = 0
|
353
|
-
buffers.each do |buffer|
|
354
|
-
examples += buffer.examples
|
355
|
-
failures += buffer.failures
|
356
|
-
pending += buffer.pending
|
357
|
-
end
|
358
|
-
if failures > 0
|
359
|
-
puts red(summary_count_line(examples, failures, pending))
|
360
|
-
elsif pending > 0
|
361
|
-
puts yellow(summary_count_line(examples, failures, pending))
|
362
|
-
else
|
363
|
-
puts green(summary_count_line(examples, failures, pending))
|
364
|
-
end
|
365
|
-
|
366
|
-
# Print out the failed examples
|
367
|
-
print_header = true
|
368
|
-
buffers.each do |buffer|
|
369
|
-
next if buffer.failed_example_lines.empty?
|
370
|
-
if print_header
|
371
|
-
puts "\nFailed examples:"
|
372
|
-
print_header = false
|
373
|
-
end
|
374
|
-
puts buffer.failed_example_lines
|
375
|
-
end
|
376
|
-
end
|
377
|
-
|
378
|
-
def summary_count_line(examples, failures, pending)
|
379
|
-
summary = ::RSpec::Core::Formatters::Helpers.pluralize(examples, "example")
|
380
|
-
summary << ", " << ::RSpec::Core::Formatters::Helpers.pluralize(failures, "failure")
|
381
|
-
summary << ", #{pending} pending" if pending > 0
|
382
|
-
summary
|
383
|
-
end
|
384
|
-
end
|
385
|
-
end
|
386
|
-
end
|
387
|
-
|
388
|
-
namespace 'parallel' do
|
389
|
-
def color_output?
|
390
|
-
# Check with RSpec to see if color is enabled
|
391
|
-
config = ::RSpec::Core::Configuration.new
|
392
|
-
config.error_stream = $stderr
|
393
|
-
config.output_stream = $stdout
|
394
|
-
options = ::RSpec::Core::ConfigurationOptions.new []
|
395
|
-
options.configure config
|
396
|
-
config.color
|
397
|
-
end
|
398
|
-
|
399
|
-
desc 'Runs specs in parallel. Extra args are passed to rspec.'
|
400
|
-
task 'spec', [:process_count, :group_size] do |_, args|
|
401
|
-
# Default group size in rspec examples
|
402
|
-
DEFAULT_GROUP_SIZE = 1000
|
403
|
-
|
404
|
-
process_count = [(args[:process_count] || Etc.nprocessors).to_i, 1].max
|
405
|
-
group_size = [(args[:group_size] || DEFAULT_GROUP_SIZE).to_i, 1].max
|
406
|
-
|
407
|
-
abort unless Parallel::RSpec::Parallelizer.new(process_count, group_size, color_output?, args.extras).run
|
408
|
-
end
|
409
|
-
end
|
410
|
-
end
|
data/tasks/parser.rake
DELETED
@@ -1,22 +0,0 @@
|
|
1
|
-
desc "Generate the 4.x 'future' parser"
|
2
|
-
task :gen_eparser => :require_racc do
|
3
|
-
%x{racc -olib/puppet/pops/parser/eparser.rb lib/puppet/pops/parser/egrammar.ra}
|
4
|
-
end
|
5
|
-
|
6
|
-
desc "Generate the 4.x 'future' parser with egrammar.output"
|
7
|
-
task :gen_eparser_output => :require_racc do
|
8
|
-
%x{racc -v -olib/puppet/pops/parser/eparser.rb lib/puppet/pops/parser/egrammar.ra}
|
9
|
-
end
|
10
|
-
|
11
|
-
desc "Generate the 4.x 'future' parser with debugging output"
|
12
|
-
task :gen_eparser_debug => :require_racc do
|
13
|
-
%x{racc -t -olib/puppet/pops/parser/eparser.rb lib/puppet/pops/parser/egrammar.ra}
|
14
|
-
end
|
15
|
-
|
16
|
-
task :require_racc do
|
17
|
-
begin
|
18
|
-
require 'racc'
|
19
|
-
rescue LoadError
|
20
|
-
abort("Run `bundle install --with development` to install the `racc` gem.")
|
21
|
-
end
|
22
|
-
end
|
data/tasks/yard.rake
DELETED
@@ -1,59 +0,0 @@
|
|
1
|
-
begin
|
2
|
-
require 'yard'
|
3
|
-
|
4
|
-
namespace :doc do
|
5
|
-
desc "Clean up generated documentation"
|
6
|
-
task :clean do
|
7
|
-
rm_rf "doc"
|
8
|
-
end
|
9
|
-
|
10
|
-
desc "Generate public documentation pages for the API"
|
11
|
-
YARD::Rake::YardocTask.new(:api) do |t|
|
12
|
-
t.files = ['lib/**/*.rb']
|
13
|
-
t.options = %w{
|
14
|
-
--protected
|
15
|
-
--private
|
16
|
-
--verbose
|
17
|
-
--markup markdown
|
18
|
-
--readme README.md
|
19
|
-
--tag status
|
20
|
-
--transitive-tag status
|
21
|
-
--tag comment
|
22
|
-
--hide-tag comment
|
23
|
-
--tag dsl:"DSL"
|
24
|
-
--no-transitive-tag api
|
25
|
-
--template-path yardoc/templates
|
26
|
-
--files README_DEVELOPER.md,CO*.md,api/**/*.md
|
27
|
-
--api public
|
28
|
-
--api private
|
29
|
-
--hide-void-return
|
30
|
-
}
|
31
|
-
end
|
32
|
-
|
33
|
-
desc "Generate documentation pages for all of the code"
|
34
|
-
YARD::Rake::YardocTask.new(:all) do |t|
|
35
|
-
t.files = ['lib/**/*.rb']
|
36
|
-
t.options = %w{
|
37
|
-
--verbose
|
38
|
-
--markup markdown
|
39
|
-
--readme README.md
|
40
|
-
--tag status
|
41
|
-
--transitive-tag status
|
42
|
-
--tag comment
|
43
|
-
--hide-tag comment
|
44
|
-
--tag dsl:"DSL"
|
45
|
-
--no-transitive-tag api
|
46
|
-
--template-path yardoc/templates
|
47
|
-
--files README_DEVELOPER.md,CO*.md,api/**/*.md
|
48
|
-
--api public
|
49
|
-
--api private
|
50
|
-
--no-api
|
51
|
-
--hide-void-return
|
52
|
-
}
|
53
|
-
end
|
54
|
-
end
|
55
|
-
rescue LoadError => e
|
56
|
-
if verbose
|
57
|
-
STDERR.puts "Document generation not available without yard. #{e.message}"
|
58
|
-
end
|
59
|
-
end
|