chef 11.12.8-x86-mingw32 → 11.14.0.alpha.2-x86-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/Rakefile +4 -2
- data/distro/common/html/_sources/index.txt +6 -0
- data/distro/common/html/_sources/knife_ssl_check.txt +41 -0
- data/distro/common/html/_sources/knife_ssl_fetch.txt +41 -0
- data/distro/common/html/_static/basic.css +2 -5
- data/distro/common/html/_static/doctools.js +5 -14
- data/distro/common/html/_static/jquery.js +2 -154
- data/distro/common/html/_static/pygments.css +2 -2
- data/distro/common/html/_static/searchtools.js +212 -150
- data/distro/common/html/_static/underscore.js +29 -21
- data/distro/common/html/_static/websupport.js +1 -1
- data/distro/common/html/ctl_chef_client.html +15 -18
- data/distro/common/html/ctl_chef_server.html +7 -7
- data/distro/common/html/ctl_chef_shell.html +6 -6
- data/distro/common/html/ctl_chef_solo.html +7 -8
- data/distro/common/html/index.html +34 -24
- data/distro/common/html/knife.html +23 -24
- data/distro/common/html/knife_bootstrap.html +13 -9
- data/distro/common/html/knife_client.html +10 -11
- data/distro/common/html/knife_common_options.html +6 -7
- data/distro/common/html/knife_configure.html +3 -4
- data/distro/common/html/knife_cookbook.html +18 -11
- data/distro/common/html/knife_cookbook_site.html +14 -14
- data/distro/common/html/knife_data_bag.html +24 -23
- data/distro/common/html/knife_delete.html +4 -5
- data/distro/common/html/knife_deps.html +4 -5
- data/distro/common/html/knife_diff.html +6 -7
- data/distro/common/html/knife_download.html +12 -13
- data/distro/common/html/knife_edit.html +4 -5
- data/distro/common/html/knife_environment.html +8 -9
- data/distro/common/html/knife_exec.html +9 -10
- data/distro/common/html/knife_index_rebuild.html +4 -5
- data/distro/common/html/knife_list.html +8 -9
- data/distro/common/html/knife_node.html +34 -33
- data/distro/common/html/knife_raw.html +2 -3
- data/distro/common/html/knife_recipe_list.html +3 -4
- data/distro/common/html/knife_role.html +30 -29
- data/distro/common/html/knife_search.html +7 -7
- data/distro/common/html/knife_show.html +4 -5
- data/distro/common/html/knife_ssh.html +2 -3
- data/distro/common/html/knife_ssl_check.html +148 -0
- data/distro/common/html/knife_ssl_fetch.html +152 -0
- data/distro/common/html/knife_status.html +4 -5
- data/distro/common/html/knife_tag.html +2 -3
- data/distro/common/html/knife_upload.html +5 -6
- data/distro/common/html/knife_user.html +9 -10
- data/distro/common/html/knife_using.html +12 -12
- data/distro/common/html/knife_xargs.html +11 -12
- data/distro/common/html/search.html +1 -2
- data/distro/common/html/searchindex.js +1 -1
- data/distro/common/man/man1/chef-shell.1 +19 -11
- data/distro/common/man/man1/knife-bootstrap.1 +35 -19
- data/distro/common/man/man1/knife-client.1 +111 -28
- data/distro/common/man/man1/knife-configure.1 +30 -14
- data/distro/common/man/man1/knife-cookbook-site.1 +105 -22
- data/distro/common/man/man1/knife-cookbook.1 +164 -23
- data/distro/common/man/man1/knife-data-bag.1 +157 -33
- data/distro/common/man/man1/knife-delete.1 +21 -17
- data/distro/common/man/man1/knife-deps.1 +60 -16
- data/distro/common/man/man1/knife-diff.1 +37 -17
- data/distro/common/man/man1/knife-download.1 +68 -24
- data/distro/common/man/man1/knife-edit.1 +19 -15
- data/distro/common/man/man1/knife-environment.1 +105 -17
- data/distro/common/man/man1/knife-exec.1 +78 -18
- data/distro/common/man/man1/knife-index-rebuild.1 +16 -8
- data/distro/common/man/man1/knife-list.1 +39 -23
- data/distro/common/man/man1/knife-node.1 +170 -22
- data/distro/common/man/man1/knife-raw.1 +33 -13
- data/distro/common/man/man1/knife-recipe-list.1 +17 -5
- data/distro/common/man/man1/knife-role.1 +86 -18
- data/distro/common/man/man1/knife-search.1 +80 -16
- data/distro/common/man/man1/knife-show.1 +30 -14
- data/distro/common/man/man1/knife-ssh.1 +54 -14
- data/distro/common/man/man1/knife-ssl-check.1 +207 -0
- data/distro/common/man/man1/knife-ssl-fetch.1 +207 -0
- data/distro/common/man/man1/knife-status.1 +48 -12
- data/distro/common/man/man1/knife-tag.1 +30 -10
- data/distro/common/man/man1/knife-upload.1 +72 -20
- data/distro/common/man/man1/knife-user.1 +79 -23
- data/distro/common/man/man1/knife-xargs.1 +61 -53
- data/distro/common/man/man8/chef-client.8 +87 -29
- data/distro/common/man/man8/chef-solo.8 +36 -15
- data/lib/chef/application.rb +19 -14
- data/lib/chef/application/client.rb +5 -0
- data/lib/chef/application/solo.rb +5 -0
- data/lib/chef/application/windows_service_manager.rb +3 -0
- data/lib/chef/chef_fs/chef_fs_data_store.rb +72 -24
- data/lib/chef/chef_fs/file_system/chef_repository_file_system_cookbook_dir.rb +20 -4
- data/lib/chef/chef_fs/file_system/chef_repository_file_system_cookbooks_dir.rb +20 -1
- data/lib/chef/chef_fs/file_system/file_system_entry.rb +10 -2
- data/lib/chef/client.rb +2 -3
- data/lib/chef/config.rb +34 -8
- data/lib/chef/cookbook/cookbook_version_loader.rb +45 -4
- data/lib/chef/cookbook_version.rb +38 -30
- data/lib/chef/dsl/recipe.rb +4 -1
- data/lib/chef/event_dispatch/base.rb +14 -0
- data/lib/chef/event_dispatch/events_output_stream.rb +29 -0
- data/lib/chef/exceptions.rb +8 -0
- data/lib/chef/formatters/base.rb +16 -45
- data/lib/chef/formatters/doc.rb +51 -26
- data/lib/chef/formatters/indentable_output_stream.rb +165 -0
- data/lib/chef/knife/node_environment_set.rb +54 -0
- data/lib/chef/knife/user_create.rb +1 -1
- data/lib/chef/monkey_patches/pathname.rb +32 -0
- data/lib/chef/node.rb +1 -1
- data/lib/chef/platform/provider_mapping.rb +345 -338
- data/lib/chef/policy_builder/expand_node_object.rb +1 -1
- data/lib/chef/policy_builder/policyfile.rb +1 -1
- data/lib/chef/provider.rb +1 -0
- data/lib/chef/provider/git.rb +1 -1
- data/lib/chef/provider/link.rb +2 -2
- data/lib/chef/provider/remote_file/content.rb +1 -1
- data/lib/chef/provider/remote_file/local_file.rb +8 -2
- data/lib/chef/provider/service/arch.rb +0 -1
- data/lib/chef/provider/service/debian.rb +0 -2
- data/lib/chef/provider/service/freebsd.rb +2 -1
- data/lib/chef/provider/service/gentoo.rb +1 -1
- data/lib/chef/provider/service/init.rb +0 -1
- data/lib/chef/provider/service/insserv.rb +0 -2
- data/lib/chef/provider/service/invokercd.rb +0 -2
- data/lib/chef/provider/service/macosx.rb +2 -1
- data/lib/chef/provider/service/redhat.rb +0 -1
- data/lib/chef/provider/service/simple.rb +1 -0
- data/lib/chef/provider/service/solaris.rb +1 -0
- data/lib/chef/provider/service/systemd.rb +1 -1
- data/lib/chef/provider/service/upstart.rb +1 -1
- data/lib/chef/provider/user.rb +9 -9
- data/lib/chef/provider/user/solaris.rb +2 -0
- data/lib/chef/resource.rb +1 -0
- data/lib/chef/resource/remote_file.rb +32 -6
- data/lib/chef/run_context.rb +22 -0
- data/lib/chef/run_lock.rb +43 -4
- data/lib/chef/version.rb +2 -2
- data/spec/functional/http/simple_spec.rb +84 -0
- data/spec/functional/resource/remote_file_spec.rb +107 -43
- data/spec/functional/rest_spec.rb +94 -0
- data/spec/functional/run_lock_spec.rb +1 -1
- data/spec/functional/win32/service_manager_spec.rb +6 -0
- data/spec/integration/knife/chef_fs_data_store_spec.rb +2 -0
- data/spec/integration/recipes/lwrp_inline_resources_spec.rb +76 -0
- data/spec/spec_helper.rb +2 -0
- data/spec/support/mock/platform.rb +7 -0
- data/spec/support/pedant/pedant_config.rb +121 -0
- data/spec/support/pedant/run_pedant.rb +63 -0
- data/spec/support/pedant/stickywicket.pem +27 -0
- data/spec/support/shared/functional/http.rb +242 -0
- data/spec/support/shared/unit/api_error_inspector.rb +2 -2
- data/spec/unit/api_client_spec.rb +2 -2
- data/spec/unit/application/client_spec.rb +6 -1
- data/spec/unit/application/knife_spec.rb +4 -0
- data/spec/unit/application/solo_spec.rb +2 -0
- data/spec/unit/application_spec.rb +7 -0
- data/spec/unit/client_spec.rb +16 -0
- data/spec/unit/config_spec.rb +3 -20
- data/spec/unit/cookbook_version_spec.rb +224 -122
- data/spec/unit/formatters/error_inspectors/compile_error_inspector_spec.rb +2 -2
- data/spec/unit/formatters/error_inspectors/cookbook_resolve_error_inspector_spec.rb +2 -2
- data/spec/unit/formatters/error_inspectors/cookbook_sync_error_inspector_spec.rb +2 -2
- data/spec/unit/formatters/error_inspectors/resource_failure_inspector_spec.rb +2 -2
- data/spec/unit/formatters/error_inspectors/run_list_expansion_error_inspector_spec.rb +2 -2
- data/spec/unit/handler_spec.rb +0 -1
- data/spec/unit/knife/client_bulk_delete_spec.rb +3 -0
- data/spec/unit/knife/cookbook_bulk_delete_spec.rb +2 -0
- data/spec/unit/knife/cookbook_metadata_spec.rb +2 -2
- data/spec/unit/knife/cookbook_site_install_spec.rb +3 -1
- data/spec/unit/knife/cookbook_upload_spec.rb +10 -10
- data/spec/unit/knife/node_environment_set_spec.rb +80 -0
- data/spec/unit/knife/user_create_spec.rb +6 -4
- data/spec/unit/knife/user_edit_spec.rb +5 -0
- data/spec/unit/knife_spec.rb +3 -0
- data/spec/unit/mixin/securable_spec.rb +18 -20
- data/spec/unit/node/attribute_spec.rb +15 -2
- data/spec/unit/node/immutable_collections_spec.rb +4 -4
- data/spec/unit/provider/cron_spec.rb +14 -14
- data/spec/unit/provider/git_spec.rb +4 -4
- data/spec/unit/provider/group_spec.rb +1 -1
- data/spec/unit/provider/ohai_spec.rb +2 -2
- data/spec/unit/provider/remote_file/content_spec.rb +58 -35
- data/spec/unit/provider/remote_file/local_file_spec.rb +23 -0
- data/spec/unit/provider/service/solaris_smf_service_spec.rb +13 -13
- data/spec/unit/resource/mount_spec.rb +0 -1
- data/spec/unit/resource/remote_file_spec.rb +29 -0
- data/spec/unit/resource_spec.rb +1 -1
- data/spec/unit/run_context_spec.rb +7 -0
- data/spec/unit/run_lock_spec.rb +98 -0
- data/spec/unit/version_constraint_spec.rb +1 -1
- metadata +166 -153
- data/distro/common/html/_static/chef.css +0 -507
- data/distro/common/html/_static/chef_logo.png +0 -0
- data/lib/chef/checksum/storage.rb +0 -18
- data/lib/chef/checksum/storage/filesystem.rb +0 -56
- data/spec/unit/checksum/storage/filesystem_spec.rb +0 -70
@@ -24,7 +24,7 @@ describe Chef::Provider::Cron do
|
|
24
24
|
@node = Chef::Node.new
|
25
25
|
@events = Chef::EventDispatch::Dispatcher.new
|
26
26
|
@run_context = Chef::RunContext.new(@node, {}, @events)
|
27
|
-
|
27
|
+
|
28
28
|
@new_resource = Chef::Resource::Cron.new("cronhole some stuff", @run_context)
|
29
29
|
@new_resource.user "root"
|
30
30
|
@new_resource.minute "30"
|
@@ -32,10 +32,10 @@ describe Chef::Provider::Cron do
|
|
32
32
|
@new_resource.time :reboot
|
33
33
|
@provider = Chef::Provider::Cron.new(@new_resource, @run_context)
|
34
34
|
end
|
35
|
-
|
35
|
+
|
36
36
|
context "with a matching entry in the user's crontab" do
|
37
37
|
before :each do
|
38
|
-
@provider.stub
|
38
|
+
@provider.stub(:read_crontab).and_return(<<-CRONTAB)
|
39
39
|
0 2 * * * /some/other/command
|
40
40
|
|
41
41
|
# Chef Name: cronhole some stuff
|
@@ -46,7 +46,7 @@ describe Chef::Provider::Cron do
|
|
46
46
|
# Another comment
|
47
47
|
CRONTAB
|
48
48
|
end
|
49
|
-
|
49
|
+
|
50
50
|
it "should set cron_exists" do
|
51
51
|
@provider.load_current_resource
|
52
52
|
@provider.cron_exists.should == true
|
@@ -60,7 +60,7 @@ CRONTAB
|
|
60
60
|
end
|
61
61
|
|
62
62
|
it "should pull env vars out" do
|
63
|
-
@provider.stub
|
63
|
+
@provider.stub(:read_crontab).and_return(<<-CRONTAB)
|
64
64
|
0 2 * * * /some/other/command
|
65
65
|
|
66
66
|
# Chef Name: cronhole some stuff
|
@@ -84,7 +84,7 @@ CRONTAB
|
|
84
84
|
end
|
85
85
|
|
86
86
|
it "should parse and load generic and standard environment variables from cron entry" do
|
87
|
-
@provider.stub
|
87
|
+
@provider.stub(:read_crontab).and_return(<<-CRONTAB)
|
88
88
|
# Chef Name: cronhole some stuff
|
89
89
|
MAILTO=warn@example.com
|
90
90
|
TEST=lol
|
@@ -98,7 +98,7 @@ CRONTAB
|
|
98
98
|
end
|
99
99
|
|
100
100
|
it "should not break with variables that match the cron resource internals" do
|
101
|
-
@provider.stub
|
101
|
+
@provider.stub(:read_crontab).and_return(<<-CRONTAB)
|
102
102
|
# Chef Name: cronhole some stuff
|
103
103
|
MINUTE=40
|
104
104
|
REBOOT=midnight
|
@@ -116,11 +116,11 @@ CRONTAB
|
|
116
116
|
Chef::Log.should_receive(:debug).with("Found cron '#{@new_resource.name}'")
|
117
117
|
@provider.load_current_resource
|
118
118
|
end
|
119
|
-
|
119
|
+
|
120
120
|
describe "action_create" do
|
121
121
|
before :each do
|
122
|
-
@provider.stub
|
123
|
-
@provider.stub
|
122
|
+
@provider.stub(:write_crontab)
|
123
|
+
@provider.stub(:read_crontab).and_return(nil)
|
124
124
|
end
|
125
125
|
|
126
126
|
context "when there is no existing crontab" do
|
@@ -128,7 +128,7 @@ CRONTAB
|
|
128
128
|
@provider.cron_exists = false
|
129
129
|
@provider.cron_empty = true
|
130
130
|
end
|
131
|
-
|
131
|
+
|
132
132
|
it "should create a crontab with the entry" do
|
133
133
|
@provider.should_receive(:write_crontab).with(<<-ENDCRON)
|
134
134
|
# Chef Name: cronhole some stuff
|
@@ -140,12 +140,12 @@ CRONTAB
|
|
140
140
|
end
|
141
141
|
end
|
142
142
|
end
|
143
|
-
|
143
|
+
|
144
144
|
before do
|
145
145
|
@node = Chef::Node.new
|
146
146
|
@events = Chef::EventDispatch::Dispatcher.new
|
147
147
|
@run_context = Chef::RunContext.new(@node, {}, @events)
|
148
|
-
|
148
|
+
|
149
149
|
@new_resource = Chef::Resource::Cron.new("cronhole some stuff", @run_context)
|
150
150
|
@new_resource.user "root"
|
151
151
|
@new_resource.minute "30"
|
@@ -417,7 +417,7 @@ CRONTAB
|
|
417
417
|
@new_resource.send(:time, :reboot)
|
418
418
|
@provider.cron_different?.should eql(true)
|
419
419
|
end
|
420
|
-
|
420
|
+
|
421
421
|
it "should return true if environment doesn't match" do
|
422
422
|
@new_resource.environment "FOO" => "something_else"
|
423
423
|
@provider.cron_different?.should eql(true)
|
@@ -93,7 +93,7 @@ describe Chef::Provider::Git do
|
|
93
93
|
@resource.revision "v1.0"
|
94
94
|
@stdout = ("d03c22a5e41f5ae3193460cca044ed1435029f53\trefs/heads/0.8-alpha\n" +
|
95
95
|
"503c22a5e41f5ae3193460cca044ed1435029f53\trefs/heads/v1.0\n")
|
96
|
-
@provider.should_receive(:shell_out!).with(@git_ls_remote + "v1.0
|
96
|
+
@provider.should_receive(:shell_out!).with(@git_ls_remote + "\"v1.0*\"", {:log_tag=>"git[web2.0 app]"}).and_return(double("ShellOut result", :stdout => @stdout))
|
97
97
|
@provider.target_revision.should eql("503c22a5e41f5ae3193460cca044ed1435029f53")
|
98
98
|
end
|
99
99
|
|
@@ -102,7 +102,7 @@ describe Chef::Provider::Git do
|
|
102
102
|
@stdout = ("d03c22a5e41f5ae3193460cca044ed1435029f53\trefs/heads/0.8-alpha\n" +
|
103
103
|
"503c22a5e41f5ae3193460cca044ed1435029f53\trefs/heads/v1.0\n" +
|
104
104
|
"663c22a5e41f5ae3193460cca044ed1435029f53\trefs/heads/v1.0^{}\n")
|
105
|
-
@provider.should_receive(:shell_out!).with(@git_ls_remote + "v1.0
|
105
|
+
@provider.should_receive(:shell_out!).with(@git_ls_remote + "\"v1.0*\"", {:log_tag=>"git[web2.0 app]"}).and_return(double("ShellOut result", :stdout => @stdout))
|
106
106
|
@provider.target_revision.should eql("663c22a5e41f5ae3193460cca044ed1435029f53")
|
107
107
|
end
|
108
108
|
|
@@ -131,7 +131,7 @@ describe Chef::Provider::Git do
|
|
131
131
|
it "does not raise an error when the revision is valid and assertions are run." do
|
132
132
|
@resource.revision "0.8-alpha"
|
133
133
|
@stdout = "503c22a5e41f5ae3193460cca044ed1435029f53\trefs/heads/0.8-alpha\n"
|
134
|
-
@provider.should_receive(:shell_out!).with(@git_ls_remote + "0.8-alpha
|
134
|
+
@provider.should_receive(:shell_out!).with(@git_ls_remote + "\"0.8-alpha*\"", {:log_tag=>"git[web2.0 app]"}).and_return(double("ShellOut result", :stdout => @stdout))
|
135
135
|
@provider.action = :checkout
|
136
136
|
::File.stub(:directory?).with("/my/deploy").and_return(true)
|
137
137
|
@provider.define_resource_requirements
|
@@ -156,7 +156,7 @@ b7d19519a1c15f1c1a324e2683bd728b6198ce5a\trefs/tags/0.7.8^{}
|
|
156
156
|
ebc1b392fe7e8f0fbabc305c299b4d365d2b4d9b\trefs/tags/chef-server-package
|
157
157
|
SHAS
|
158
158
|
@resource.revision ''
|
159
|
-
@provider.should_receive(:shell_out!).with(@git_ls_remote + "HEAD", {:log_tag=>"git[web2.0 app]"}).and_return(double("ShellOut result", :stdout => @stdout))
|
159
|
+
@provider.should_receive(:shell_out!).with(@git_ls_remote + "\"HEAD\"", {:log_tag=>"git[web2.0 app]"}).and_return(double("ShellOut result", :stdout => @stdout))
|
160
160
|
@provider.target_revision.should eql("28af684d8460ba4793eda3e7ac238c864a5d029a")
|
161
161
|
end
|
162
162
|
end
|
@@ -97,7 +97,7 @@ describe Chef::Provider::User do
|
|
97
97
|
end
|
98
98
|
|
99
99
|
it "should coerce an integer to a string for comparison" do
|
100
|
-
@current_resource.stub
|
100
|
+
@current_resource.stub(:gid).and_return("500")
|
101
101
|
@provider.compare_group.should be_false
|
102
102
|
end
|
103
103
|
|
@@ -41,8 +41,8 @@ describe Chef::Provider::Ohai do
|
|
41
41
|
:newdata => "somevalue"
|
42
42
|
}
|
43
43
|
}
|
44
|
-
mock_ohai.stub
|
45
|
-
mock_ohai.stub
|
44
|
+
mock_ohai.stub(:all_plugins).and_return(true)
|
45
|
+
mock_ohai.stub(:data).and_return(mock_ohai[:data],
|
46
46
|
mock_ohai[:data2])
|
47
47
|
Ohai::System.stub(:new).and_return(mock_ohai)
|
48
48
|
Chef::Platform.stub(:find_platform_and_version).and_return({ "platform" => @platform,
|
@@ -160,44 +160,68 @@ describe Chef::Provider::RemoteFile::Content do
|
|
160
160
|
|
161
161
|
describe "when there is an array of sources and the first fails" do
|
162
162
|
|
163
|
-
|
164
|
-
|
165
|
-
|
166
|
-
|
167
|
-
|
168
|
-
|
169
|
-
URI.should_receive(:parse).with(new_resource.source[0]).and_return(@uri0)
|
170
|
-
URI.should_receive(:parse).with(new_resource.source[1]).and_return(@uri1)
|
171
|
-
@http_fetcher_throws_exception = double("Chef::Provider::RemoteFile::HTTP")
|
172
|
-
@http_fetcher_throws_exception.should_receive(:fetch).at_least(:once).and_raise(Errno::ECONNREFUSED)
|
173
|
-
Chef::Provider::RemoteFile::Fetcher.should_receive(:for_resource).with(@uri0, new_resource, current_resource).and_return(@http_fetcher_throws_exception)
|
174
|
-
end
|
175
|
-
|
176
|
-
describe "when the second url succeeds" do
|
177
|
-
before do
|
178
|
-
@tempfile = double("Tempfile")
|
179
|
-
mtime = Time.now
|
180
|
-
http_fetcher_works = double("Chef::Provider::RemoteFile::HTTP", :fetch => @tempfile)
|
181
|
-
Chef::Provider::RemoteFile::Fetcher.should_receive(:for_resource).with(@uri1, new_resource, current_resource).and_return(http_fetcher_works)
|
182
|
-
end
|
183
|
-
|
184
|
-
it "should return a valid tempfile" do
|
185
|
-
content.tempfile.should == @tempfile
|
186
|
-
end
|
187
|
-
|
188
|
-
it "should not mutate the new_resource" do
|
189
|
-
content.tempfile
|
190
|
-
new_resource.source.length.should == 2
|
163
|
+
# https://github.com/opscode/chef/pull/1358#issuecomment-40853299
|
164
|
+
def create_exception(exception_class)
|
165
|
+
if [ Net::HTTPServerException, Net::HTTPFatalError ].include? exception_class
|
166
|
+
exception_class.new("message", {"something" => 1})
|
167
|
+
else
|
168
|
+
exception_class.new
|
191
169
|
end
|
192
170
|
end
|
193
171
|
|
194
|
-
|
195
|
-
before do
|
196
|
-
Chef::Provider::RemoteFile::Fetcher.should_receive(:for_resource).with(@uri1, new_resource, current_resource).and_return(@http_fetcher_throws_exception)
|
197
|
-
end
|
172
|
+
let(:source) { [ "http://opscode.com/seattle.txt", "http://opscode.com/nyc.txt" ] }
|
198
173
|
|
199
|
-
|
200
|
-
|
174
|
+
### Test each exception we care about and make sure they all behave properly
|
175
|
+
[
|
176
|
+
SocketError,
|
177
|
+
Errno::ECONNREFUSED,
|
178
|
+
Errno::ENOENT,
|
179
|
+
Errno::EACCES,
|
180
|
+
Timeout::Error,
|
181
|
+
Net::HTTPServerException,
|
182
|
+
Net::HTTPFatalError,
|
183
|
+
Net::FTPError
|
184
|
+
].each do |exception|
|
185
|
+
describe "with an exception of #{exception}" do
|
186
|
+
before do
|
187
|
+
new_resource.stub(:checksum).and_return(nil)
|
188
|
+
current_resource.stub(:checksum).and_return(nil)
|
189
|
+
@uri0 = double("URI0")
|
190
|
+
@uri1 = double("URI1")
|
191
|
+
URI.should_receive(:parse).with(new_resource.source[0]).and_return(@uri0)
|
192
|
+
URI.should_receive(:parse).with(new_resource.source[1]).and_return(@uri1)
|
193
|
+
@http_fetcher_throws_exception = double("Chef::Provider::RemoteFile::HTTP")
|
194
|
+
@http_fetcher_throws_exception.should_receive(:fetch).at_least(:once).and_raise(create_exception(exception))
|
195
|
+
Chef::Provider::RemoteFile::Fetcher.should_receive(:for_resource).with(@uri0, new_resource, current_resource).and_return(@http_fetcher_throws_exception)
|
196
|
+
end
|
197
|
+
|
198
|
+
describe "the second url should succeed" do
|
199
|
+
before do
|
200
|
+
@tempfile = double("Tempfile")
|
201
|
+
mtime = Time.now
|
202
|
+
http_fetcher_works = double("Chef::Provider::RemoteFile::HTTP", :fetch => @tempfile)
|
203
|
+
Chef::Provider::RemoteFile::Fetcher.should_receive(:for_resource).with(@uri1, new_resource, current_resource).and_return(http_fetcher_works)
|
204
|
+
end
|
205
|
+
|
206
|
+
it "should return a valid tempfile" do
|
207
|
+
content.tempfile.should == @tempfile
|
208
|
+
end
|
209
|
+
|
210
|
+
it "should not mutate the new_resource" do
|
211
|
+
content.tempfile
|
212
|
+
new_resource.source.length.should == 2
|
213
|
+
end
|
214
|
+
end
|
215
|
+
|
216
|
+
describe "when both urls fail" do
|
217
|
+
before do
|
218
|
+
Chef::Provider::RemoteFile::Fetcher.should_receive(:for_resource).with(@uri1, new_resource, current_resource).and_return(@http_fetcher_throws_exception)
|
219
|
+
end
|
220
|
+
|
221
|
+
it "should propagate the error back to the caller" do
|
222
|
+
lambda { content.tempfile }.should raise_error(exception)
|
223
|
+
end
|
224
|
+
end
|
201
225
|
end
|
202
226
|
end
|
203
227
|
end
|
@@ -227,4 +251,3 @@ describe Chef::Provider::RemoteFile::Content do
|
|
227
251
|
end
|
228
252
|
|
229
253
|
end
|
230
|
-
|
@@ -25,6 +25,29 @@ describe Chef::Provider::RemoteFile::LocalFile do
|
|
25
25
|
let(:new_resource) { Chef::Resource::RemoteFile.new("local file backend test (new_resource)") }
|
26
26
|
let(:current_resource) { Chef::Resource::RemoteFile.new("local file backend test (current_resource)") }
|
27
27
|
subject(:fetcher) { Chef::Provider::RemoteFile::LocalFile.new(uri, new_resource, current_resource) }
|
28
|
+
|
29
|
+
context "when parsing source path" do
|
30
|
+
describe "when given local unix path" do
|
31
|
+
let(:uri) { URI.parse("file:///nyan_cat.png") }
|
32
|
+
it "returns a correct unix path" do
|
33
|
+
fetcher.fix_windows_path(uri.path).should == "/nyan_cat.png"
|
34
|
+
end
|
35
|
+
end
|
36
|
+
|
37
|
+
describe "when given local windows path" do
|
38
|
+
let(:uri) { URI.parse("file:///z:/windows/path/file.txt") }
|
39
|
+
it "returns a valid windows local path" do
|
40
|
+
fetcher.fix_windows_path(uri.path).should == "z:/windows/path/file.txt"
|
41
|
+
end
|
42
|
+
end
|
43
|
+
|
44
|
+
describe "when given unc windows path" do
|
45
|
+
let(:uri) { URI.parse("file:////server/share/windows/path/file.txt") }
|
46
|
+
it "returns a valid windows unc path" do
|
47
|
+
fetcher.fix_windows_path(uri.path).should == "//server/share/windows/path/file.txt"
|
48
|
+
end
|
49
|
+
end
|
50
|
+
end
|
28
51
|
|
29
52
|
context "when first created" do
|
30
53
|
|
@@ -54,14 +54,14 @@ describe Chef::Provider::Service::Solaris do
|
|
54
54
|
|
55
55
|
describe "when discovering the current service state" do
|
56
56
|
it "should create a current resource with the name of the new resource" do
|
57
|
-
@provider.stub
|
57
|
+
@provider.stub(:shell_out!).with("/bin/svcs -l chef").and_return(@status)
|
58
58
|
Chef::Resource::Service.should_receive(:new).and_return(@current_resource)
|
59
59
|
@provider.load_current_resource
|
60
60
|
end
|
61
61
|
|
62
62
|
|
63
63
|
it "should return the current resource" do
|
64
|
-
@provider.stub
|
64
|
+
@provider.stub(:shell_out!).with("/bin/svcs -l chef").and_return(@status)
|
65
65
|
@provider.load_current_resource.should eql(@current_resource)
|
66
66
|
end
|
67
67
|
|
@@ -71,27 +71,27 @@ describe Chef::Provider::Service::Solaris do
|
|
71
71
|
end
|
72
72
|
|
73
73
|
it "should mark service as not running" do
|
74
|
-
@provider.stub
|
74
|
+
@provider.stub(:shell_out!).and_return(@status)
|
75
75
|
@current_resource.should_receive(:running).with(false)
|
76
76
|
@provider.load_current_resource
|
77
77
|
end
|
78
78
|
|
79
79
|
it "should mark service as running" do
|
80
|
-
@status =
|
81
|
-
@provider.stub
|
80
|
+
@status = double("Status", :exitstatus => 0, :stdout => 'state online')
|
81
|
+
@provider.stub(:shell_out!).and_return(@status)
|
82
82
|
@current_resource.should_receive(:running).with(true)
|
83
83
|
@provider.load_current_resource
|
84
84
|
end
|
85
85
|
|
86
86
|
it "should not mark service as maintenance" do
|
87
|
-
@provider.stub
|
87
|
+
@provider.stub(:shell_out!).and_return(@status)
|
88
88
|
@provider.load_current_resource
|
89
89
|
@provider.maintenance.should be_false
|
90
90
|
end
|
91
91
|
|
92
92
|
it "should mark service as maintenance" do
|
93
|
-
@status =
|
94
|
-
@provider.stub
|
93
|
+
@status = double("Status", :exitstatus => 0, :stdout => 'state maintenance')
|
94
|
+
@provider.stub(:shell_out!).and_return(@status)
|
95
95
|
@provider.load_current_resource
|
96
96
|
@provider.maintenance.should be_true
|
97
97
|
end
|
@@ -104,7 +104,7 @@ describe Chef::Provider::Service::Solaris do
|
|
104
104
|
end
|
105
105
|
|
106
106
|
it "should call svcadm enable -s chef" do
|
107
|
-
@new_resource.stub
|
107
|
+
@new_resource.stub(:enable_command).and_return("#{@new_resource.enable_command}")
|
108
108
|
@provider.should_not_receive(:shell_out!).with("/usr/sbin/svcadm clear #{@current_resource.service_name}")
|
109
109
|
@provider.should_receive(:shell_out!).with("/usr/sbin/svcadm enable -s #{@current_resource.service_name}").and_return(@status)
|
110
110
|
@provider.enable_service.should be_true
|
@@ -112,7 +112,7 @@ describe Chef::Provider::Service::Solaris do
|
|
112
112
|
end
|
113
113
|
|
114
114
|
it "should call svcadm enable -s chef for start_service" do
|
115
|
-
@new_resource.stub
|
115
|
+
@new_resource.stub(:start_command).and_return("#{@new_resource.start_command}")
|
116
116
|
@provider.should_not_receive(:shell_out!).with("/usr/sbin/svcadm clear #{@current_resource.service_name}")
|
117
117
|
@provider.should_receive(:shell_out!).with("/usr/sbin/svcadm enable -s #{@current_resource.service_name}").and_return(@status)
|
118
118
|
@provider.start_service.should be_true
|
@@ -120,10 +120,10 @@ describe Chef::Provider::Service::Solaris do
|
|
120
120
|
end
|
121
121
|
|
122
122
|
it "should call svcadm clear chef for start_service when state maintenance" do
|
123
|
-
@status =
|
124
|
-
@provider.stub
|
123
|
+
@status = double("Status", :exitstatus => 0, :stdout => 'state maintenance')
|
124
|
+
@provider.stub(:shell_out!).and_return(@status)
|
125
125
|
@provider.load_current_resource
|
126
|
-
@new_resource.stub
|
126
|
+
@new_resource.stub(:enable_command).and_return("#{@new_resource.enable_command}")
|
127
127
|
@provider.should_receive(:shell_out!).with("/usr/sbin/svcadm clear #{@current_resource.service_name}").and_return(@status)
|
128
128
|
@provider.should_receive(:shell_out!).with("/usr/sbin/svcadm enable -s #{@current_resource.service_name}").and_return(@status)
|
129
129
|
@provider.enable_service.should be_true
|
@@ -50,20 +50,49 @@ describe Chef::Resource::RemoteFile do
|
|
50
50
|
@resource.source.should eql([ "http://opscode.com/" ])
|
51
51
|
end
|
52
52
|
|
53
|
+
it "should accept a delayed evalutator (string) for the remote file source" do
|
54
|
+
@resource.source Chef::DelayedEvaluator.new {"http://opscode.com/"}
|
55
|
+
@resource.source.should eql([ "http://opscode.com/" ])
|
56
|
+
end
|
57
|
+
|
53
58
|
it "should accept an array of URIs for the remote file source" do
|
54
59
|
@resource.source([ "http://opscode.com/", "http://puppetlabs.com/" ])
|
55
60
|
@resource.source.should eql([ "http://opscode.com/", "http://puppetlabs.com/" ])
|
56
61
|
end
|
57
62
|
|
63
|
+
it "should accept a delated evaluator (array) for the remote file source" do
|
64
|
+
@resource.source Chef::DelayedEvaluator.new { [ "http://opscode.com/", "http://puppetlabs.com/" ] }
|
65
|
+
@resource.source.should eql([ "http://opscode.com/", "http://puppetlabs.com/" ])
|
66
|
+
end
|
67
|
+
|
58
68
|
it "should accept an multiple URIs as arguments for the remote file source" do
|
59
69
|
@resource.source("http://opscode.com/", "http://puppetlabs.com/")
|
60
70
|
@resource.source.should eql([ "http://opscode.com/", "http://puppetlabs.com/" ])
|
61
71
|
end
|
62
72
|
|
73
|
+
it "should only accept a single argument if a delayed evalutor is used" do
|
74
|
+
lambda {
|
75
|
+
@resource.source("http://opscode.com/", Chef::DelayedEvaluator.new {"http://opscode.com/"})
|
76
|
+
}.should raise_error(Chef::Exceptions::InvalidRemoteFileURI)
|
77
|
+
end
|
78
|
+
|
79
|
+
it "should only accept a single array item if a delayed evalutor is used" do
|
80
|
+
lambda {
|
81
|
+
@resource.source(["http://opscode.com/", Chef::DelayedEvaluator.new {"http://opscode.com/"}])
|
82
|
+
}.should raise_error(Chef::Exceptions::InvalidRemoteFileURI)
|
83
|
+
end
|
84
|
+
|
63
85
|
it "does not accept a non-URI as the source" do
|
64
86
|
lambda { @resource.source("not-a-uri") }.should raise_error(Chef::Exceptions::InvalidRemoteFileURI)
|
65
87
|
end
|
66
88
|
|
89
|
+
it "does not accept a non-URI as the source when read from a delayed evaluator" do
|
90
|
+
lambda {
|
91
|
+
@resource.source(Chef::DelayedEvaluator.new {"not-a-uri"})
|
92
|
+
@resource.source
|
93
|
+
}.should raise_error(Chef::Exceptions::InvalidRemoteFileURI)
|
94
|
+
end
|
95
|
+
|
67
96
|
it "should raise an exception when source is an empty array" do
|
68
97
|
lambda { @resource.source([]) }.should raise_error(ArgumentError)
|
69
98
|
end
|
data/spec/unit/resource_spec.rb
CHANGED
@@ -612,7 +612,7 @@ describe Chef::Resource do
|
|
612
612
|
it "should print \"skipped due to action :nothing\" message for doc formatter when action is :nothing" do
|
613
613
|
fdoc = Chef::Formatters.new(:doc, STDOUT, STDERR)
|
614
614
|
@run_context.stub(:events).and_return(fdoc)
|
615
|
-
fdoc.should_receive(:puts).with(" (skipped due to action :nothing)")
|
615
|
+
fdoc.should_receive(:puts).with(" (skipped due to action :nothing)", anything())
|
616
616
|
@resource.should_skip?(:nothing)
|
617
617
|
end
|
618
618
|
|