chef 13.1.31-universal-mingw32 → 13.2.20-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.
Files changed (45) hide show
  1. checksums.yaml +4 -4
  2. data/README.md +68 -134
  3. data/Rakefile +1 -0
  4. data/VERSION +1 -1
  5. data/acceptance/.shared/kitchen_acceptance/.kitchen.ec2.yml +1 -0
  6. data/acceptance/top-cookbooks/.kitchen.docker.yml +4 -0
  7. data/lib/chef/application/client.rb +27 -18
  8. data/lib/chef/deprecated.rb +10 -0
  9. data/lib/chef/dsl/declare_resource.rb +9 -1
  10. data/lib/chef/knife.rb +5 -1
  11. data/lib/chef/knife/cookbook_test.rb +1 -1
  12. data/lib/chef/policy_builder/policyfile.rb +27 -1
  13. data/lib/chef/provider.rb +2 -2
  14. data/lib/chef/provider/group/aix.rb +1 -1
  15. data/lib/chef/provider/group/groupadd.rb +1 -1
  16. data/lib/chef/provider/package/chocolatey.rb +1 -1
  17. data/lib/chef/provider/user/pw.rb +1 -1
  18. data/lib/chef/provider/user/windows.rb +1 -1
  19. data/lib/chef/resource/breakpoint.rb +1 -1
  20. data/lib/chef/version.rb +3 -1
  21. data/lib/chef/version_string.rb +143 -0
  22. data/spec/functional/mixin/powershell_out_spec.rb +20 -4
  23. data/spec/functional/resource/group_spec.rb +19 -13
  24. data/spec/functional/resource/windows_task_spec.rb +2 -9
  25. data/spec/integration/knife/common_options_spec.rb +29 -11
  26. data/spec/integration/knife/cookbook_bulk_delete_spec.rb +2 -2
  27. data/spec/integration/knife/cookbook_show_spec.rb +2 -2
  28. data/spec/integration/knife/environment_compare_spec.rb +2 -2
  29. data/spec/integration/knife/environment_show_spec.rb +2 -2
  30. data/spec/integration/knife/role_show_spec.rb +2 -2
  31. data/spec/integration/recipes/accumulator_spec.rb +6 -6
  32. data/spec/integration/recipes/resource_action_spec.rb +18 -7
  33. data/spec/integration/recipes/resource_load_spec.rb +5 -21
  34. data/spec/spec_helper.rb +2 -0
  35. data/spec/support/platform_helpers.rb +5 -0
  36. data/spec/support/shared/unit/provider/useradd_based_user_provider.rb +1 -1
  37. data/spec/unit/application/client_spec.rb +2 -0
  38. data/spec/unit/knife_spec.rb +22 -0
  39. data/spec/unit/policy_builder/policyfile_spec.rb +50 -0
  40. data/spec/unit/provider/group/groupadd_spec.rb +1 -1
  41. data/spec/unit/provider/user/pw_spec.rb +1 -1
  42. data/spec/unit/version_string_spec.rb +79 -0
  43. data/tasks/dependencies.rb +1 -42
  44. metadata +6 -5
  45. data/tasks/bundle.rb +0 -73
@@ -64,7 +64,7 @@ describe Chef::Provider::Group::Groupadd do
64
64
 
65
65
  it "should combine all the possible options" do
66
66
  match_array = []
67
- field_list.sort { |a, b| a[0] <=> b[0] }.each do |attribute, option|
67
+ field_list.sort_by { |a| a[0] }.each do |attribute, option|
68
68
  allow(new_resource).to receive(attribute).and_return("hola")
69
69
  match_array << option
70
70
  match_array << "hola"
@@ -69,7 +69,7 @@ describe Chef::Provider::User::Pw do
69
69
 
70
70
  it "should combine all the possible options" do
71
71
  match_array = [ "adam" ]
72
- field_list.sort { |a, b| a[0] <=> b[0] }.each do |attribute, option|
72
+ field_list.sort_by { |a| a[0] }.each do |attribute, option|
73
73
  allow(@new_resource).to receive(attribute).and_return("hola")
74
74
  match_array << option
75
75
  match_array << "hola"
@@ -0,0 +1,79 @@
1
+ # Copyright:: Copyright 2017, Noah Kantrowitz
2
+ # License:: Apache License, Version 2.0
3
+ #
4
+ # Licensed under the Apache License, Version 2.0 (the "License");
5
+ # you may not use this file except in compliance with the License.
6
+ # You may obtain a copy of the License at
7
+ #
8
+ # http://www.apache.org/licenses/LICENSE-2.0
9
+ #
10
+ # Unless required by applicable law or agreed to in writing, software
11
+ # distributed under the License is distributed on an "AS IS" BASIS,
12
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13
+ # See the License for the specific language governing permissions and
14
+ # limitations under the License.
15
+
16
+ require "spec_helper"
17
+ require "chef/version_string"
18
+
19
+ describe Chef::VersionString do
20
+ let(:input) { "1.2.3" }
21
+ subject(:described_object) { described_class.new(input) }
22
+
23
+ it { is_expected.to eq "1.2.3" }
24
+ it { is_expected.to eql "1.2.3" }
25
+ it { is_expected.to be == "1.2.3" }
26
+ it { is_expected.to be < "abc" }
27
+ it { is_expected.to be > "0" }
28
+ it { is_expected.to eq described_class.new("1.2.3") }
29
+ it { is_expected.to be == described_class.new("1.2.3") }
30
+
31
+ context "with !=" do
32
+ subject { described_object != "1.2.4" }
33
+ it { is_expected.to be true }
34
+ end
35
+
36
+ context "with +" do
37
+ subject { described_object + "asdf" }
38
+ it { is_expected.to eq "1.2.3asdf" }
39
+ end
40
+
41
+ context "with *" do
42
+ subject { described_object * 3 }
43
+ it { is_expected.to eq "1.2.31.2.31.2.3" }
44
+ end
45
+
46
+ context "with version-like comparisons" do
47
+ subject { described_class.new("1.02.3") }
48
+
49
+ it { is_expected.to eq "1.2.3" }
50
+ it { is_expected.to be > "1.2.2" }
51
+ it { is_expected.to be > "1.2.3a" }
52
+ it { is_expected.to be < "1.2.4" }
53
+ end
54
+
55
+ context "with =~ Regexp" do
56
+ subject { described_object =~ /^1/ }
57
+ it { is_expected.to eq 0 }
58
+ end
59
+
60
+ context "with =~ Requirement" do
61
+ subject { described_object =~ Gem::Requirement.create("~> 1.0") }
62
+ it { is_expected.to be true }
63
+ end
64
+
65
+ context "with =~ String" do
66
+ subject { described_object =~ "~> 1.0" }
67
+ it { is_expected.to be true }
68
+ end
69
+
70
+ context "with Regexp =~" do
71
+ subject { /^2/ =~ described_object }
72
+ it { is_expected.to be nil }
73
+ end
74
+
75
+ context "with String =~" do
76
+ subject { "~> 1.0" =~ described_object }
77
+ it { expect { subject }.to raise_error TypeError }
78
+ end
79
+ end
@@ -15,9 +15,6 @@
15
15
  # limitations under the License.
16
16
  #
17
17
 
18
- require_relative "bundle"
19
- require_relative "../version_policy"
20
-
21
18
  desc "Tasks to update and check dependencies"
22
19
  namespace :dependencies do
23
20
 
@@ -93,47 +90,9 @@ namespace :dependencies do
93
90
  berks_update_task :update_kitchen_tests_berksfile_lock, "kitchen-tests"
94
91
  berks_update_task :update_audit_tests_berksfile_lock, "kitchen-tests/cookbooks/audit_test"
95
92
 
96
- desc "Update omnibus overrides, including versions in version_policy.rb and latest version of gems: #{OMNIBUS_RUBYGEMS_AT_LATEST_VERSION.keys}."
97
- task :update_omnibus_overrides do |t, rake_args|
98
- puts ""
99
- puts "-------------------------------------------------------------------"
100
- puts "Updating omnibus_overrides.rb ..."
101
- puts "-------------------------------------------------------------------"
102
-
103
- # Generate the new overrides file
104
- overrides = "# DO NOT EDIT. Generated by \"rake dependencies\". Edit version_policy.rb instead.\n"
105
-
106
- # Replace the bundler and rubygems versions
107
- OMNIBUS_RUBYGEMS_AT_LATEST_VERSION.each do |override_name, gem_name|
108
- # Get the latest bundler version
109
- puts "Running gem list -r #{gem_name} ..."
110
- gem_list = `gem list -r #{gem_name}`
111
- unless gem_list =~ /^#{gem_name}\s*\(([^)]*)\)$/
112
- raise "gem list -r #{gem_name} failed with output:\n#{gem_list}"
113
- end
114
-
115
- # Emit it
116
- puts "Latest version of #{gem_name} is #{$1}"
117
- overrides << "override #{override_name.inspect}, version: #{$1.inspect}\n"
118
- end
119
-
120
- # Add explicit overrides
121
- OMNIBUS_OVERRIDES.each do |override_name, version|
122
- overrides << "override #{override_name.inspect}, version: #{version.inspect}\n"
123
- end
124
-
125
- # Write the file out (if changed)
126
- overrides_path = File.expand_path("../../omnibus_overrides.rb", __FILE__)
127
- if overrides != IO.read(overrides_path)
128
- puts "Overrides changed!"
129
- puts `git diff #{overrides_path}`
130
- puts "Writing modified #{overrides_path} ..."
131
- IO.write(overrides_path, overrides)
132
- end
133
- end
134
93
  end
135
94
 
136
95
  desc "Update all dependencies and check for outdated gems."
137
- task :dependencies_ci => [ "dependencies:update_ci", "bundle:outdated" ]
96
+ task :dependencies_ci => [ "dependencies:update_ci" ]
138
97
  task :dependencies => [ "dependencies:update" ]
139
98
  task :update => [ "dependencies:update" ]
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: chef
3
3
  version: !ruby/object:Gem::Version
4
- version: 13.1.31
4
+ version: 13.2.20
5
5
  platform: universal-mingw32
6
6
  authors:
7
7
  - Adam Jacob
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2017-05-30 00:00:00.000000000 Z
11
+ date: 2017-07-04 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: chef-config
@@ -16,14 +16,14 @@ dependencies:
16
16
  requirements:
17
17
  - - '='
18
18
  - !ruby/object:Gem::Version
19
- version: 13.1.31
19
+ version: 13.2.20
20
20
  type: :runtime
21
21
  prerelease: false
22
22
  version_requirements: !ruby/object:Gem::Requirement
23
23
  requirements:
24
24
  - - '='
25
25
  - !ruby/object:Gem::Version
26
- version: 13.1.31
26
+ version: 13.2.20
27
27
  - !ruby/object:Gem::Dependency
28
28
  name: mixlib-cli
29
29
  requirement: !ruby/object:Gem::Requirement
@@ -1715,6 +1715,7 @@ files:
1715
1715
  - lib/chef/version_class.rb
1716
1716
  - lib/chef/version_constraint.rb
1717
1717
  - lib/chef/version_constraint/platform.rb
1718
+ - lib/chef/version_string.rb
1718
1719
  - lib/chef/whitelist.rb
1719
1720
  - lib/chef/win32/api.rb
1720
1721
  - lib/chef/win32/api/crypto.rb
@@ -2825,13 +2826,13 @@ files:
2825
2826
  - spec/unit/version_class_spec.rb
2826
2827
  - spec/unit/version_constraint/platform_spec.rb
2827
2828
  - spec/unit/version_constraint_spec.rb
2829
+ - spec/unit/version_string_spec.rb
2828
2830
  - spec/unit/win32/error_spec.rb
2829
2831
  - spec/unit/win32/registry_spec.rb
2830
2832
  - spec/unit/win32/security_spec.rb
2831
2833
  - spec/unit/windows_service_spec.rb
2832
2834
  - tasks/announce.rb
2833
2835
  - tasks/bin/run_external_test
2834
- - tasks/bundle.rb
2835
2836
  - tasks/cbgb.rb
2836
2837
  - tasks/changelog.rb
2837
2838
  - tasks/dependencies.rb
data/tasks/bundle.rb DELETED
@@ -1,73 +0,0 @@
1
- #
2
- # Copyright:: Copyright (c) 2016-2017, 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 "../version_policy"
19
- require "fileutils"
20
-
21
- desc "Tasks to work with the main Gemfile and Gemfile.<platform>"
22
- namespace :bundle do
23
- desc "Update Gemfile.lock and all Gemfile.<platform>.locks (or one or more gems via bundle:update gem1 gem2 ...)."
24
- task :update, [:args] do |t, rake_args|
25
- args = rake_args[:args] || ""
26
- Bundler.with_clean_env do
27
- sh "bundle update #{args}"
28
- end
29
- end
30
-
31
- desc "Conservatively update Gemfile.lock and all Gemfile.<platform>.locks"
32
- task :install, [:args] do |t, rake_args|
33
- args = rake_args[:args] || ""
34
- args = rake_args[:args] || ""
35
- Bundler.with_clean_env do
36
- sh "bundle install #{args}"
37
- end
38
- end
39
-
40
- def parse_bundle_outdated(bundle_outdated_output)
41
- result = []
42
- bundle_outdated_output.each_line do |line|
43
- if line =~ /^\s*\* (.+) \(newest ([^,]+), installed ([^,)])*/
44
- gem_name, newest_version, installed_version = $1, $2, $3
45
- result << [ line, gem_name ]
46
- end
47
- end
48
- result
49
- end
50
-
51
- # Find out if we're using the latest gems we can (so we don't regress versions)
52
- 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."
53
- task :outdated do
54
- bundle_outdated = ""
55
- Bundler.with_clean_env do
56
- bundle_outdated = `bundle outdated`
57
- puts bundle_outdated
58
- end
59
- outdated_gems = parse_bundle_outdated(bundle_outdated).map { |line, gem_name| gem_name }
60
- outdated_gems = outdated_gems.reject { |gem_name| ACCEPTABLE_OUTDATED_GEMS.include?(gem_name) }
61
- unless outdated_gems.empty?
62
- raise "ERROR: outdated gems: #{outdated_gems.join(", ")}. Either fix them or add them to ACCEPTABLE_OUTDATED_GEMS in #{__FILE__}."
63
- end
64
- end
65
- end
66
-
67
- desc "Run bundle with arbitrary args"
68
- task :bundle, [:args] do |t, rake_args|
69
- args = rake_args[:args] || ""
70
- Bundler.with_clean_env do
71
- sh "bundle #{args}"
72
- end
73
- end