chef 14.1.12-universal-mingw32 → 14.2.0-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 +1 -6
- data/VERSION +1 -1
- data/chef.gemspec +2 -3
- data/lib/chef/chef_fs/data_handler/data_handler_base.rb +8 -4
- data/lib/chef/cookbook/manifest_v0.rb +2 -2
- data/lib/chef/cookbook_manifest.rb +3 -2
- data/lib/chef/cookbook_version.rb +3 -2
- data/lib/chef/guard_interpreter/default_guard_interpreter.rb +2 -2
- data/lib/chef/http/auth_credentials.rb +5 -3
- data/lib/chef/http/authenticator.rb +6 -3
- data/lib/chef/knife.rb +3 -6
- data/lib/chef/knife/configure.rb +12 -8
- data/lib/chef/knife/raw.rb +6 -1
- data/lib/chef/mixin/shell_out.rb +16 -14
- data/lib/chef/provider/execute.rb +4 -3
- data/lib/chef/provider/git.rb +1 -1
- data/lib/chef/provider/package/dnf.rb +5 -5
- data/lib/chef/provider/package/windows.rb +7 -0
- data/lib/chef/provider/package/yum.rb +7 -7
- data/lib/chef/provider/service/freebsd.rb +3 -3
- data/lib/chef/provider/service/init.rb +5 -5
- data/lib/chef/provider/service/macosx.rb +5 -4
- data/lib/chef/provider/service/simple.rb +4 -4
- data/lib/chef/provider/service/systemd.rb +13 -13
- data/lib/chef/provider/service/upstart.rb +3 -3
- data/lib/chef/provider/service/windows.rb +2 -0
- data/lib/chef/provider/systemd_unit.rb +4 -4
- data/lib/chef/provider/user.rb +18 -1
- data/lib/chef/provider/user/aix.rb +40 -8
- data/lib/chef/provider/user/dscl.rb +7 -14
- data/lib/chef/provider/user/linux.rb +1 -11
- data/lib/chef/provider/user/solaris.rb +57 -26
- data/lib/chef/provider/user/useradd.rb +4 -1
- data/lib/chef/provider/windows_task.rb +1 -0
- data/lib/chef/providers.rb +1 -2
- data/lib/chef/resource/execute.rb +4 -1
- data/lib/chef/resource/gem_package.rb +1 -1
- data/lib/chef/resource/hostname.rb +1 -1
- data/lib/chef/resource/sysctl.rb +3 -1
- data/lib/chef/resource/windows_ad_join.rb +16 -3
- data/lib/chef/resource_inspector.rb +13 -0
- data/lib/chef/run_context/cookbook_compiler.rb +1 -1
- data/lib/chef/server_api.rb +2 -0
- data/lib/chef/version.rb +1 -1
- data/spec/functional/mixin/shell_out_spec.rb +27 -1
- data/spec/functional/resource/execute_spec.rb +2 -2
- data/spec/functional/resource/windows_task_spec.rb +1 -1
- data/spec/support/shared/functional/securable_resource.rb +1 -1
- data/spec/support/shared/unit/execute_resource.rb +1 -1
- data/spec/support/shared/unit/provider/useradd_based_user_provider.rb +3 -3
- data/spec/unit/chef_fs/data_handler/data_handler_base_spec.rb +65 -0
- data/spec/unit/cookbook/manifest_v0_spec.rb +1 -1
- data/spec/unit/cookbook_manifest_spec.rb +2 -0
- data/spec/unit/dsl/recipe_spec.rb +1 -5
- data/spec/unit/http/authenticator_spec.rb +33 -8
- data/spec/unit/mixin/shell_out_spec.rb +61 -1
- data/spec/unit/provider/apt_update_spec.rb +7 -7
- data/spec/unit/provider/execute_spec.rb +16 -15
- data/spec/unit/provider/git_spec.rb +3 -3
- data/spec/unit/provider/package/windows_spec.rb +12 -0
- data/spec/unit/provider/script_spec.rb +2 -2
- data/spec/unit/provider/service/arch_service_spec.rb +9 -9
- data/spec/unit/provider/service/freebsd_service_spec.rb +6 -6
- data/spec/unit/provider/service/init_service_spec.rb +11 -11
- data/spec/unit/provider/service/invokercd_service_spec.rb +9 -9
- data/spec/unit/provider/service/macosx_spec.rb +11 -11
- data/spec/unit/provider/service/openbsd_service_spec.rb +6 -6
- data/spec/unit/provider/service/simple_service_spec.rb +4 -4
- data/spec/unit/provider/service/systemd_service_spec.rb +16 -16
- data/spec/unit/provider/service/upstart_service_spec.rb +12 -12
- data/spec/unit/provider/service/windows_spec.rb +5 -0
- data/spec/unit/provider/systemd_unit_spec.rb +163 -118
- data/spec/unit/provider/user/dscl_spec.rb +2 -9
- data/spec/unit/provider/user/solaris_spec.rb +2 -2
- data/spec/unit/provider/zypper_repository_spec.rb +3 -3
- data/spec/unit/provider_spec.rb +1 -5
- data/spec/unit/resource/apt_package_spec.rb +14 -0
- data/spec/unit/resource/apt_preference_spec.rb +14 -1
- data/spec/unit/resource/apt_repository_spec.rb +12 -3
- data/spec/unit/resource/apt_update_spec.rb +9 -0
- data/spec/unit/resource/bash_spec.rb +8 -0
- data/spec/unit/resource/bff_package_spec.rb +51 -0
- data/spec/unit/resource/breakpoint_spec.rb +4 -4
- data/spec/unit/resource/build_essential_spec.rb +5 -1
- data/spec/unit/resource/cab_package_spec.rb +10 -0
- data/spec/unit/resource/chef_gem_spec.rb +14 -0
- data/spec/unit/resource/chef_handler_spec.rb +9 -4
- data/spec/unit/resource/chocolatey_package_spec.rb +15 -1
- data/spec/unit/resource/conditional_spec.rb +3 -3
- data/spec/unit/resource/cookbook_file_spec.rb +13 -2
- data/spec/unit/resource/cron_spec.rb +2 -7
- data/spec/unit/resource/csh_spec.rb +8 -0
- data/spec/unit/resource/directory_spec.rb +4 -9
- data/spec/unit/resource/dmg_package_spec.rb +8 -4
- data/spec/unit/resource/dnf_package_spec.rb +16 -1
- data/spec/unit/resource/dpkg_package_spec.rb +18 -0
- data/spec/unit/resource/dsc_resource_spec.rb +6 -6
- data/spec/unit/resource/dsc_script_spec.rb +39 -39
- data/spec/unit/resource/execute_spec.rb +20 -12
- data/spec/unit/resource/file_spec.rb +10 -10
- data/spec/unit/resource/freebsd_package_spec.rb +16 -0
- data/spec/unit/resource/gem_package_spec.rb +27 -0
- data/spec/unit/resource/git_spec.rb +17 -2
- data/spec/unit/resource/group_spec.rb +18 -17
- data/spec/unit/resource/homebrew_cask_spec.rb +9 -4
- data/spec/unit/resource/homebrew_package_spec.rb +14 -0
- data/spec/unit/resource/homebrew_tap_spec.rb +8 -3
- data/spec/unit/resource/hostname_spec.rb +10 -6
- data/spec/unit/resource/http_request_spec.rb +14 -0
- data/spec/unit/resource/ips_package_spec.rb +15 -3
- data/spec/unit/resource/ksh_spec.rb +8 -0
- data/spec/unit/resource/launchd_spec.rb +11 -5
- data/spec/unit/resource/link_spec.rb +6 -11
- data/spec/unit/resource/log_spec.rb +8 -8
- data/spec/unit/resource/macos_user_defaults_spec.rb +5 -1
- data/spec/unit/resource/macports_package_spec.rb +19 -0
- data/spec/unit/resource/mdadm_spec.rb +7 -3
- data/spec/unit/resource/mount_spec.rb +15 -18
- data/spec/unit/resource/msu_package_spec.rb +10 -0
- data/spec/unit/resource/ohai_hint_spec.rb +9 -8
- data/spec/unit/resource/ohai_spec.rb +11 -3
- data/spec/unit/resource/openbsd_package_spec.rb +14 -0
- data/spec/unit/resource/openssl_dhparam.rb +10 -5
- data/spec/unit/resource/openssl_rsa_private_key_spec.rb +10 -5
- data/spec/unit/resource/openssl_rsa_public_key_spec.rb +9 -5
- data/spec/unit/resource/osx_profile_spec.rb +7 -4
- data/spec/unit/resource/package_spec.rb +14 -0
- data/spec/unit/resource/pacman_package_spec.rb +17 -3
- data/spec/unit/resource/paludis_package_spec.rb +36 -0
- data/spec/unit/resource/perl_spec.rb +8 -0
- data/spec/unit/resource/portage_package_spec.rb +14 -0
- data/spec/unit/resource/powershell_package_spec.rb +14 -0
- data/spec/unit/resource/python_spec.rb +8 -0
- data/spec/unit/resource/reboot_spec.rb +5 -3
- data/spec/unit/resource/registry_key_spec.rb +12 -1
- data/spec/unit/resource/remote_directory_spec.rb +11 -1
- data/spec/unit/resource/remote_file_spec.rb +19 -0
- data/spec/unit/resource/rhsm_errata_level_spec.rb +7 -3
- data/spec/unit/resource/rhsm_errata_spec.rb +8 -4
- data/spec/unit/resource/rhsm_register_spec.rb +6 -1
- data/spec/unit/resource/rhsm_repo_spec.rb +9 -4
- data/spec/unit/resource/rhsm_subscription_spec.rb +9 -4
- data/spec/unit/resource/route_spec.rb +4 -9
- data/spec/unit/resource/rpm_package_spec.rb +14 -0
- data/spec/unit/resource/ruby_block_spec.rb +12 -8
- data/spec/unit/resource/ruby_spec.rb +8 -0
- data/spec/unit/resource/scm_spec.rb +16 -8
- data/spec/unit/resource/script_spec.rb +8 -0
- data/spec/unit/resource/service_spec.rb +15 -0
- data/spec/unit/resource/smartos_package_spec.rb +18 -4
- data/spec/unit/resource/solaris_package_spec.rb +14 -0
- data/spec/unit/resource/subversion_spec.rb +14 -8
- data/spec/unit/resource/sudo_spec.rb +11 -4
- data/spec/unit/resource/swap_file_spec.rb +4 -5
- data/spec/unit/resource/sysctl_spec.rb +8 -10
- data/spec/unit/resource/systemd_unit_spec.rb +14 -12
- data/spec/unit/resource/template_spec.rb +19 -0
- data/spec/unit/resource/{windows_ad_join.rb → windows_ad_join_spec.rb} +12 -6
- data/spec/unit/resource/windows_auto_run_spec.rb +9 -9
- data/spec/unit/resource/windows_env_spec.rb +8 -16
- data/spec/unit/resource/windows_feature.rb +27 -8
- data/spec/unit/resource/windows_feature_dism.rb +30 -9
- data/spec/unit/resource/windows_feature_powershell.rb +7 -7
- data/spec/unit/resource/windows_font_spec.rb +3 -4
- data/spec/unit/resource/windows_package_spec.rb +12 -2
- data/spec/unit/resource/windows_pagefile_spec.rb +12 -8
- data/spec/unit/resource/windows_path_spec.rb +4 -5
- data/spec/unit/resource/windows_printer_port_spec.rb +20 -3
- data/spec/unit/resource/windows_printer_spec.rb +12 -5
- data/spec/unit/resource/windows_service_spec.rb +24 -1
- data/spec/unit/resource/windows_shortcut_spec.rb +4 -5
- data/spec/unit/resource/yum_repository_spec.rb +48 -2
- data/spec/unit/resource/zypper_package_spec.rb +51 -0
- data/spec/unit/resource/zypper_repository_spec.rb +56 -11
- data/spec/unit/resource_spec.rb +1 -5
- metadata +21 -12
- data/spec/functional/resource/user/useradd_spec.rb +0 -709
@@ -1,7 +1,7 @@
|
|
1
1
|
#
|
2
2
|
# Author:: Adam Jacob (<adam@chef.io>)
|
3
3
|
# Author:: Daniel DeLeo (<dan@chef.io>)
|
4
|
-
# Copyright:: Copyright 2008-
|
4
|
+
# Copyright:: Copyright 2008-2018, Chef Software Inc.
|
5
5
|
#
|
6
6
|
# License:: Apache License, Version 2.0
|
7
7
|
#
|
@@ -385,7 +385,7 @@ shared_examples_for "a useradd-based user provider" do |supported_useradd_option
|
|
385
385
|
expect(Pathname).to receive(:new).with(@new_resource.home).and_return(@new_home_mock)
|
386
386
|
expect(@new_home_mock).to receive(:cleanpath).and_return(home_check["new_resource_home"].last)
|
387
387
|
|
388
|
-
expect(provider.updating_home?).to eq(home_check["expected_result"])
|
388
|
+
expect(provider.send(:updating_home?)).to eq(home_check["expected_result"])
|
389
389
|
end
|
390
390
|
end
|
391
391
|
it "should return true if the current home does not exist but a home is specified by the new resource" do
|
@@ -396,7 +396,7 @@ shared_examples_for "a useradd-based user provider" do |supported_useradd_option
|
|
396
396
|
@current_resource.home nil
|
397
397
|
@new_resource.home "/home/kitten"
|
398
398
|
|
399
|
-
expect(provider.updating_home?).to eq(true)
|
399
|
+
expect(provider.send(:updating_home?)).to eq(true)
|
400
400
|
end
|
401
401
|
end
|
402
402
|
end
|
@@ -0,0 +1,65 @@
|
|
1
|
+
#
|
2
|
+
# Author:: Jeremy Miller (<jm@chef.io>)
|
3
|
+
# Copyright:: Copyright 2014-2018, Chef Software Inc.
|
4
|
+
# License:: Apache License, Version 2.0
|
5
|
+
#
|
6
|
+
# Licensed under the Apache License, Version 2.0 (the "License");
|
7
|
+
# you may not use this file except in compliance with the License.
|
8
|
+
# You may obtain a copy of the License at
|
9
|
+
#
|
10
|
+
# http://www.apache.org/licenses/LICENSE-2.0
|
11
|
+
#
|
12
|
+
# Unless required by applicable law or agreed to in writing, software
|
13
|
+
# distributed under the License is distributed on an "AS IS" BASIS,
|
14
|
+
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
15
|
+
# See the License for the specific language governing permissions and
|
16
|
+
# limitations under the License.
|
17
|
+
#
|
18
|
+
|
19
|
+
require "spec_helper"
|
20
|
+
require "lib/chef/chef_fs/data_handler/data_handler_base"
|
21
|
+
|
22
|
+
describe Chef::ChefFS::DataHandler::DataHandlerBase do
|
23
|
+
describe "#normalize_hash" do
|
24
|
+
let(:some_item) do
|
25
|
+
{ "name" => "grizzly",
|
26
|
+
"gender" => "female",
|
27
|
+
"age" => 3,
|
28
|
+
"food" => "honey"
|
29
|
+
}
|
30
|
+
end
|
31
|
+
|
32
|
+
let(:item_defaults) do
|
33
|
+
{ "family" => "ursidae",
|
34
|
+
"hibernate" => true,
|
35
|
+
"food" => "berries",
|
36
|
+
"avg_lifespan_years" => 22
|
37
|
+
}
|
38
|
+
end
|
39
|
+
|
40
|
+
let(:normalized) do
|
41
|
+
{ "name" => "grizzly",
|
42
|
+
"gender" => "female",
|
43
|
+
"family" => "ursidae",
|
44
|
+
"hibernate" => true,
|
45
|
+
"avg_lifespan_years" => 22,
|
46
|
+
"age" => 3,
|
47
|
+
"food" => "honey"
|
48
|
+
}
|
49
|
+
end
|
50
|
+
|
51
|
+
let(:handler) { described_class.new }
|
52
|
+
|
53
|
+
it "normalizes the Hash, filling in default values" do
|
54
|
+
expect(handler.normalize_hash(some_item, item_defaults)).to eq(normalized)
|
55
|
+
end
|
56
|
+
|
57
|
+
it "prefers already existing values over default values" do
|
58
|
+
expect(handler.normalize_hash(some_item, item_defaults)["food"]).to eq("honey")
|
59
|
+
end
|
60
|
+
|
61
|
+
it "handles being passed a nil value instead of Hash" do
|
62
|
+
expect(handler.normalize_hash(nil, item_defaults)).to eq(item_defaults)
|
63
|
+
end
|
64
|
+
end
|
65
|
+
end
|
@@ -82,7 +82,7 @@ describe Chef::Cookbook::ManifestV0 do
|
|
82
82
|
|
83
83
|
it "creates an all_files key and populates it" do
|
84
84
|
result = described_class.from_hash(source_hash)
|
85
|
-
expect(result[:all_files].map { |f| f["name"] }).to match_array %w{ recipes/default.rb attributes/default.rb README.rdoc }
|
85
|
+
expect(result[:all_files].map { |f| f["name"] }).to match_array %w{ recipes/default.rb attributes/default.rb root_files/README.rdoc }
|
86
86
|
end
|
87
87
|
|
88
88
|
it "deletes unwanted segment types" do
|
@@ -122,6 +122,8 @@ describe Chef::CookbookManifest do
|
|
122
122
|
parts = relative_path.split("/")
|
123
123
|
name = if %w{templates files}.include?(parts[0]) && parts.length == 3
|
124
124
|
File.join(parts[0], parts[2])
|
125
|
+
elsif parts.length == 1
|
126
|
+
"root_files/#{parts[0]}"
|
125
127
|
else
|
126
128
|
relative_path
|
127
129
|
end
|
@@ -1,6 +1,6 @@
|
|
1
1
|
#
|
2
2
|
# Author:: Daniel DeLeo (<dan@chef.io>)
|
3
|
-
# Copyright:: Copyright 2014-
|
3
|
+
# Copyright:: Copyright 2014-2018, Chef Software Inc.
|
4
4
|
# License:: Apache License, Version 2.0
|
5
5
|
#
|
6
6
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
@@ -53,10 +53,6 @@ describe Chef::DSL::Recipe do
|
|
53
53
|
it "responds to shell_out" do
|
54
54
|
expect(recipe.respond_to?(:shell_out!)).to be true
|
55
55
|
end
|
56
|
-
|
57
|
-
it "responds to shell_out" do
|
58
|
-
expect(recipe.respond_to?(:shell_out_with_systems_locale)).to be true
|
59
|
-
end
|
60
56
|
end
|
61
57
|
|
62
58
|
context "when included in a class that defines the required interface directly" do
|
@@ -20,18 +20,18 @@ require "spec_helper"
|
|
20
20
|
require "chef/http/authenticator"
|
21
21
|
|
22
22
|
describe Chef::HTTP::Authenticator do
|
23
|
-
let(:class_instance) { Chef::HTTP::Authenticator.new }
|
24
|
-
let(:method) {
|
25
|
-
let(:url) {
|
23
|
+
let(:class_instance) { Chef::HTTP::Authenticator.new(client_name: "test") }
|
24
|
+
let(:method) { "GET" }
|
25
|
+
let(:url) { URI("https://chef.example.com/organizations/test") }
|
26
26
|
let(:headers) { Hash.new }
|
27
|
-
let(:data) {
|
28
|
-
|
29
|
-
before do
|
30
|
-
allow(class_instance).to receive(:authentication_headers).and_return({})
|
31
|
-
end
|
27
|
+
let(:data) { "" }
|
32
28
|
|
33
29
|
context "when handle_request is called" do
|
34
30
|
shared_examples_for "merging the server API version into the headers" do
|
31
|
+
before do
|
32
|
+
allow(class_instance).to receive(:authentication_headers).and_return({})
|
33
|
+
end
|
34
|
+
|
35
35
|
it "merges the default version of X-Ops-Server-API-Version into the headers" do
|
36
36
|
# headers returned
|
37
37
|
expect(class_instance.handle_request(method, url, headers, data)[2]).
|
@@ -96,5 +96,30 @@ describe Chef::HTTP::Authenticator do
|
|
96
96
|
class_instance.handle_request(method, url, headers, data)
|
97
97
|
end
|
98
98
|
end
|
99
|
+
|
100
|
+
context "when ssh_agent_signing" do
|
101
|
+
let(:public_key) { <<-EOH }
|
102
|
+
-----BEGIN PUBLIC KEY-----
|
103
|
+
MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEA49TA0y81ps0zxkOpmf5V
|
104
|
+
4/c4IeR5yVyQFpX3JpxO4TquwnRh8VSUhrw8kkTLmB3cS39Db+3HadvhoqCEbqPE
|
105
|
+
6915kXSuk/cWIcNozujLK7tkuPEyYVsyTioQAddSdfe+8EhQVf3oHxaKmUd6waXr
|
106
|
+
WqYCnhxgOjxocenREYNhZ/OETIeiPbOku47vB4nJK/0GhKBytL2XnsRgfKgDxf42
|
107
|
+
BqAi1jglIdeq8lAWZNF9TbNBU21AO1iuT7Pm6LyQujhggPznR5FJhXKRUARXBJZa
|
108
|
+
wxpGV4dGtdcahwXNE4601aXPra+xPcRd2puCNoEDBzgVuTSsLYeKBDMSfs173W1Q
|
109
|
+
YwIDAQAB
|
110
|
+
-----END PUBLIC KEY-----
|
111
|
+
EOH
|
112
|
+
|
113
|
+
let(:class_instance) { Chef::HTTP::Authenticator.new(client_name: "test", raw_key: public_key, ssh_agent_signing: true) }
|
114
|
+
|
115
|
+
it "sets use_ssh_agent if needed" do
|
116
|
+
expect(Mixlib::Authentication::SignedHeaderAuth).to receive(:signing_object).and_wrap_original { |m, *args|
|
117
|
+
m.call(*args).tap do |signing_obj|
|
118
|
+
expect(signing_obj).to receive(:sign).with(instance_of(OpenSSL::PKey::RSA), use_ssh_agent: true).and_return({})
|
119
|
+
end
|
120
|
+
}
|
121
|
+
class_instance.handle_request(method, url, headers, data)
|
122
|
+
end
|
123
|
+
end
|
99
124
|
end
|
100
125
|
end
|
@@ -226,11 +226,71 @@ describe Chef::Mixin::ShellOut do
|
|
226
226
|
|
227
227
|
describe "when the last argument is not a Hash" do
|
228
228
|
it "should no longer add environment options and set environment['LC_ALL'] to nil" do
|
229
|
-
expect(shell_out_obj).to receive(:shell_out_command).with(cmd).and_return(true)
|
229
|
+
expect(shell_out_obj).to receive(:shell_out_command).with(cmd, {}).and_return(true)
|
230
230
|
shell_out_obj.shell_out_with_systems_locale(cmd)
|
231
231
|
end
|
232
232
|
end
|
233
233
|
end
|
234
234
|
|
235
|
+
describe "#shell_out default_env: false" do
|
236
|
+
|
237
|
+
describe "when the last argument is a Hash" do
|
238
|
+
describe "and environment is an option" do
|
239
|
+
it "should not change environment['LC_ALL'] when set to nil" do
|
240
|
+
options = { :environment => { "LC_ALL" => nil } }
|
241
|
+
expect(shell_out_obj).to receive(:shell_out_command).with(cmd, options).and_return(true)
|
242
|
+
shell_out_obj.shell_out(cmd, **options, default_env: false)
|
243
|
+
end
|
244
|
+
|
245
|
+
it "should not change environment['LC_ALL'] when set to non-nil" do
|
246
|
+
options = { :environment => { "LC_ALL" => "en_US.UTF-8" } }
|
247
|
+
expect(shell_out_obj).to receive(:shell_out_command).with(cmd, options).and_return(true)
|
248
|
+
shell_out_obj.shell_out(cmd, **options, default_env: false)
|
249
|
+
end
|
250
|
+
|
251
|
+
it "should no longer set environment['LC_ALL'] to nil when 'LC_ALL' not present" do
|
252
|
+
options = { :environment => { "HOME" => "/Users/morty" } }
|
253
|
+
expect(shell_out_obj).to receive(:shell_out_command).with(cmd, options).and_return(true)
|
254
|
+
shell_out_obj.shell_out(cmd, **options, default_env: false)
|
255
|
+
end
|
256
|
+
end
|
257
|
+
|
258
|
+
describe "and env is an option" do
|
259
|
+
it "should not change env when set to nil" do
|
260
|
+
options = { :env => { "LC_ALL" => nil } }
|
261
|
+
expect(shell_out_obj).to receive(:shell_out_command).with(cmd, options).and_return(true)
|
262
|
+
shell_out_obj.shell_out(cmd, **options, default_env: false)
|
263
|
+
end
|
264
|
+
|
265
|
+
it "should not change env when set to non-nil" do
|
266
|
+
options = { :env => { "LC_ALL" => "en_US.UTF-8" } }
|
267
|
+
expect(shell_out_obj).to receive(:shell_out_command).with(cmd, options).and_return(true)
|
268
|
+
shell_out_obj.shell_out(cmd, **options, default_env: false)
|
269
|
+
end
|
270
|
+
|
271
|
+
it "should no longer set env['LC_ALL'] to nil when 'LC_ALL' not present" do
|
272
|
+
options = { :env => { "HOME" => "/Users/morty" } }
|
273
|
+
expect(shell_out_obj).to receive(:shell_out_command).with(cmd, options).and_return(true)
|
274
|
+
shell_out_obj.shell_out(cmd, **options, default_env: false)
|
275
|
+
end
|
276
|
+
end
|
277
|
+
|
278
|
+
describe "and no env/environment option is present" do
|
279
|
+
it "should no longer add environment option and set environment['LC_ALL'] to nil" do
|
280
|
+
options = { :user => "morty" }
|
281
|
+
expect(shell_out_obj).to receive(:shell_out_command).with(cmd, options).and_return(true)
|
282
|
+
shell_out_obj.shell_out(cmd, **options, default_env: false)
|
283
|
+
end
|
284
|
+
end
|
285
|
+
end
|
286
|
+
|
287
|
+
describe "when the last argument is not a Hash" do
|
288
|
+
it "should no longer add environment options and set environment['LC_ALL'] to nil" do
|
289
|
+
expect(shell_out_obj).to receive(:shell_out_command).with(cmd, {}).and_return(true)
|
290
|
+
shell_out_obj.shell_out(cmd, default_env: false)
|
291
|
+
end
|
292
|
+
end
|
293
|
+
end
|
294
|
+
|
235
295
|
end
|
236
296
|
end
|
@@ -1,6 +1,6 @@
|
|
1
1
|
#
|
2
2
|
# Author:: Thom May (<thom@chef.io>)
|
3
|
-
# Copyright:: Copyright (c) 2016-
|
3
|
+
# Copyright:: Copyright (c) 2016-2018, Chef Software Inc.
|
4
4
|
# License:: Apache License, Version 2.0
|
5
5
|
#
|
6
6
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
@@ -45,7 +45,7 @@ describe Chef::Provider::AptUpdate do
|
|
45
45
|
before do
|
46
46
|
FileUtils.rmdir config_dir
|
47
47
|
expect(File.exist?(config_dir)).to be false
|
48
|
-
allow_any_instance_of(Chef::Provider::Execute).to receive(:
|
48
|
+
allow_any_instance_of(Chef::Provider::Execute).to receive(:shell_out!).with("apt-get -q update", anything())
|
49
49
|
end
|
50
50
|
|
51
51
|
it "should create the directory" do
|
@@ -64,7 +64,7 @@ describe Chef::Provider::AptUpdate do
|
|
64
64
|
describe "#action_update" do
|
65
65
|
it "should update the apt cache" do
|
66
66
|
provider.load_current_resource
|
67
|
-
expect_any_instance_of(Chef::Provider::Execute).to receive(:
|
67
|
+
expect_any_instance_of(Chef::Provider::Execute).to receive(:shell_out!).with("apt-get -q update", anything())
|
68
68
|
provider.run_action(:update)
|
69
69
|
expect(new_resource).to be_updated_by_last_action
|
70
70
|
end
|
@@ -79,14 +79,14 @@ describe Chef::Provider::AptUpdate do
|
|
79
79
|
|
80
80
|
it "should run if the time stamp is old" do
|
81
81
|
expect(File).to receive(:mtime).with("#{stamp_dir}/update-success-stamp").and_return(Time.now - 86_500)
|
82
|
-
expect_any_instance_of(Chef::Provider::Execute).to receive(:
|
82
|
+
expect_any_instance_of(Chef::Provider::Execute).to receive(:shell_out!).with("apt-get -q update", anything())
|
83
83
|
provider.run_action(:periodic)
|
84
84
|
expect(new_resource).to be_updated_by_last_action
|
85
85
|
end
|
86
86
|
|
87
87
|
it "should not run if the time stamp is new" do
|
88
88
|
expect(File).to receive(:mtime).with("#{stamp_dir}/update-success-stamp").and_return(Time.now)
|
89
|
-
expect_any_instance_of(Chef::Provider::Execute).not_to receive(:
|
89
|
+
expect_any_instance_of(Chef::Provider::Execute).not_to receive(:shell_out!).with("apt-get -q update", anything())
|
90
90
|
provider.run_action(:periodic)
|
91
91
|
expect(new_resource).to_not be_updated_by_last_action
|
92
92
|
end
|
@@ -98,14 +98,14 @@ describe Chef::Provider::AptUpdate do
|
|
98
98
|
|
99
99
|
it "should run if the time stamp is old" do
|
100
100
|
expect(File).to receive(:mtime).with("#{stamp_dir}/update-success-stamp").and_return(Time.now - 500)
|
101
|
-
expect_any_instance_of(Chef::Provider::Execute).to receive(:
|
101
|
+
expect_any_instance_of(Chef::Provider::Execute).to receive(:shell_out!).with("apt-get -q update", anything())
|
102
102
|
provider.run_action(:periodic)
|
103
103
|
expect(new_resource).to be_updated_by_last_action
|
104
104
|
end
|
105
105
|
|
106
106
|
it "should not run if the time stamp is new" do
|
107
107
|
expect(File).to receive(:mtime).with("#{stamp_dir}/update-success-stamp").and_return(Time.now - 300)
|
108
|
-
expect_any_instance_of(Chef::Provider::Execute).not_to receive(:
|
108
|
+
expect_any_instance_of(Chef::Provider::Execute).not_to receive(:shell_out!).with("apt-get -q update", anything())
|
109
109
|
provider.run_action(:periodic)
|
110
110
|
expect(new_resource).to_not be_updated_by_last_action
|
111
111
|
end
|
@@ -1,6 +1,6 @@
|
|
1
1
|
#
|
2
2
|
# Author:: Prajakta Purohit (<prajakta@chef.io>)
|
3
|
-
# Copyright:: Copyright 2008-
|
3
|
+
# Copyright:: Copyright 2008-2018, Chef Software Inc.
|
4
4
|
# License:: Apache License, Version 2.0
|
5
5
|
#
|
6
6
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
@@ -33,6 +33,7 @@ describe Chef::Provider::Execute do
|
|
33
33
|
timeout: 3600,
|
34
34
|
returns: 0,
|
35
35
|
log_level: :info,
|
36
|
+
default_env: false,
|
36
37
|
log_tag: new_resource.to_s,
|
37
38
|
}
|
38
39
|
end
|
@@ -76,7 +77,7 @@ describe Chef::Provider::Execute do
|
|
76
77
|
|
77
78
|
describe "#action_run" do
|
78
79
|
it "runs shell_out with the default options" do
|
79
|
-
expect(provider).to receive(:
|
80
|
+
expect(provider).to receive(:shell_out!).with(new_resource.name, opts)
|
80
81
|
expect(provider).to receive(:converge_by).with("execute foo_resource").and_call_original
|
81
82
|
expect(Chef::Log).not_to receive(:warn)
|
82
83
|
provider.run_action(:run)
|
@@ -103,7 +104,7 @@ describe Chef::Provider::Execute do
|
|
103
104
|
|
104
105
|
it "if you pass a command attribute, it runs the command" do
|
105
106
|
new_resource.command "/usr/argelbargle/bin/oogachacka 12345"
|
106
|
-
expect(provider).to receive(:
|
107
|
+
expect(provider).to receive(:shell_out!).with(new_resource.command, opts)
|
107
108
|
expect(provider).to receive(:converge_by).with("execute #{new_resource.command}").and_call_original
|
108
109
|
expect(Chef::Log).not_to receive(:warn)
|
109
110
|
provider.run_action(:run)
|
@@ -114,7 +115,7 @@ describe Chef::Provider::Execute do
|
|
114
115
|
new_resource.sensitive true
|
115
116
|
# Since the resource is sensitive, it should not have :live_stream set
|
116
117
|
opts.delete(:live_stream)
|
117
|
-
expect(provider).to receive(:
|
118
|
+
expect(provider).to receive(:shell_out!).with(new_resource.name, opts)
|
118
119
|
expect(provider).to receive(:converge_by).with("execute sensitive resource").and_call_original
|
119
120
|
expect(Chef::Log).not_to receive(:warn)
|
120
121
|
provider.run_action(:run)
|
@@ -124,7 +125,7 @@ describe Chef::Provider::Execute do
|
|
124
125
|
it "should do nothing if the sentinel file exists" do
|
125
126
|
new_resource.creates "/foo_resource"
|
126
127
|
expect(FileTest).to receive(:exist?).with(new_resource.creates).and_return(true)
|
127
|
-
expect(provider).not_to receive(:
|
128
|
+
expect(provider).not_to receive(:shell_out!)
|
128
129
|
expect(Chef::Log).not_to receive(:warn)
|
129
130
|
provider.run_action(:run)
|
130
131
|
expect(new_resource).not_to be_updated
|
@@ -137,7 +138,7 @@ describe Chef::Provider::Execute do
|
|
137
138
|
end
|
138
139
|
|
139
140
|
it "should raise if user specified relative path without cwd for Chef-13" do
|
140
|
-
expect(provider).not_to receive(:
|
141
|
+
expect(provider).not_to receive(:shell_out!)
|
141
142
|
expect { provider.run_action(:run) }.to raise_error(Chef::Exceptions::Execute)
|
142
143
|
end
|
143
144
|
end
|
@@ -148,7 +149,7 @@ describe Chef::Provider::Execute do
|
|
148
149
|
expect(FileTest).not_to receive(:exist?).with(new_resource.creates)
|
149
150
|
expect(FileTest).to receive(:exist?).with(File.join("/tmp", new_resource.creates)).and_return(true)
|
150
151
|
expect(Chef::Log).not_to receive(:warn)
|
151
|
-
expect(provider).not_to receive(:
|
152
|
+
expect(provider).not_to receive(:shell_out!)
|
152
153
|
|
153
154
|
provider.run_action(:run)
|
154
155
|
expect(new_resource).not_to be_updated
|
@@ -157,7 +158,7 @@ describe Chef::Provider::Execute do
|
|
157
158
|
it "should not include stdout/stderr in failure exception for sensitive resource" do
|
158
159
|
opts.delete(:live_stream)
|
159
160
|
new_resource.sensitive true
|
160
|
-
expect(provider).to receive(:
|
161
|
+
expect(provider).to receive(:shell_out!).and_raise(Mixlib::ShellOut::ShellCommandFailed)
|
161
162
|
expect do
|
162
163
|
provider.run_action(:run)
|
163
164
|
end.to raise_error(Mixlib::ShellOut::ShellCommandFailed, /suppressed for sensitive resource/)
|
@@ -166,7 +167,7 @@ describe Chef::Provider::Execute do
|
|
166
167
|
describe "streaming output" do
|
167
168
|
it "should not set the live_stream if sensitive is on" do
|
168
169
|
new_resource.sensitive true
|
169
|
-
expect(provider).to receive(:
|
170
|
+
expect(provider).to receive(:shell_out!).with(new_resource.name, opts)
|
170
171
|
expect(provider).to receive(:converge_by).with("execute sensitive resource").and_call_original
|
171
172
|
expect(Chef::Log).not_to receive(:warn)
|
172
173
|
provider.run_action(:run)
|
@@ -183,7 +184,7 @@ describe Chef::Provider::Execute do
|
|
183
184
|
it "should set the live_stream if the log level is info or above" do
|
184
185
|
nopts = opts
|
185
186
|
nopts[:live_stream] = @live_stream
|
186
|
-
expect(provider).to receive(:
|
187
|
+
expect(provider).to receive(:shell_out!).with(new_resource.name, nopts)
|
187
188
|
expect(provider).to receive(:converge_by).with("execute foo_resource").and_call_original
|
188
189
|
expect(Chef::Log).not_to receive(:warn)
|
189
190
|
provider.run_action(:run)
|
@@ -195,7 +196,7 @@ describe Chef::Provider::Execute do
|
|
195
196
|
new_resource.live_stream true
|
196
197
|
nopts = opts
|
197
198
|
nopts[:live_stream] = @live_stream
|
198
|
-
expect(provider).to receive(:
|
199
|
+
expect(provider).to receive(:shell_out!).with(new_resource.name, nopts)
|
199
200
|
expect(provider).to receive(:converge_by).with("execute foo_resource").and_call_original
|
200
201
|
expect(Chef::Log).not_to receive(:warn)
|
201
202
|
provider.run_action(:run)
|
@@ -204,7 +205,7 @@ describe Chef::Provider::Execute do
|
|
204
205
|
|
205
206
|
it "should not set the live_stream if the resource is sensitive" do
|
206
207
|
new_resource.sensitive true
|
207
|
-
expect(provider).to receive(:
|
208
|
+
expect(provider).to receive(:shell_out!).with(new_resource.name, opts)
|
208
209
|
expect(provider).to receive(:converge_by).with("execute sensitive resource").and_call_original
|
209
210
|
expect(Chef::Log).not_to receive(:warn)
|
210
211
|
provider.run_action(:run)
|
@@ -217,7 +218,7 @@ describe Chef::Provider::Execute do
|
|
217
218
|
nopts = opts
|
218
219
|
nopts[:live_stream] = STDOUT
|
219
220
|
allow(STDOUT).to receive(:tty?).and_return(true)
|
220
|
-
expect(provider).to receive(:
|
221
|
+
expect(provider).to receive(:shell_out!).with(new_resource.name, nopts)
|
221
222
|
expect(provider).to receive(:converge_by).with("execute foo_resource").and_call_original
|
222
223
|
expect(Chef::Log).not_to receive(:warn)
|
223
224
|
provider.run_action(:run)
|
@@ -227,7 +228,7 @@ describe Chef::Provider::Execute do
|
|
227
228
|
it "should not set the live_stream to STDOUT if we are a TTY, not daemonized, but sensitive" do
|
228
229
|
new_resource.sensitive true
|
229
230
|
allow(STDOUT).to receive(:tty?).and_return(true)
|
230
|
-
expect(provider).to receive(:
|
231
|
+
expect(provider).to receive(:shell_out!).with(new_resource.name, opts)
|
231
232
|
expect(provider).to receive(:converge_by).with("execute sensitive resource").and_call_original
|
232
233
|
expect(Chef::Log).not_to receive(:warn)
|
233
234
|
provider.run_action(:run)
|
@@ -237,7 +238,7 @@ describe Chef::Provider::Execute do
|
|
237
238
|
it "should not set the live_stream to STDOUT if we are a TTY, but daemonized" do
|
238
239
|
Chef::Config[:daemon] = true
|
239
240
|
allow(STDOUT).to receive(:tty?).and_return(true)
|
240
|
-
expect(provider).to receive(:
|
241
|
+
expect(provider).to receive(:shell_out!).with(new_resource.name, opts)
|
241
242
|
expect(provider).to receive(:converge_by).with("execute foo_resource").and_call_original
|
242
243
|
expect(Chef::Log).not_to receive(:warn)
|
243
244
|
provider.run_action(:run)
|