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.
Files changed (193) hide show
  1. checksums.yaml +4 -4
  2. data/Rakefile +4 -2
  3. data/distro/common/html/_sources/index.txt +6 -0
  4. data/distro/common/html/_sources/knife_ssl_check.txt +41 -0
  5. data/distro/common/html/_sources/knife_ssl_fetch.txt +41 -0
  6. data/distro/common/html/_static/basic.css +2 -5
  7. data/distro/common/html/_static/doctools.js +5 -14
  8. data/distro/common/html/_static/jquery.js +2 -154
  9. data/distro/common/html/_static/pygments.css +2 -2
  10. data/distro/common/html/_static/searchtools.js +212 -150
  11. data/distro/common/html/_static/underscore.js +29 -21
  12. data/distro/common/html/_static/websupport.js +1 -1
  13. data/distro/common/html/ctl_chef_client.html +15 -18
  14. data/distro/common/html/ctl_chef_server.html +7 -7
  15. data/distro/common/html/ctl_chef_shell.html +6 -6
  16. data/distro/common/html/ctl_chef_solo.html +7 -8
  17. data/distro/common/html/index.html +34 -24
  18. data/distro/common/html/knife.html +23 -24
  19. data/distro/common/html/knife_bootstrap.html +13 -9
  20. data/distro/common/html/knife_client.html +10 -11
  21. data/distro/common/html/knife_common_options.html +6 -7
  22. data/distro/common/html/knife_configure.html +3 -4
  23. data/distro/common/html/knife_cookbook.html +18 -11
  24. data/distro/common/html/knife_cookbook_site.html +14 -14
  25. data/distro/common/html/knife_data_bag.html +24 -23
  26. data/distro/common/html/knife_delete.html +4 -5
  27. data/distro/common/html/knife_deps.html +4 -5
  28. data/distro/common/html/knife_diff.html +6 -7
  29. data/distro/common/html/knife_download.html +12 -13
  30. data/distro/common/html/knife_edit.html +4 -5
  31. data/distro/common/html/knife_environment.html +8 -9
  32. data/distro/common/html/knife_exec.html +9 -10
  33. data/distro/common/html/knife_index_rebuild.html +4 -5
  34. data/distro/common/html/knife_list.html +8 -9
  35. data/distro/common/html/knife_node.html +34 -33
  36. data/distro/common/html/knife_raw.html +2 -3
  37. data/distro/common/html/knife_recipe_list.html +3 -4
  38. data/distro/common/html/knife_role.html +30 -29
  39. data/distro/common/html/knife_search.html +7 -7
  40. data/distro/common/html/knife_show.html +4 -5
  41. data/distro/common/html/knife_ssh.html +2 -3
  42. data/distro/common/html/knife_ssl_check.html +148 -0
  43. data/distro/common/html/knife_ssl_fetch.html +152 -0
  44. data/distro/common/html/knife_status.html +4 -5
  45. data/distro/common/html/knife_tag.html +2 -3
  46. data/distro/common/html/knife_upload.html +5 -6
  47. data/distro/common/html/knife_user.html +9 -10
  48. data/distro/common/html/knife_using.html +12 -12
  49. data/distro/common/html/knife_xargs.html +11 -12
  50. data/distro/common/html/search.html +1 -2
  51. data/distro/common/html/searchindex.js +1 -1
  52. data/distro/common/man/man1/chef-shell.1 +19 -11
  53. data/distro/common/man/man1/knife-bootstrap.1 +35 -19
  54. data/distro/common/man/man1/knife-client.1 +111 -28
  55. data/distro/common/man/man1/knife-configure.1 +30 -14
  56. data/distro/common/man/man1/knife-cookbook-site.1 +105 -22
  57. data/distro/common/man/man1/knife-cookbook.1 +164 -23
  58. data/distro/common/man/man1/knife-data-bag.1 +157 -33
  59. data/distro/common/man/man1/knife-delete.1 +21 -17
  60. data/distro/common/man/man1/knife-deps.1 +60 -16
  61. data/distro/common/man/man1/knife-diff.1 +37 -17
  62. data/distro/common/man/man1/knife-download.1 +68 -24
  63. data/distro/common/man/man1/knife-edit.1 +19 -15
  64. data/distro/common/man/man1/knife-environment.1 +105 -17
  65. data/distro/common/man/man1/knife-exec.1 +78 -18
  66. data/distro/common/man/man1/knife-index-rebuild.1 +16 -8
  67. data/distro/common/man/man1/knife-list.1 +39 -23
  68. data/distro/common/man/man1/knife-node.1 +170 -22
  69. data/distro/common/man/man1/knife-raw.1 +33 -13
  70. data/distro/common/man/man1/knife-recipe-list.1 +17 -5
  71. data/distro/common/man/man1/knife-role.1 +86 -18
  72. data/distro/common/man/man1/knife-search.1 +80 -16
  73. data/distro/common/man/man1/knife-show.1 +30 -14
  74. data/distro/common/man/man1/knife-ssh.1 +54 -14
  75. data/distro/common/man/man1/knife-ssl-check.1 +207 -0
  76. data/distro/common/man/man1/knife-ssl-fetch.1 +207 -0
  77. data/distro/common/man/man1/knife-status.1 +48 -12
  78. data/distro/common/man/man1/knife-tag.1 +30 -10
  79. data/distro/common/man/man1/knife-upload.1 +72 -20
  80. data/distro/common/man/man1/knife-user.1 +79 -23
  81. data/distro/common/man/man1/knife-xargs.1 +61 -53
  82. data/distro/common/man/man8/chef-client.8 +87 -29
  83. data/distro/common/man/man8/chef-solo.8 +36 -15
  84. data/lib/chef/application.rb +19 -14
  85. data/lib/chef/application/client.rb +5 -0
  86. data/lib/chef/application/solo.rb +5 -0
  87. data/lib/chef/application/windows_service_manager.rb +3 -0
  88. data/lib/chef/chef_fs/chef_fs_data_store.rb +72 -24
  89. data/lib/chef/chef_fs/file_system/chef_repository_file_system_cookbook_dir.rb +20 -4
  90. data/lib/chef/chef_fs/file_system/chef_repository_file_system_cookbooks_dir.rb +20 -1
  91. data/lib/chef/chef_fs/file_system/file_system_entry.rb +10 -2
  92. data/lib/chef/client.rb +2 -3
  93. data/lib/chef/config.rb +34 -8
  94. data/lib/chef/cookbook/cookbook_version_loader.rb +45 -4
  95. data/lib/chef/cookbook_version.rb +38 -30
  96. data/lib/chef/dsl/recipe.rb +4 -1
  97. data/lib/chef/event_dispatch/base.rb +14 -0
  98. data/lib/chef/event_dispatch/events_output_stream.rb +29 -0
  99. data/lib/chef/exceptions.rb +8 -0
  100. data/lib/chef/formatters/base.rb +16 -45
  101. data/lib/chef/formatters/doc.rb +51 -26
  102. data/lib/chef/formatters/indentable_output_stream.rb +165 -0
  103. data/lib/chef/knife/node_environment_set.rb +54 -0
  104. data/lib/chef/knife/user_create.rb +1 -1
  105. data/lib/chef/monkey_patches/pathname.rb +32 -0
  106. data/lib/chef/node.rb +1 -1
  107. data/lib/chef/platform/provider_mapping.rb +345 -338
  108. data/lib/chef/policy_builder/expand_node_object.rb +1 -1
  109. data/lib/chef/policy_builder/policyfile.rb +1 -1
  110. data/lib/chef/provider.rb +1 -0
  111. data/lib/chef/provider/git.rb +1 -1
  112. data/lib/chef/provider/link.rb +2 -2
  113. data/lib/chef/provider/remote_file/content.rb +1 -1
  114. data/lib/chef/provider/remote_file/local_file.rb +8 -2
  115. data/lib/chef/provider/service/arch.rb +0 -1
  116. data/lib/chef/provider/service/debian.rb +0 -2
  117. data/lib/chef/provider/service/freebsd.rb +2 -1
  118. data/lib/chef/provider/service/gentoo.rb +1 -1
  119. data/lib/chef/provider/service/init.rb +0 -1
  120. data/lib/chef/provider/service/insserv.rb +0 -2
  121. data/lib/chef/provider/service/invokercd.rb +0 -2
  122. data/lib/chef/provider/service/macosx.rb +2 -1
  123. data/lib/chef/provider/service/redhat.rb +0 -1
  124. data/lib/chef/provider/service/simple.rb +1 -0
  125. data/lib/chef/provider/service/solaris.rb +1 -0
  126. data/lib/chef/provider/service/systemd.rb +1 -1
  127. data/lib/chef/provider/service/upstart.rb +1 -1
  128. data/lib/chef/provider/user.rb +9 -9
  129. data/lib/chef/provider/user/solaris.rb +2 -0
  130. data/lib/chef/resource.rb +1 -0
  131. data/lib/chef/resource/remote_file.rb +32 -6
  132. data/lib/chef/run_context.rb +22 -0
  133. data/lib/chef/run_lock.rb +43 -4
  134. data/lib/chef/version.rb +2 -2
  135. data/spec/functional/http/simple_spec.rb +84 -0
  136. data/spec/functional/resource/remote_file_spec.rb +107 -43
  137. data/spec/functional/rest_spec.rb +94 -0
  138. data/spec/functional/run_lock_spec.rb +1 -1
  139. data/spec/functional/win32/service_manager_spec.rb +6 -0
  140. data/spec/integration/knife/chef_fs_data_store_spec.rb +2 -0
  141. data/spec/integration/recipes/lwrp_inline_resources_spec.rb +76 -0
  142. data/spec/spec_helper.rb +2 -0
  143. data/spec/support/mock/platform.rb +7 -0
  144. data/spec/support/pedant/pedant_config.rb +121 -0
  145. data/spec/support/pedant/run_pedant.rb +63 -0
  146. data/spec/support/pedant/stickywicket.pem +27 -0
  147. data/spec/support/shared/functional/http.rb +242 -0
  148. data/spec/support/shared/unit/api_error_inspector.rb +2 -2
  149. data/spec/unit/api_client_spec.rb +2 -2
  150. data/spec/unit/application/client_spec.rb +6 -1
  151. data/spec/unit/application/knife_spec.rb +4 -0
  152. data/spec/unit/application/solo_spec.rb +2 -0
  153. data/spec/unit/application_spec.rb +7 -0
  154. data/spec/unit/client_spec.rb +16 -0
  155. data/spec/unit/config_spec.rb +3 -20
  156. data/spec/unit/cookbook_version_spec.rb +224 -122
  157. data/spec/unit/formatters/error_inspectors/compile_error_inspector_spec.rb +2 -2
  158. data/spec/unit/formatters/error_inspectors/cookbook_resolve_error_inspector_spec.rb +2 -2
  159. data/spec/unit/formatters/error_inspectors/cookbook_sync_error_inspector_spec.rb +2 -2
  160. data/spec/unit/formatters/error_inspectors/resource_failure_inspector_spec.rb +2 -2
  161. data/spec/unit/formatters/error_inspectors/run_list_expansion_error_inspector_spec.rb +2 -2
  162. data/spec/unit/handler_spec.rb +0 -1
  163. data/spec/unit/knife/client_bulk_delete_spec.rb +3 -0
  164. data/spec/unit/knife/cookbook_bulk_delete_spec.rb +2 -0
  165. data/spec/unit/knife/cookbook_metadata_spec.rb +2 -2
  166. data/spec/unit/knife/cookbook_site_install_spec.rb +3 -1
  167. data/spec/unit/knife/cookbook_upload_spec.rb +10 -10
  168. data/spec/unit/knife/node_environment_set_spec.rb +80 -0
  169. data/spec/unit/knife/user_create_spec.rb +6 -4
  170. data/spec/unit/knife/user_edit_spec.rb +5 -0
  171. data/spec/unit/knife_spec.rb +3 -0
  172. data/spec/unit/mixin/securable_spec.rb +18 -20
  173. data/spec/unit/node/attribute_spec.rb +15 -2
  174. data/spec/unit/node/immutable_collections_spec.rb +4 -4
  175. data/spec/unit/provider/cron_spec.rb +14 -14
  176. data/spec/unit/provider/git_spec.rb +4 -4
  177. data/spec/unit/provider/group_spec.rb +1 -1
  178. data/spec/unit/provider/ohai_spec.rb +2 -2
  179. data/spec/unit/provider/remote_file/content_spec.rb +58 -35
  180. data/spec/unit/provider/remote_file/local_file_spec.rb +23 -0
  181. data/spec/unit/provider/service/solaris_smf_service_spec.rb +13 -13
  182. data/spec/unit/resource/mount_spec.rb +0 -1
  183. data/spec/unit/resource/remote_file_spec.rb +29 -0
  184. data/spec/unit/resource_spec.rb +1 -1
  185. data/spec/unit/run_context_spec.rb +7 -0
  186. data/spec/unit/run_lock_spec.rb +98 -0
  187. data/spec/unit/version_constraint_spec.rb +1 -1
  188. metadata +166 -153
  189. data/distro/common/html/_static/chef.css +0 -507
  190. data/distro/common/html/_static/chef_logo.png +0 -0
  191. data/lib/chef/checksum/storage.rb +0 -18
  192. data/lib/chef/checksum/storage/filesystem.rb +0 -56
  193. data/spec/unit/checksum/storage/filesystem_spec.rb +0 -70
data/spec/spec_helper.rb CHANGED
@@ -82,6 +82,7 @@ require 'spec/support/platform_helpers'
82
82
  # Do not change the gsub.
83
83
  Dir["spec/support/**/*.rb"].
84
84
  reject { |f| f =~ %r{^spec/support/platforms} }.
85
+ reject { |f| f =~ %r{^spec/support/pedant} }.
85
86
  map { |f| f.gsub(%r{.rb$}, '') }.
86
87
  map { |f| f.gsub(%r[spec/], '')}.
87
88
  each { |f| require f }
@@ -98,6 +99,7 @@ RSpec.configure do |config|
98
99
 
99
100
  # Tests that randomly fail, but may have value.
100
101
  config.filter_run_excluding :volatile => true
102
+ config.filter_run_excluding :volatile_on_solaris => true if solaris?
101
103
 
102
104
  # Add jruby filters here
103
105
  config.filter_run_excluding :windows_only => true unless windows?
@@ -8,6 +8,13 @@
8
8
  def platform_mock(platform = :unix, &block)
9
9
  Chef::Platform.stub(:windows?).and_return(platform == :windows ? true : false)
10
10
  ENV['SYSTEMDRIVE'] = (platform == :windows ? 'C:' : nil)
11
+
12
+ if platform == :windows
13
+ Chef::Config.set_defaults_for_windows
14
+ else
15
+ Chef::Config.set_defaults_for_nix
16
+ end
17
+
11
18
  if block_given?
12
19
  mock_constants({"RUBY_PLATFORM" => (platform == :windows ? 'i386-mingw32' : 'x86_64-darwin11.2.0'),
13
20
  "File::PATH_SEPARATOR" => (platform == :windows ? ";" : ":"),
@@ -0,0 +1,121 @@
1
+ # Copyright: Copyright (c) 2012 Opscode, Inc.
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
+ # This annotated Pedant configuration file details the various
17
+ # configuration settings available to you. It is separate from the
18
+ # actual Pedant::Config class because not all settings have sane
19
+ # defaults, and not all settings are appropriate in all settings.
20
+
21
+ ################################################################################
22
+ # You MUST specify the address of the server the API requests will be
23
+ # sent to. Only specify protocol, hostname, and port.
24
+ chef_server 'http://127.0.0.1:8889'
25
+
26
+ # If you are doing development testing, you can specify the address of
27
+ # the Solr server. The presence of this parameter will enable tests
28
+ # to force commits to Solr, greatly decreasing the amout of time
29
+ # needed for testing the search endpoint. This is only an
30
+ # optimization for development! If you are testing a "live" Chef
31
+ # Server, or otherwise do not have access to the Solr server from your
32
+ # testing location, you should not specify a value for this parameter.
33
+ # The tests will still run, albeit slower, as they will now need to
34
+ # poll for a period to ensure they are querying committed results.
35
+ #search_server "http://localhost:8983"
36
+
37
+ # Related to the 'search_server' parameter, this specifies the maximum
38
+ # amout of time (in seconds) that search endpoint requests should be
39
+ # retried before giving up. If not explicitly set, it will default to
40
+ # 65 seconds; only set it if you know that your Solr commit interval
41
+ # differs significantly from this.
42
+ maximum_search_time 0
43
+
44
+ # OSC sends erchef a host header with a port, so this option needs
45
+ # # to be enabled for Pedant tests to work correctly
46
+ explicit_port_url true
47
+
48
+ # We're starting to break tests up into groups based on different
49
+ # criteria. The proper API tests (the results of which are viewable
50
+ # to OPC customers) should be the only ones run by Pedant embedded in
51
+ # OPC installs. There are other specs that help us keep track of API
52
+ # cruft that we want to come back and fix later; these shouldn't be
53
+ # viewable to customers, but we should be able to run them in
54
+ # development and CI environments. If this parameter is missing or
55
+ # explicitly `false` only the customer-friendly tests will be run.
56
+ #
57
+ # This is mainly here for documentation purposes, since the
58
+ # command-line `opscode-pedant` utility ultimately determines this
59
+ # value.
60
+ include_internal false
61
+
62
+ # Test users. The five users specified below are required; their
63
+ # names (:user, :non_org_user, etc.) are indicative of their role
64
+ # within the tests. All users must have a ':name' key. If they have
65
+ # a ':create_me' key, Pedant will create these users for you. If you
66
+ # are using pre-existing users, you must supply a ':key_file' key,
67
+ # which should be the fully-qualified path /on the machine Pedant is
68
+ # running on/ to a private key for that user.
69
+ key = 'spec/support/pedant/stickywicket.pem'
70
+ superuser_name 'admin'
71
+ superuser_key key
72
+ webui_key key
73
+
74
+ # Set the platform_class
75
+ platform_class Pedant::OpenSourcePlatform
76
+
77
+ requestors({
78
+ :clients => {
79
+ # The the admin user, for the purposes of getting things rolling
80
+ :admin => {
81
+ :name => "pedant_admin_client",
82
+ :create_me => true,
83
+ :create_knife => true,
84
+ :admin => true
85
+ },
86
+ :non_admin => {
87
+ :name => 'pedant_client',
88
+ :create_me => true,
89
+ :create_knife => true
90
+ },
91
+ :bad => {
92
+ :name => 'bad_client',
93
+ :bogus => true
94
+ }
95
+ },
96
+ :users => {
97
+ :admin => {
98
+ :name => "admin",
99
+ :key_file => key,
100
+ :create_me => false,
101
+ :create_knife => false,
102
+ :admin => true
103
+ },
104
+ :non_admin => {
105
+ :name => "pedant_non_admin_user",
106
+ :create_me => true,
107
+ :create_knife => true,
108
+ :admin => false
109
+ },
110
+ # A user for Knife tests. A knife.rb and key files will be set up
111
+ # for this user
112
+ :knife_user => {
113
+ :name => "knifey",
114
+ :create_me => true,
115
+ :create_knife => true
116
+ }
117
+ }
118
+ })
119
+
120
+ self[:tags] = [:validation, :authentication, :authorization]
121
+ verify_error_messages false
@@ -0,0 +1,63 @@
1
+ #!/usr/bin/env ruby
2
+ require 'bundler'
3
+ require 'bundler/setup'
4
+ require 'chef_zero/server'
5
+ require 'rspec/core'
6
+ require 'chef/chef_fs/chef_fs_data_store'
7
+ require 'chef/chef_fs/config'
8
+ require 'tmpdir'
9
+ require 'fileutils'
10
+ require 'chef/version'
11
+
12
+ def start_server(chef_repo_path)
13
+ Dir.mkdir(chef_repo_path) if !File.exists?(chef_repo_path)
14
+
15
+ # 11.6 and below had a bug where it couldn't create the repo children automatically
16
+ if Chef::VERSION.to_f < 11.8
17
+ %w(clients cookbooks data_bags environments nodes roles users).each do |child|
18
+ Dir.mkdir("#{chef_repo_path}/#{child}") if !File.exists?("#{chef_repo_path}/#{child}")
19
+ end
20
+ end
21
+
22
+ # Start the new server
23
+ Chef::Config.repo_mode = 'everything'
24
+ Chef::Config.chef_repo_path = chef_repo_path
25
+ Chef::Config.versioned_cookbooks = true
26
+ chef_fs = Chef::ChefFS::Config.new.local_fs
27
+ data_store = Chef::ChefFS::ChefFSDataStore.new(chef_fs)
28
+ server = ChefZero::Server.new(:port => 8889, :data_store => data_store)#, :log_level => :debug)
29
+ server.start_background
30
+ server
31
+ end
32
+
33
+ tmpdir = Dir.mktmpdir
34
+ begin
35
+ # Create chef repository
36
+ chef_repo_path = "#{tmpdir}/repo"
37
+
38
+ # Capture setup data into master_chef_repo_path
39
+ server = start_server(chef_repo_path)
40
+
41
+ require 'pedant'
42
+ require 'pedant/opensource'
43
+
44
+ #Pedant::Config.rerun = true
45
+
46
+ Pedant.config.suite = 'api'
47
+ Pedant.config[:config_file] = 'spec/support/pedant/pedant_config.rb'
48
+ Pedant.setup([
49
+ '--skip-knife',
50
+ '--skip-validation',
51
+ '--skip-authentication',
52
+ '--skip-authorization',
53
+ '--skip-omnibus'
54
+ ])
55
+
56
+ result = RSpec::Core::Runner.run(Pedant.config.rspec_args)
57
+
58
+ server.stop if server.running?
59
+ ensure
60
+ FileUtils.remove_entry_secure(tmpdir) if tmpdir
61
+ end
62
+
63
+ exit(result)
@@ -0,0 +1,27 @@
1
+ -----BEGIN RSA PRIVATE KEY-----
2
+ MIIEpQIBAAKCAQEApNCkX2k+lFGDWRVhX4uClaVQrumG9XXvk6X7M2izrIg7RzMP
3
+ Dk4thhZkpx5gr22By7PZQdMEjWC/Zo8MBjtoJ0GV0jw8npefbU1MGKs2dtpYgo0N
4
+ Fq8fX8MdFPu4h2W3g0dMEdhT8icc2H4EjhZmdeUhUn3RIEt2duCgp3YDYnUUZx3j
5
+ N7MHcTIdzD58ikr6zQrZzHOv+OOI86Xk9EpyEEQizOLoQxkICNrhqN7ElQDuvXaX
6
+ BSBrYDRKH2umBMMcXzvsR/SvkmqxoEESSpIlW8zeKAWQ+znNjDC0tmTg7jZmgSP7
7
+ siKrwo4t4ebjcmjpIoi/JKww/nGN3Uhz1ZOZuwIDAQABAoIBAQCaJQD2s0nyEeKU
8
+ uKhfYe155Cl3zbWJcQnmv4AXbr9MiAVY6+oS6Q8ur1bn7kNjDzoruENjiuZhC7E3
9
+ TGZklb8tp+tluyy+7vQOmBKpp8fClSfewekR5CultqhGbb8B8yIVR+NfdUHd4rLZ
10
+ z9KWyWB+txPZQQ8L80gSmrfmpzs3IuT7oPvmtBU1Wq9QapC4n/rUohHUpUV1du4G
11
+ 0wCIF4zQTg6cbYW2YXozwVQvw+P7P3RVEqZt+aZlbVcy0fNr6jNao0hi1KFC9OH2
12
+ VjjU+PioreoA/NU3aZPIUzmJpWtsu31yuOZxXmytAkYooCZgiEQNEHnJlNPv0RmC
13
+ 6BPMzVoBAoGBAM7yZoSNJpzdP/q1/4+H3zyy7o4I0VTW9u/GqUzhnbjm5poK30X9
14
+ YXh/7WOVV0OoVqdO6ljRKygP3Oggf41ZEbi1C6bbsO57pksBWgx9bD9V35XscZ0J
15
+ F1ERe//kMHwVQy74R8/cIuRwm75haLSBj5/fwGbLeeVDglJkCVqPjtuBAoGBAMvh
16
+ qsAGG5k9u6voTcXlFwS+B5YjULhK4NSxdJ2BnOxzYzxQ3IYQZMlb2xt8yZYx/ZZK
17
+ wjkr9rcAPEQIQZ2A6NUbGq6qCD7sSmg6UAi0CgiqTokQ/Wtag0UDvFMzwerdg/On
18
+ 37uxffpxpte8z1jYi/MxRaoTYueuc1UVnqofVIM7AoGBALZJzwPzUY/bVAADUJmd
19
+ lYZiFsAGBF42/E05MOgH1GaK/ZWy/fkouDLsfK67XaK7JZk6ajLSDLG9R1kxRym6
20
+ y2FoGFtiKPfo8xIenrNhx3gCrG/jVjB9UYyXWiKNXifukr9M8/SkdBfFGWsZYqGd
21
+ fmXVMiVaFoVcce8hLxwWWEABAoGBAKcyhKX/HEj6YFqlIoqkydDAylXs1jicZ27l
22
+ rF2yum8KXZpMMdzbutuKsdAD8Ql0K6NB4a+jByuiTMn5/11cJxUEqkgM9sArZQW+
23
+ tH2+r+/VQpyTS0/rpXVGj/2nl2K1kI2T4R36e/aTl6CanWweAf9JK/lC9rxKyxg+
24
+ p6SaFuObAoGACP6TKCkp2oymXlKgdUUgPrnsaz2VAw8jD5QHtx10U4wty0C8gxsk
25
+ MLe00h09iLPyFmvJpD+MgbxV/r6RrZeVdsKdU/5LG52YgiVSTaizyy+ciEfW7xoQ
26
+ CL5EtZd8Cn5OKinBEzzFpELqunlqepIKCIDOcLKz/cjR+3a+E6Zx5Wo=
27
+ -----END RSA PRIVATE KEY-----
@@ -0,0 +1,242 @@
1
+ #
2
+ # Author:: Lamont Granquist (<lamont@getchef.com>)
3
+ # Copyright:: Copyright (c) 2014 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
+ #
20
+ # shared code for Chef::REST and Chef::HTTP::Simple and other Chef::HTTP wrappers
21
+ #
22
+
23
+ module ChefHTTPShared
24
+ def nyan_uncompressed_filename
25
+ File.join(CHEF_SPEC_DATA, 'remote_file', 'nyan_cat.png')
26
+ end
27
+
28
+ def nyan_compressed_filename
29
+ File.join(CHEF_SPEC_DATA, 'remote_file', 'nyan_cat.png.gz')
30
+ end
31
+
32
+ def binread(file)
33
+ content = File.open(file, "rb") do |f|
34
+ f.read
35
+ end
36
+ content.force_encoding(Encoding::BINARY) if "".respond_to?(:force_encoding)
37
+ content
38
+ end
39
+
40
+ def start_tiny_server(server_opts={})
41
+ nyan_uncompressed_size = File::Stat.new(nyan_uncompressed_filename).size
42
+ nyan_compressed_size = File::Stat.new(nyan_compressed_filename).size
43
+
44
+ @server = TinyServer::Manager.new(server_opts)
45
+ @server.start
46
+ @api = TinyServer::API.instance
47
+ @api.clear
48
+
49
+ #
50
+ # trivial endpoints
51
+ #
52
+
53
+ # just a normal file
54
+ # (expected_content should be uncompressed)
55
+ @api.get("/nyan_cat.png", 200) {
56
+ File.open(nyan_uncompressed_filename, "rb") do |f|
57
+ f.read
58
+ end
59
+ }
60
+
61
+ # this ends in .gz, we do not uncompress it and drop it on the filesystem as a .gz file (the internet often lies)
62
+ # (expected_content should be compressed)
63
+ @api.get("/nyan_cat.png.gz", 200, nil, { 'Content-Type' => 'application/gzip', 'Content-Encoding' => 'gzip' } ) {
64
+ File.open(nyan_compressed_filename, "rb") do |f|
65
+ f.read
66
+ end
67
+ }
68
+
69
+ # this is an uncompressed file that was compressed by some mod_gzip-ish webserver thingy, so we will expand it
70
+ # (expected_content should be uncompressed)
71
+ @api.get("/nyan_cat_compressed.png", 200, nil, { 'Content-Type' => 'application/gzip', 'Content-Encoding' => 'gzip' } ) {
72
+ File.open(nyan_compressed_filename, "rb") do |f|
73
+ f.read
74
+ end
75
+ }
76
+
77
+ #
78
+ # endpoints that set Content-Length correctly
79
+ #
80
+
81
+ # (expected_content should be uncompressed)
82
+ @api.get("/nyan_cat_content_length.png", 200, nil,
83
+ {
84
+ 'Content-Length' => nyan_uncompressed_size.to_s,
85
+ }
86
+ ) {
87
+ File.open(nyan_uncompressed_filename, "rb") do |f|
88
+ f.read
89
+ end
90
+ }
91
+
92
+ # (expected_content should be uncompressed)
93
+ @api.get("/nyan_cat_content_length_compressed.png", 200, nil,
94
+ {
95
+ 'Content-Length' => nyan_compressed_size.to_s,
96
+ 'Content-Type' => 'application/gzip',
97
+ 'Content-Encoding' => 'gzip'
98
+ }
99
+ ) {
100
+ File.open(nyan_compressed_filename, "rb") do |f|
101
+ f.read
102
+ end
103
+ }
104
+
105
+ #
106
+ # endpoints that simulate truncated downloads (bad content-length header)
107
+ #
108
+
109
+ # (expected_content should be uncompressed)
110
+ @api.get("/nyan_cat_truncated.png", 200, nil,
111
+ {
112
+ 'Content-Length' => (nyan_uncompressed_size + 1).to_s,
113
+ }
114
+ ) {
115
+ File.open(nyan_uncompressed_filename, "rb") do |f|
116
+ f.read
117
+ end
118
+ }
119
+
120
+ # (expected_content should be uncompressed)
121
+ @api.get("/nyan_cat_truncated_compressed.png", 200, nil,
122
+ {
123
+ 'Content-Length' => (nyan_compressed_size + 1).to_s,
124
+ 'Content-Type' => 'application/gzip',
125
+ 'Content-Encoding' => 'gzip'
126
+ }
127
+ ) {
128
+ File.open(nyan_compressed_filename, "rb") do |f|
129
+ f.read
130
+ end
131
+ }
132
+
133
+ #
134
+ # in the presense of a transfer-encoding header, we must ignore the content-length (this bad content-length should work)
135
+ #
136
+
137
+ # (expected_content should be uncompressed)
138
+ @api.get("/nyan_cat_transfer_encoding.png", 200, nil,
139
+ {
140
+ 'Content-Length' => (nyan_uncompressed_size + 1).to_s,
141
+ 'Transfer-Encoding' => 'anything',
142
+ }
143
+ ) {
144
+ File.open(nyan_uncompressed_filename, "rb") do |f|
145
+ f.read
146
+ end
147
+ }
148
+
149
+ #
150
+ # 403 with a Content-Length
151
+ #
152
+ @api.get('/forbidden', 403, 'Forbidden',
153
+ {
154
+ 'Content-Length' => 'Forbidden'.bytesize.to_s
155
+ }
156
+ )
157
+
158
+ end
159
+
160
+ def stop_tiny_server
161
+ @server.stop
162
+ @server = @api = nil
163
+ end
164
+
165
+ end
166
+
167
+ shared_examples_for "downloading all the things" do
168
+
169
+ describe "when downloading a simple uncompressed file" do
170
+ let(:source) { 'http://localhost:9000/nyan_cat.png' }
171
+ let(:expected_content) { binread(nyan_uncompressed_filename) }
172
+
173
+ it_behaves_like "downloads requests correctly"
174
+ end
175
+
176
+ describe "when downloading a compressed file that should be left compressed" do
177
+ let(:source) { 'http://localhost:9000/nyan_cat.png.gz' }
178
+ let(:expected_content) { binread(nyan_compressed_filename) }
179
+
180
+ # its the callers responsibility to disable_gzip when downloading a .gz url
181
+ let(:http_client) { http_client_disable_gzip }
182
+
183
+ it_behaves_like "downloads requests correctly"
184
+ end
185
+
186
+ describe "when downloading a file that has been compressed by the webserver" do
187
+ let(:source) { 'http://localhost:9000/nyan_cat_compressed.png' }
188
+ let(:expected_content) { binread(nyan_uncompressed_filename) }
189
+
190
+ it_behaves_like "downloads requests correctly"
191
+ end
192
+
193
+ describe "when downloading an uncompressed file with a correct content_length" do
194
+ let(:source) { 'http://localhost:9000/nyan_cat_content_length.png' }
195
+ let(:expected_content) { binread(nyan_uncompressed_filename) }
196
+
197
+ it_behaves_like "downloads requests correctly"
198
+ end
199
+
200
+ describe "when downloading a file that has been compressed by the webserver with a correct content_length" do
201
+ let(:source) { 'http://localhost:9000/nyan_cat_content_length_compressed.png' }
202
+ let(:expected_content) { binread(nyan_uncompressed_filename) }
203
+
204
+ it_behaves_like "downloads requests correctly"
205
+ end
206
+
207
+ describe "when downloading an uncompressed file that is truncated" do
208
+ let(:source) { 'http://localhost:9000/nyan_cat_truncated.png' }
209
+ let(:expected_content) { binread(nyan_uncompressed_filename) }
210
+
211
+ it_behaves_like "validates content length and throws an exception"
212
+ end
213
+
214
+ describe "when downloading a file that has been compressed by the webserver that is truncated" do
215
+ let(:source) { 'http://localhost:9000/nyan_cat_truncated_compressed.png' }
216
+ let(:expected_content) { binread(nyan_uncompressed_filename) }
217
+
218
+ it_behaves_like "validates content length and throws an exception"
219
+ end
220
+
221
+ describe "when downloading a file that has transfer encoding set with a bad content length that should be ignored" do
222
+ let(:source) { 'http://localhost:9000/nyan_cat_transfer_encoding.png' }
223
+ let(:expected_content) { binread(nyan_uncompressed_filename) }
224
+
225
+ it_behaves_like "downloads requests correctly"
226
+ end
227
+
228
+ describe "when downloading an endpoint that 403s" do
229
+ let(:source) { 'http://localhost:9000/forbidden' }
230
+
231
+ it_behaves_like "an endpoint that 403s"
232
+ end
233
+
234
+ describe "when downloading an endpoint that 403s" do
235
+ let(:source) { 'http://localhost:9000/nyan_cat_content_length_compressed.png' }
236
+ let(:expected_content) { binread(nyan_uncompressed_filename) }
237
+ let(:source2) { 'http://localhost:9000/forbidden' }
238
+
239
+ it_behaves_like "a 403 after a successful request when reusing the request object"
240
+ end
241
+ end
242
+