chef 12.9.41-universal-mingw32 → 12.10.24-universal-mingw32
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 +52 -13
- data/README.md +145 -0
- data/Rakefile +4 -14
- data/VERSION +1 -1
- data/acceptance/.gitignore +0 -1
- data/acceptance/Gemfile +2 -2
- data/acceptance/Gemfile.lock +235 -0
- data/acceptance/fips/.kitchen.yml +5 -1
- data/acceptance/fips/test/integration/{fips → fips-integration}/serverspec/Gemfile +0 -0
- data/acceptance/fips/test/integration/fips-integration/serverspec/fips-integration_spec.rb +51 -0
- data/acceptance/fips/test/integration/fips-unit-functional/serverspec/Gemfile +3 -0
- data/acceptance/fips/test/integration/fips-unit-functional/serverspec/fips-unit-functional_spec.rb +56 -0
- data/{chef-windows.gemspec → chef-universal-mingw32.gemspec} +0 -0
- data/chef.gemspec +0 -6
- data/{lib → lib-backcompat}/chef/chef_fs/file_system/already_exists_error.rb +0 -0
- data/{lib → lib-backcompat}/chef/chef_fs/file_system/cookbook_frozen_error.rb +0 -0
- data/{lib → lib-backcompat}/chef/chef_fs/file_system/default_environment_cannot_be_modified_error.rb +0 -0
- data/{lib → lib-backcompat}/chef/chef_fs/file_system/file_system_error.rb +0 -0
- data/{lib → lib-backcompat}/chef/chef_fs/file_system/must_delete_recursively_error.rb +0 -0
- data/{lib → lib-backcompat}/chef/chef_fs/file_system/not_found_error.rb +0 -0
- data/{lib → lib-backcompat}/chef/chef_fs/file_system/operation_failed_error.rb +0 -0
- data/{lib → lib-backcompat}/chef/chef_fs/file_system/operation_not_allowed_error.rb +0 -0
- data/lib-backcompat/chef/chef_fs/file_system/repository/chef_repository_file_system_acls_dir.rb +5 -0
- data/lib-backcompat/chef/chef_fs/file_system/repository/chef_repository_file_system_client_keys_dir.rb +5 -0
- data/lib-backcompat/chef/chef_fs/file_system/repository/chef_repository_file_system_entry.rb +6 -0
- data/lib-backcompat/chef/chef_fs/file_system/repository/chef_repository_file_system_policies_dir.rb +5 -0
- data/{lib → lib-backcompat}/chef/chef_fs/file_system/repository/file_system_root_dir.rb +1 -0
- data/lib/chef/chef_fs/file_system/repository/acl.rb +38 -0
- data/lib/chef/chef_fs/file_system/repository/{chef_repository_file_system_acls_dir.rb → acls_dir.rb} +14 -5
- data/lib/chef/chef_fs/file_system/repository/acls_sub_dir.rb +42 -0
- data/lib/chef/chef_fs/file_system/repository/base_file.rb +120 -0
- data/lib/chef/chef_fs/file_system/repository/chef_repository_file_system_cookbook_entry.rb +1 -1
- data/lib/chef/chef_fs/file_system/repository/chef_repository_file_system_root_dir.rb +36 -32
- data/lib/chef/chef_fs/file_system/repository/client.rb +38 -0
- data/lib/chef/chef_fs/file_system/repository/client_key.rb +38 -0
- data/lib/chef/chef_fs/file_system/repository/{chef_repository_file_system_client_keys_dir.rb → client_keys_dir.rb} +9 -5
- data/lib/chef/chef_fs/file_system/repository/client_keys_sub_dir.rb +42 -0
- data/lib/chef/chef_fs/file_system/repository/clients_dir.rb +40 -0
- data/lib/chef/chef_fs/file_system/repository/container.rb +38 -0
- data/lib/chef/chef_fs/file_system/repository/containers_dir.rb +41 -0
- data/lib/chef/chef_fs/file_system/repository/cookbooks_dir.rb +0 -1
- data/lib/chef/chef_fs/file_system/repository/data_bag_item.rb +3 -79
- data/lib/chef/chef_fs/file_system/repository/directory.rb +15 -2
- data/lib/chef/chef_fs/file_system/repository/environment.rb +38 -0
- data/lib/chef/chef_fs/file_system/repository/environments_dir.rb +41 -0
- data/lib/chef/chef_fs/file_system/repository/file_system_entry.rb +66 -30
- data/lib/chef/chef_fs/file_system/repository/group.rb +38 -0
- data/lib/chef/chef_fs/file_system/repository/groups_dir.rb +41 -0
- data/lib/chef/chef_fs/file_system/repository/node.rb +38 -0
- data/lib/chef/chef_fs/file_system/repository/nodes_dir.rb +41 -0
- data/lib/chef/chef_fs/file_system/repository/{chef_repository_file_system_policies_dir.rb → policies_dir.rb} +9 -5
- data/lib/chef/chef_fs/file_system/repository/policy.rb +38 -0
- data/lib/chef/chef_fs/file_system/repository/policy_group.rb +38 -0
- data/lib/chef/chef_fs/file_system/repository/policy_groups_dir.rb +41 -0
- data/lib/chef/chef_fs/file_system/repository/role.rb +38 -0
- data/lib/chef/chef_fs/file_system/repository/roles_dir.rb +41 -0
- data/lib/chef/chef_fs/file_system/repository/user.rb +38 -0
- data/lib/chef/chef_fs/file_system/repository/users_dir.rb +41 -0
- data/lib/chef/dsl/declare_resource.rb +182 -7
- data/lib/chef/http/json_input.rb +2 -2
- data/lib/chef/knife.rb +1 -1
- data/lib/chef/mixin/shell_out.rb +10 -21
- data/lib/chef/property.rb +9 -2
- data/lib/chef/provider.rb +8 -7
- data/lib/chef/provider/apt_repository.rb +8 -6
- data/lib/chef/provider/directory.rb +15 -1
- data/lib/chef/provider/env/windows.rb +1 -1
- data/lib/chef/provider/mdadm.rb +1 -0
- data/lib/chef/provider/package/easy_install.rb +2 -0
- data/lib/chef/provider/package/rubygems.rb +4 -1
- data/lib/chef/provider/package/windows.rb +1 -1
- data/lib/chef/recipe.rb +1 -2
- data/lib/chef/resource/apt_repository.rb +6 -6
- data/lib/chef/resource/mdadm.rb +9 -0
- data/lib/chef/resource_collection.rb +5 -0
- data/lib/chef/resource_collection/resource_list.rb +10 -0
- data/lib/chef/resource_collection/resource_set.rb +14 -11
- data/lib/chef/version.rb +1 -1
- data/spec/functional/resource/git_spec.rb +1 -3
- data/spec/functional/resource/group_spec.rb +5 -5
- data/spec/functional/tiny_server_spec.rb +1 -1
- data/spec/functional/util/powershell/cmdlet_spec.rb +1 -1
- data/spec/functional/win32/registry_spec.rb +3 -3
- data/spec/integration/solo/solo_spec.rb +2 -2
- data/spec/support/shared/functional/securable_resource.rb +1 -1
- data/spec/support/shared/unit/provider/file.rb +3 -3
- data/spec/support/shared/unit/windows_script_resource.rb +1 -1
- data/spec/unit/application/apply_spec.rb +1 -0
- data/spec/unit/chef_fs/file_system/repository/base_file_spec.rb +128 -0
- data/spec/unit/chef_fs/file_system/repository/directory_spec.rb +174 -0
- data/spec/unit/cookbook/metadata_spec.rb +1 -1
- data/spec/unit/dsl/declare_resource_spec.rb +335 -0
- data/spec/unit/knife/bootstrap_spec.rb +2 -2
- data/spec/unit/mixin/shell_out_spec.rb +4 -0
- data/spec/unit/node/attribute_spec.rb +1 -1
- data/spec/unit/node/immutable_collections_spec.rb +2 -2
- data/spec/unit/node_map_spec.rb +1 -1
- data/spec/unit/property/validation_spec.rb +23 -7
- data/spec/unit/provider/apt_repository_spec.rb +5 -0
- data/spec/unit/provider/apt_update_spec.rb +1 -0
- data/spec/unit/provider/directory_spec.rb +0 -7
- data/spec/unit/provider/file/content_spec.rb +1 -1
- data/spec/unit/provider/mdadm_spec.rb +9 -0
- data/spec/unit/provider/package/easy_install_spec.rb +6 -0
- data/spec/unit/provider/package/rubygems_spec.rb +8 -4
- data/spec/unit/provider/package/yum_spec.rb +1 -1
- data/spec/unit/provider/powershell_script_spec.rb +1 -1
- data/spec/unit/provider/user/dscl_spec.rb +6 -6
- data/spec/unit/recipe_spec.rb +1 -0
- data/spec/unit/resource/apt_repository_spec.rb +4 -0
- data/spec/unit/resource/file/verification_spec.rb +1 -1
- data/spec/unit/resource/file_spec.rb +2 -2
- data/spec/unit/resource/mdadm_spec.rb +7 -2
- data/spec/unit/resource_collection_spec.rb +30 -0
- data/spec/unit/resource_spec.rb +1 -1
- data/tasks/bin/bundle-platform +15 -0
- data/tasks/bin/bundle-platform.bat +2 -0
- data/tasks/bin/create-override-gemfile +110 -0
- data/tasks/bin/run_chef_tests +17 -0
- data/tasks/bin/run_external_test +47 -0
- data/tasks/bundle.rb +97 -0
- data/tasks/bundle_util.rb +94 -0
- data/tasks/changelog.rb +12 -0
- data/tasks/dependencies.rb +147 -0
- data/tasks/gemfile_util.rb +390 -0
- data/tasks/maintainers.rb +2 -1
- data/tasks/rspec.rb +2 -1
- metadata +61 -83
- data/acceptance/fips/test/integration/fips/serverspec/fips_spec.rb +0 -39
- data/lib/chef/chef_fs/file_system/repository/chef_repository_file_system_entry.rb +0 -83
- data/tasks/external_tests.rb +0 -64
@@ -0,0 +1,15 @@
|
|
1
|
+
#!/usr/bin/env ruby
|
2
|
+
|
3
|
+
platforms = ARGV.shift
|
4
|
+
old_platforms = Gem.platforms
|
5
|
+
Gem.platforms = platforms.split(" ").map { |p| Gem::Platform.new(p) }
|
6
|
+
puts "bundle-platform set Gem.platforms to #{Gem.platforms.map { |p| p.to_s }} (was #{old_platforms.map { |p| p.to_s } })"
|
7
|
+
|
8
|
+
# The rest of this is a normal bundler binstub
|
9
|
+
require "pathname"
|
10
|
+
ENV["BUNDLE_GEMFILE"] ||= File.expand_path("../../../Gemfile",
|
11
|
+
Pathname.new(__FILE__).realpath)
|
12
|
+
|
13
|
+
require "rubygems"
|
14
|
+
|
15
|
+
load Gem.bin_path("bundler", "bundle")
|
@@ -0,0 +1,110 @@
|
|
1
|
+
#!/usr/bin/env ruby
|
2
|
+
|
3
|
+
require "rubygems"
|
4
|
+
require "bundler"
|
5
|
+
|
6
|
+
Bundler.with_clean_env do
|
7
|
+
require_relative "../gemfile_util"
|
8
|
+
|
9
|
+
options = {}
|
10
|
+
opts = OptionParser.new do |opts|
|
11
|
+
opts.banner = "Usage: create-override-gemfile [OPTIONS]"
|
12
|
+
|
13
|
+
opts.on("--gemfile GEMFILE", "The Gemfile to read (default: Gemfile).") { |path| options[:gemfile_path] = path }
|
14
|
+
opts.on("--lockfile GEMFILE", "The lockfile to read (default: <gemfile>.lock).") { |path| options[:lockfile_path] = path }
|
15
|
+
|
16
|
+
opts.on("--group GROUP", "Groups to include (whitelist).") do |group|
|
17
|
+
options[:groups] ||= []
|
18
|
+
options[:groups] << group.to_sym
|
19
|
+
end
|
20
|
+
|
21
|
+
opts.on("--without GROUP", "Groups to exclude.") do |group|
|
22
|
+
options[:without_groups] ||= []
|
23
|
+
options[:without_groups] << group.to_sym
|
24
|
+
end
|
25
|
+
|
26
|
+
opts.on("--gem GEM", "Gems to include regardless of groups.") do |name|
|
27
|
+
options[:gems] ||= []
|
28
|
+
options[:gems] << name
|
29
|
+
end
|
30
|
+
|
31
|
+
opts.on("--relative-to PATH", "A path to prepend to any relative paths in the Gemfile.") do |path|
|
32
|
+
unless Pathname.new(path).absolute?
|
33
|
+
puts opts
|
34
|
+
raise "--relative-to #{path} was not an absolute path!"
|
35
|
+
end
|
36
|
+
options[:relative_to] = path
|
37
|
+
end
|
38
|
+
|
39
|
+
opts.on("--[no-]copy-groups", "Whether to copy groups over from the original Gemfile or not (default: false).") { |val| options[:copy_groups] = val }
|
40
|
+
|
41
|
+
opts.on("--[no-]override", "Whether to emit override: true on each gem line (default: false).") { |val| options[:override] = val }
|
42
|
+
|
43
|
+
opts.on("-h", "--help", "Print this message.") do
|
44
|
+
puts opts
|
45
|
+
exit(0)
|
46
|
+
end
|
47
|
+
end
|
48
|
+
|
49
|
+
args = opts.parse(ARGV)
|
50
|
+
|
51
|
+
if args.size > 0
|
52
|
+
puts opts
|
53
|
+
raise "Invalid arguments #{args}"
|
54
|
+
end
|
55
|
+
|
56
|
+
def create_override_gemfile(gemfile_path: "Gemfile", lockfile_path: "#{gemfile_path}.lock", groups: nil, without_groups: nil, gems: [], copy_groups: false, relative_to: ".", override: false)
|
57
|
+
relative_to = Pathname.new(relative_to).realpath
|
58
|
+
# Select the gems we want
|
59
|
+
bundle = GemfileUtil::Bundle.parse(gemfile_path, lockfile_path)
|
60
|
+
gems_to_include = bundle.select_gems(groups: groups, without_groups: without_groups)
|
61
|
+
gems.each do |name|
|
62
|
+
raise "Requested gem #{name} is not in #{gemfile_path}.lock!" if !bundle.gems[name]
|
63
|
+
gems_to_include[name] ||= bundle.gems[name]
|
64
|
+
gems_to_include[name][:dependencies].each do |dep|
|
65
|
+
gems_to_include[name] ||= bundle.gems[dep]
|
66
|
+
end
|
67
|
+
end
|
68
|
+
|
69
|
+
# Add the gems to the Gemfile
|
70
|
+
gem_root = Pathname.new(gemfile_path).dirname.realpath
|
71
|
+
gems_to_include.sort_by { |name, options| options[:declared_groups].empty? ? 1 : 0 }.each do |name, options|
|
72
|
+
comment = nil
|
73
|
+
options = options.dup
|
74
|
+
version = options.delete(:version)
|
75
|
+
if copy_groups
|
76
|
+
# Some dependencies have no groups (are not in the Gemfile--just runtime
|
77
|
+
# dependencies). If we actually record that they have no groups, they
|
78
|
+
# will *always* be installed (or perhaps never). We only want them to
|
79
|
+
# install if their other deps do, so we mark them with the groups of the
|
80
|
+
# things that brought them in (the gems that depended on them). To do
|
81
|
+
# this, we just leave :groups intact.
|
82
|
+
if options[:declared_groups].empty?
|
83
|
+
options.delete(:declared_groups)
|
84
|
+
comment = " # Transitive dependency, not actually in original Gemfile"
|
85
|
+
else
|
86
|
+
# For other things, we want to copy the actual declared_groups--the
|
87
|
+
# ones that were in the Gemfile. We want the same --with and --without
|
88
|
+
# options to include and exclude them as worked with the original
|
89
|
+
# Gemfile.
|
90
|
+
options[:groups] = options.delete(:declared_groups)
|
91
|
+
end
|
92
|
+
else
|
93
|
+
options.delete(:groups)
|
94
|
+
options.delete(:declared_groups)
|
95
|
+
end
|
96
|
+
options.delete(:dependencies)
|
97
|
+
options.delete(:development_dependencies)
|
98
|
+
options[:override] = true if override
|
99
|
+
options[:path] = Pathname.new(options[:path]).expand_path(gem_root).relative_path_from(relative_to).to_s if options[:path]
|
100
|
+
line = "gem #{name.inspect}, #{version.inspect}"
|
101
|
+
options.each do |name, value|
|
102
|
+
line << ", #{name}: #{value.inspect}"
|
103
|
+
end
|
104
|
+
line << comment if comment
|
105
|
+
puts line
|
106
|
+
end
|
107
|
+
end
|
108
|
+
|
109
|
+
create_override_gemfile(options)
|
110
|
+
end
|
@@ -0,0 +1,17 @@
|
|
1
|
+
#!/bin/bash
|
2
|
+
|
3
|
+
# Fail fast (e) and echo commands (vx)
|
4
|
+
set -evx
|
5
|
+
|
6
|
+
echo --color > .rspec
|
7
|
+
echo -fp >> .rspec
|
8
|
+
|
9
|
+
sudo sed -i -e 's/^Defaults\tsecure_path.*$//' /etc/sudoers;
|
10
|
+
# If we have any args, just run the given command
|
11
|
+
if [ -n "$1" ]; then
|
12
|
+
sudo -E $(which bundle) exec $@;
|
13
|
+
else
|
14
|
+
sudo -E $(which bundle) exec rake spec;
|
15
|
+
bundle exec rake style;
|
16
|
+
bundle exec bundle-audit check --update;
|
17
|
+
fi
|
@@ -0,0 +1,47 @@
|
|
1
|
+
#!/bin/bash
|
2
|
+
|
3
|
+
# Fail fast (e) and echo commands (vx)
|
4
|
+
set -evx
|
5
|
+
|
6
|
+
# Arguments
|
7
|
+
TEST_GEM=$1
|
8
|
+
shift
|
9
|
+
|
10
|
+
PROJECT_ROOT=$(pwd)
|
11
|
+
PROJECT_BUNDLE_PATH=${BUNDLE_PATH:-$(grep BUNDLE_PATH: $PROJECT_ROOT/.bundle/config | cut -d' ' -f2-)}
|
12
|
+
if [ -n "$PROJECT_BUNDLE_PATH" ]; then
|
13
|
+
PROJECT_BUNDLE_PATH=$PROJECT_ROOT/$PROJECT_BUNDLE_PATH
|
14
|
+
fi
|
15
|
+
|
16
|
+
TEST_GEM_ROOT=$(bundle show $TEST_GEM)
|
17
|
+
|
18
|
+
# Make a copy of the original Gemfile and stitch in our Gemfile.lock
|
19
|
+
TEST_GEMFILE=$TEST_GEM_ROOT/Gemfile
|
20
|
+
MODIFIED_TEST_GEMFILE=$TEST_GEMFILE.externaltest
|
21
|
+
cat <<EOM > $MODIFIED_TEST_GEMFILE
|
22
|
+
require_relative "$PROJECT_ROOT/tasks/gemfile_util"
|
23
|
+
GemfileUtil.include_locked_gemfile(self, "$PROJECT_ROOT/Gemfile", gems: ["$TEST_GEM"] + "$TEST_WITH_GEMS".split(/\s+/))
|
24
|
+
$TEST_GEM_OVERRIDES
|
25
|
+
EOM
|
26
|
+
cat $TEST_GEMFILE >> $MODIFIED_TEST_GEMFILE
|
27
|
+
if [ -f $TEST_GEMFILE.lock ]; then
|
28
|
+
cp $TEST_GEMFILE.lock $MODIFIED_TEST_GEMFILE.lock
|
29
|
+
elif [ -f $MODIFIED_TEST_GEMFILE.lock ]; then
|
30
|
+
rm -f $MODIFIED_TEST_GEMFILE.lock
|
31
|
+
fi
|
32
|
+
|
33
|
+
# Run the bundle install
|
34
|
+
cd $TEST_GEM_ROOT
|
35
|
+
export BUNDLE_GEMFILE=$MODIFIED_TEST_GEMFILE
|
36
|
+
# Don't read from the project .bundle/config, just our env vars
|
37
|
+
export BUNDLE_IGNORE_CONFIG=true
|
38
|
+
# Use the top level bundle cache so we don't have to reinstall their packages
|
39
|
+
if [ -n "$PROJECT_BUNDLE_PATH" ]; then
|
40
|
+
export BUNDLE_PATH=$PROJECT_BUNDLE_PATH
|
41
|
+
fi
|
42
|
+
export BUNDLE_FROZEN=
|
43
|
+
bundle install
|
44
|
+
export BUNDLE_FROZEN=true
|
45
|
+
|
46
|
+
bundle config
|
47
|
+
bundle exec $@
|
data/tasks/bundle.rb
ADDED
@@ -0,0 +1,97 @@
|
|
1
|
+
#
|
2
|
+
# Copyright:: Copyright (c) 2016 Chef Software Inc.
|
3
|
+
# License:: Apache License, Version 2.0
|
4
|
+
#
|
5
|
+
# Licensed under the Apache License, Version 2.0 (the "License");
|
6
|
+
# you may not use this file except in compliance with the License.
|
7
|
+
# You may obtain a copy of the License at
|
8
|
+
#
|
9
|
+
# http://www.apache.org/licenses/LICENSE-2.0
|
10
|
+
#
|
11
|
+
# Unless required by applicable law or agreed to in writing, software
|
12
|
+
# distributed under the License is distributed on an "AS IS" BASIS,
|
13
|
+
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
14
|
+
# See the License for the specific language governing permissions and
|
15
|
+
# limitations under the License.
|
16
|
+
#
|
17
|
+
|
18
|
+
require_relative "bundle_util"
|
19
|
+
require_relative "../version_policy"
|
20
|
+
require "fileutils"
|
21
|
+
|
22
|
+
desc "Tasks to work with the main Gemfile and Gemfile.<platform>"
|
23
|
+
namespace :bundle do
|
24
|
+
desc "Update Gemfile.lock and all Gemfile.<platform>.locks (or one or more gems via bundle:update gem1 gem2 ...)."
|
25
|
+
task :update, [:args] do |t, rake_args|
|
26
|
+
extend BundleUtil
|
27
|
+
args = rake_args[:args] || ""
|
28
|
+
with_bundle_unfrozen do
|
29
|
+
puts ""
|
30
|
+
puts "-------------------------------------------------------------------"
|
31
|
+
puts "Updating Gemfile.lock ..."
|
32
|
+
puts "-------------------------------------------------------------------"
|
33
|
+
bundle "install #{args}", delete_gemfile_lock: true
|
34
|
+
platforms.each do |platform|
|
35
|
+
bundle "lock", platform: platform
|
36
|
+
end
|
37
|
+
end
|
38
|
+
end
|
39
|
+
|
40
|
+
desc "Conservatively update Gemfile.lock and all Gemfile.<platform>.locks"
|
41
|
+
task :install, [:args] do |t, rake_args|
|
42
|
+
extend BundleUtil
|
43
|
+
args = rake_args[:args] || ""
|
44
|
+
with_bundle_unfrozen do
|
45
|
+
puts ""
|
46
|
+
puts "-------------------------------------------------------------------"
|
47
|
+
puts "Updating Gemfile.lock ..."
|
48
|
+
puts "-------------------------------------------------------------------"
|
49
|
+
bundle "install #{args}"
|
50
|
+
platforms.each do |platform|
|
51
|
+
bundle "lock", platform: platform
|
52
|
+
end
|
53
|
+
end
|
54
|
+
end
|
55
|
+
|
56
|
+
# Find out if we're using the latest gems we can (so we don't regress versions)
|
57
|
+
desc "Check for gems that are not at the latest released version, and report if anything not in ACCEPTABLE_OUTDATED_GEMS (version_policy.rb) is out of date."
|
58
|
+
task :outdated do
|
59
|
+
extend BundleUtil
|
60
|
+
puts ""
|
61
|
+
puts "-------------------------------------------------------------------"
|
62
|
+
puts "Checking for outdated gems ..."
|
63
|
+
puts "-------------------------------------------------------------------"
|
64
|
+
# TODO check for outdated windows gems too
|
65
|
+
with_bundle_unfrozen do
|
66
|
+
bundle_outdated = bundle("outdated", extract_output: true)
|
67
|
+
puts bundle_outdated
|
68
|
+
outdated_gems = parse_bundle_outdated(bundle_outdated).map { |line, gem_name| gem_name }
|
69
|
+
# Weed out the acceptable ones
|
70
|
+
outdated_gems = outdated_gems.reject { |gem_name| ACCEPTABLE_OUTDATED_GEMS.include?(gem_name) }
|
71
|
+
if outdated_gems.empty?
|
72
|
+
puts ""
|
73
|
+
puts "SUCCESS!"
|
74
|
+
else
|
75
|
+
raise "ERROR: outdated gems: #{outdated_gems.join(", ")}. Either fix them or add them to ACCEPTABLE_OUTDATED_GEMS in #{__FILE__}."
|
76
|
+
end
|
77
|
+
end
|
78
|
+
end
|
79
|
+
end
|
80
|
+
|
81
|
+
desc "Run bundle with arbitrary args against the given platform; e.g. rake bundle[show]. No platform to run against the main bundle; bundle[show,windows] to run the windows one; bundle[show,*] to run against all non-default platforms."
|
82
|
+
task :bundle, [:args, :platform] do |t, rake_args|
|
83
|
+
extend BundleUtil
|
84
|
+
args = rake_args[:args] || ""
|
85
|
+
platform = rake_args[:platform]
|
86
|
+
with_bundle_unfrozen do
|
87
|
+
if platform == "*"
|
88
|
+
platforms.each do |platform|
|
89
|
+
bundle args, platform: platform
|
90
|
+
end
|
91
|
+
elsif platform
|
92
|
+
bundle args, platform: platform
|
93
|
+
else
|
94
|
+
bundle args
|
95
|
+
end
|
96
|
+
end
|
97
|
+
end
|
@@ -0,0 +1,94 @@
|
|
1
|
+
require "bundler"
|
2
|
+
require "shellwords"
|
3
|
+
|
4
|
+
module BundleUtil
|
5
|
+
PLATFORMS = { "windows" => %w{ruby x86-mingw32} }
|
6
|
+
|
7
|
+
def project_root
|
8
|
+
File.expand_path("../..", __FILE__)
|
9
|
+
end
|
10
|
+
|
11
|
+
def bundle_platform
|
12
|
+
File.join(project_root, "tasks", "bin", "bundle-platform")
|
13
|
+
end
|
14
|
+
|
15
|
+
# Parse the output of "bundle outdated" and get the list of gems that
|
16
|
+
# were outdated
|
17
|
+
def parse_bundle_outdated(bundle_outdated_output)
|
18
|
+
result = []
|
19
|
+
bundle_outdated_output.each_line do |line|
|
20
|
+
if line =~ /^\s*\* (.+) \(newest ([^,]+), installed ([^,)])*/
|
21
|
+
gem_name, newest_version, installed_version = $1, $2, $3
|
22
|
+
result << [ line, gem_name ]
|
23
|
+
end
|
24
|
+
end
|
25
|
+
result
|
26
|
+
end
|
27
|
+
|
28
|
+
def with_bundle_unfrozen(cwd: nil, leave_frozen: false)
|
29
|
+
bundle "config --delete frozen", cwd: cwd
|
30
|
+
begin
|
31
|
+
yield
|
32
|
+
ensure
|
33
|
+
bundle "config --local frozen 1", cwd: cwd unless leave_frozen
|
34
|
+
end
|
35
|
+
end
|
36
|
+
|
37
|
+
# Run bundle-platform with the given ruby platform(s)
|
38
|
+
def bundle(args, gemfile: nil, platform: nil, cwd: nil, extract_output: false, delete_gemfile_lock: false)
|
39
|
+
args = args.split(/\s+/)
|
40
|
+
if cwd
|
41
|
+
prefix = "[#{cwd}] "
|
42
|
+
end
|
43
|
+
cwd = File.expand_path(cwd || ".", project_root)
|
44
|
+
Bundler.with_clean_env do
|
45
|
+
Dir.chdir(cwd) do
|
46
|
+
gemfile ||= "Gemfile"
|
47
|
+
gemfile = File.expand_path(gemfile, cwd)
|
48
|
+
raise "No platform #{platform} (supported: #{PLATFORMS.keys.join(", ")})" if platform && !PLATFORMS[platform]
|
49
|
+
|
50
|
+
# First delete the gemfile.lock
|
51
|
+
if delete_gemfile_lock
|
52
|
+
if File.exist?("#{gemfile}.lock")
|
53
|
+
puts "Deleting #{gemfile}.lock ..."
|
54
|
+
File.delete("#{gemfile}.lock")
|
55
|
+
end
|
56
|
+
end
|
57
|
+
|
58
|
+
# Run the bundle command
|
59
|
+
ruby_platforms = platform ? PLATFORMS[platform].join(" ") : "ruby"
|
60
|
+
cmd = Shellwords.join([Gem.ruby, "-S", bundle_platform, ruby_platforms, *args])
|
61
|
+
puts "#{prefix}#{Shellwords.join(["bundle", *args])}#{platform ? " for #{platform} platform" : ""}:"
|
62
|
+
with_gemfile(gemfile) do
|
63
|
+
puts "#{prefix}BUNDLE_GEMFILE=#{gemfile}"
|
64
|
+
puts "#{prefix}> #{cmd}"
|
65
|
+
if extract_output
|
66
|
+
`#{cmd}`
|
67
|
+
else
|
68
|
+
unless system(bundle_platform, ruby_platforms, *args)
|
69
|
+
raise "#{bundle_platform} failed: exit code #{$?}"
|
70
|
+
end
|
71
|
+
end
|
72
|
+
end
|
73
|
+
end
|
74
|
+
end
|
75
|
+
end
|
76
|
+
|
77
|
+
def with_gemfile(gemfile)
|
78
|
+
old_gemfile = ENV["BUNDLE_GEMFILE"]
|
79
|
+
ENV["BUNDLE_GEMFILE"] = gemfile
|
80
|
+
begin
|
81
|
+
yield
|
82
|
+
ensure
|
83
|
+
if old_gemfile
|
84
|
+
ENV["BUNDLE_GEMFILE"] = old_gemfile
|
85
|
+
else
|
86
|
+
ENV.delete("BUNDLE_GEMFILE")
|
87
|
+
end
|
88
|
+
end
|
89
|
+
end
|
90
|
+
|
91
|
+
def platforms
|
92
|
+
PLATFORMS.keys
|
93
|
+
end
|
94
|
+
end
|
data/tasks/changelog.rb
ADDED
@@ -0,0 +1,12 @@
|
|
1
|
+
begin
|
2
|
+
require "github_changelog_generator/task"
|
3
|
+
|
4
|
+
GitHubChangelogGenerator::RakeTask.new :changelog do |config|
|
5
|
+
config.future_release = Chef::VERSION
|
6
|
+
config.enhancement_labels = "enhancement,Enhancement,New Feature,Feature".split(",")
|
7
|
+
config.bug_labels = "bug,Bug,Improvement,Upstream Bug".split(",")
|
8
|
+
config.exclude_labels = "duplicate,question,invalid,wontfix,no_changelog,Exclude From Changelog,Question,Discussion".split(",")
|
9
|
+
end
|
10
|
+
rescue LoadError
|
11
|
+
puts "github_changelog_generator is not available. gem install github_changelog_generator to generate changelogs"
|
12
|
+
end
|
@@ -0,0 +1,147 @@
|
|
1
|
+
#
|
2
|
+
# Copyright:: Copyright (c) 2016 Chef Software Inc.
|
3
|
+
# License:: Apache License, Version 2.0
|
4
|
+
#
|
5
|
+
# Licensed under the Apache License, Version 2.0 (the "License");
|
6
|
+
# you may not use this file except in compliance with the License.
|
7
|
+
# You may obtain a copy of the License at
|
8
|
+
#
|
9
|
+
# http://www.apache.org/licenses/LICENSE-2.0
|
10
|
+
#
|
11
|
+
# Unless required by applicable law or agreed to in writing, software
|
12
|
+
# distributed under the License is distributed on an "AS IS" BASIS,
|
13
|
+
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
14
|
+
# See the License for the specific language governing permissions and
|
15
|
+
# limitations under the License.
|
16
|
+
#
|
17
|
+
|
18
|
+
require_relative "bundle_util"
|
19
|
+
require_relative "bundle"
|
20
|
+
require_relative "../version_policy"
|
21
|
+
|
22
|
+
desc "Tasks to update and check dependencies"
|
23
|
+
namespace :dependencies do
|
24
|
+
# Update all dependencies to the latest constraint-matching version
|
25
|
+
desc "Update all dependencies. dependencies:update[conservative] to update as little as possible."
|
26
|
+
task :update, [:conservative] => %w{
|
27
|
+
dependencies:update_gemfile_lock
|
28
|
+
dependencies:update_omnibus_overrides
|
29
|
+
dependencies:update_omnibus_gemfile_lock
|
30
|
+
dependencies:update_acceptance_gemfile_lock
|
31
|
+
dependencies:update_kitchen_tests_gemfile_lock
|
32
|
+
dependencies:update_kitchen_tests_berksfile_lock
|
33
|
+
}
|
34
|
+
|
35
|
+
desc "Update Gemfile.lock and all Gemfile.<platform>.locks. update_gemfile_lock[conservative] to update as little as possible."
|
36
|
+
task :update_gemfile_lock, [:conservative] do |t, rake_args|
|
37
|
+
conservative = rake_args[:conservative]
|
38
|
+
if conservative
|
39
|
+
Rake::Task["bundle:install"].invoke
|
40
|
+
else
|
41
|
+
Rake::Task["bundle:update"].invoke
|
42
|
+
end
|
43
|
+
end
|
44
|
+
|
45
|
+
def gemfile_lock_task(task_name, dirs: [], other_platforms: true, leave_frozen: true)
|
46
|
+
dirs.each do |dir|
|
47
|
+
desc "Update #{dir}/Gemfile.lock. #{task_name}[conservative] to update as little as possible."
|
48
|
+
task task_name, [:conservative] do |t, rake_args|
|
49
|
+
extend BundleUtil
|
50
|
+
conservative = rake_args[:conservative]
|
51
|
+
puts ""
|
52
|
+
puts "-------------------------------------------------------------------"
|
53
|
+
puts "Updating #{dir}/Gemfile.lock#{conservative ? " (conservatively)" : ""} ..."
|
54
|
+
puts "-------------------------------------------------------------------"
|
55
|
+
with_bundle_unfrozen(cwd: dir, leave_frozen: leave_frozen) do
|
56
|
+
bundle "install", cwd: dir, delete_gemfile_lock: !conservative
|
57
|
+
if other_platforms
|
58
|
+
# Include all other supported platforms into the lockfile as well
|
59
|
+
platforms.each do |platform|
|
60
|
+
bundle "lock", cwd: dir, platform: platform
|
61
|
+
end
|
62
|
+
end
|
63
|
+
end
|
64
|
+
end
|
65
|
+
end
|
66
|
+
end
|
67
|
+
|
68
|
+
def berksfile_lock_task(task_name, dirs: [])
|
69
|
+
dirs.each do |dir|
|
70
|
+
desc "Update #{dir}/Berksfile.lock. #{task_name}[conservative] to update as little as possible."
|
71
|
+
task task_name, [:conservative] do |t, rake_args|
|
72
|
+
extend BundleUtil
|
73
|
+
conservative = rake_args[:conservative]
|
74
|
+
puts ""
|
75
|
+
puts "-------------------------------------------------------------------"
|
76
|
+
puts "Updating #{dir}/Berksfile.lock#{conservative ? " (conservatively)" : ""} ..."
|
77
|
+
puts "-------------------------------------------------------------------"
|
78
|
+
if !conservative && File.exist?("#{project_root}/#{dir}/Berksfile.lock")
|
79
|
+
File.delete("#{project_root}/#{dir}/Berksfile.lock")
|
80
|
+
end
|
81
|
+
Dir.chdir("#{project_root}/#{dir}") do
|
82
|
+
Bundler.with_clean_env do
|
83
|
+
sh "bundle exec berks install"
|
84
|
+
end
|
85
|
+
end
|
86
|
+
end
|
87
|
+
end
|
88
|
+
end
|
89
|
+
|
90
|
+
gemfile_lock_task :update_omnibus_gemfile_lock, dirs: %w{omnibus}
|
91
|
+
gemfile_lock_task :update_acceptance_gemfile_lock, dirs: %w{acceptance},
|
92
|
+
other_platforms: false, leave_frozen: false
|
93
|
+
gemfile_lock_task :update_kitchen_tests_gemfile_lock, dirs: %w{
|
94
|
+
kitchen-tests
|
95
|
+
kitchen-tests/test/integration/webapp/serverspec
|
96
|
+
}
|
97
|
+
berksfile_lock_task :update_kitchen_tests_berksfile_lock, dirs: %w{
|
98
|
+
kitchen-tests
|
99
|
+
kitchen-tests/cookbooks/audit_test
|
100
|
+
}
|
101
|
+
# kitchen-tests/cookbooks/webapp isn't solving right now ....
|
102
|
+
|
103
|
+
desc "Update omnibus overrides, including versions in version_policy.rb and latest version of gems: #{OMNIBUS_RUBYGEMS_AT_LATEST_VERSION.keys}. update_omnibus_overrides[conservative] does nothing."
|
104
|
+
task :update_omnibus_overrides, [:conservative] do |t, rake_args|
|
105
|
+
conservative = rake_args[:conservative]
|
106
|
+
unless conservative
|
107
|
+
puts ""
|
108
|
+
puts "-------------------------------------------------------------------"
|
109
|
+
puts "Updating omnibus_overrides.rb ..."
|
110
|
+
puts "-------------------------------------------------------------------"
|
111
|
+
|
112
|
+
# Generate the new overrides file
|
113
|
+
overrides = "# DO NOT EDIT. Generated by \"rake dependencies\". Edit version_policy.rb instead.\n"
|
114
|
+
|
115
|
+
# Replace the bundler and rubygems versions
|
116
|
+
OMNIBUS_RUBYGEMS_AT_LATEST_VERSION.each do |override_name, gem_name|
|
117
|
+
# Get the latest bundler version
|
118
|
+
puts "Running gem list -r #{gem_name} ..."
|
119
|
+
gem_list = `gem list -r #{gem_name}`
|
120
|
+
unless gem_list =~ /^#{gem_name}\s*\(([^)]*)\)$/
|
121
|
+
raise "gem list -r #{gem_name} failed with output:\n#{gem_list}"
|
122
|
+
end
|
123
|
+
|
124
|
+
# Emit it
|
125
|
+
puts "Latest version of #{gem_name} is #{$1}"
|
126
|
+
overrides << "override #{override_name.inspect}, version: #{$1.inspect}\n"
|
127
|
+
end
|
128
|
+
|
129
|
+
# Add explicit overrides
|
130
|
+
OMNIBUS_OVERRIDES.each do |override_name, version|
|
131
|
+
overrides << "override #{override_name.inspect}, version: #{version.inspect}\n"
|
132
|
+
end
|
133
|
+
|
134
|
+
# Write the file out (if changed)
|
135
|
+
overrides_path = File.expand_path("../../omnibus_overrides.rb", __FILE__)
|
136
|
+
if overrides != IO.read(overrides_path)
|
137
|
+
puts "Overrides changed!"
|
138
|
+
puts `git diff #{overrides_path}`
|
139
|
+
puts "Writing modified #{overrides_path} ..."
|
140
|
+
IO.write(overrides_path, overrides)
|
141
|
+
end
|
142
|
+
end
|
143
|
+
end
|
144
|
+
end
|
145
|
+
desc "Update all dependencies and check for outdated gems. Call dependencies[conservative] to update as little as possible."
|
146
|
+
task :dependencies, [:conservative] => [ "dependencies:update", "bundle:outdated" ]
|
147
|
+
task :update, [:conservative] => [ "dependencies:update", "bundle:outdated"]
|