chef 16.4.35 → 16.6.14

Sign up to get free protection for your applications and to get access to all the features.
Files changed (320) hide show
  1. checksums.yaml +4 -4
  2. data/Gemfile +1 -1
  3. data/Rakefile +2 -2
  4. data/bin/knife +1 -1
  5. data/chef.gemspec +2 -1
  6. data/lib/chef/api_client/registration.rb +6 -6
  7. data/lib/chef/application.rb +19 -22
  8. data/lib/chef/application/apply.rb +12 -7
  9. data/lib/chef/application/base.rb +26 -25
  10. data/lib/chef/application/client.rb +16 -8
  11. data/lib/chef/application/exit_code.rb +13 -4
  12. data/lib/chef/application/knife.rb +22 -11
  13. data/lib/chef/application/solo.rb +2 -1
  14. data/lib/chef/application/windows_service.rb +14 -14
  15. data/lib/chef/application/windows_service_manager.rb +6 -6
  16. data/lib/chef/chef_fs/chef_fs_data_store.rb +1 -1
  17. data/lib/chef/chef_fs/file_system/repository/chef_repository_file_system_cookbook_entry.rb +1 -1
  18. data/lib/chef/chef_fs/knife.rb +2 -2
  19. data/lib/chef/chef_fs/parallelizer.rb +0 -1
  20. data/lib/chef/client.rb +12 -42
  21. data/lib/chef/cookbook/cookbook_version_loader.rb +1 -1
  22. data/lib/chef/cookbook/gem_installer.rb +1 -1
  23. data/lib/chef/cookbook/synchronizer.rb +2 -2
  24. data/lib/chef/cookbook_site_streaming_uploader.rb +13 -11
  25. data/lib/chef/cookbook_uploader.rb +1 -1
  26. data/lib/chef/data_collector.rb +7 -6
  27. data/lib/chef/data_collector/config_validation.rb +22 -13
  28. data/lib/chef/data_collector/run_end_message.rb +2 -2
  29. data/lib/chef/data_collector/run_start_message.rb +1 -1
  30. data/lib/chef/deprecated.rb +1 -1
  31. data/lib/chef/deprecation/warnings.rb +2 -2
  32. data/lib/chef/digester.rb +2 -2
  33. data/lib/chef/dsl/chef_vault.rb +1 -1
  34. data/lib/chef/dsl/data_query.rb +2 -2
  35. data/lib/chef/dsl/platform_introspection.rb +1 -1
  36. data/lib/chef/encrypted_data_bag_item.rb +3 -4
  37. data/lib/chef/encrypted_data_bag_item/decryptor.rb +3 -3
  38. data/lib/chef/encrypted_data_bag_item/encryptor.rb +3 -3
  39. data/lib/chef/environment.rb +2 -2
  40. data/lib/chef/event_loggers/windows_eventlog.rb +2 -2
  41. data/lib/chef/exceptions.rb +4 -4
  42. data/lib/chef/file_access_control/windows.rb +5 -1
  43. data/lib/chef/file_content_management/tempfile.rb +1 -1
  44. data/lib/chef/formatters/doc.rb +7 -6
  45. data/lib/chef/formatters/error_inspectors/api_error_formatting.rb +6 -5
  46. data/lib/chef/formatters/error_inspectors/node_load_error_inspector.rb +3 -3
  47. data/lib/chef/formatters/error_inspectors/registration_error_inspector.rb +9 -9
  48. data/lib/chef/formatters/error_inspectors/resource_failure_inspector.rb +2 -2
  49. data/lib/chef/formatters/error_inspectors/run_list_expansion_error_inspector.rb +3 -3
  50. data/lib/chef/formatters/indentable_output_stream.rb +2 -2
  51. data/lib/chef/formatters/minimal.rb +5 -4
  52. data/lib/chef/http.rb +6 -4
  53. data/lib/chef/http/auth_credentials.rb +5 -1
  54. data/lib/chef/http/authenticator.rb +1 -1
  55. data/lib/chef/http/basic_client.rb +4 -2
  56. data/lib/chef/http/decompressor.rb +1 -1
  57. data/lib/chef/http/http_request.rb +7 -5
  58. data/lib/chef/http/socketless_chef_zero_client.rb +5 -2
  59. data/lib/chef/http/ssl_policies.rb +1 -1
  60. data/lib/chef/json_compat.rb +1 -1
  61. data/lib/chef/knife.rb +4 -4
  62. data/lib/chef/knife/bootstrap.rb +16 -14
  63. data/lib/chef/knife/bootstrap/chef_vault_handler.rb +1 -1
  64. data/lib/chef/knife/bootstrap/templates/chef-full.erb +3 -3
  65. data/lib/chef/knife/bootstrap/templates/windows-chef-client-msi.erb +7 -7
  66. data/lib/chef/knife/client_create.rb +3 -3
  67. data/lib/chef/knife/config_get.rb +8 -97
  68. data/lib/chef/knife/config_get_profile.rb +9 -9
  69. data/lib/chef/knife/config_list.rb +139 -0
  70. data/lib/chef/knife/config_list_profiles.rb +8 -98
  71. data/lib/chef/knife/config_show.rb +127 -0
  72. data/lib/chef/knife/config_use.rb +61 -0
  73. data/lib/chef/knife/config_use_profile.rb +9 -24
  74. data/lib/chef/knife/configure.rb +4 -2
  75. data/lib/chef/knife/core/bootstrap_context.rb +2 -2
  76. data/lib/chef/knife/core/object_loader.rb +1 -1
  77. data/lib/chef/knife/core/ui.rb +1 -1
  78. data/lib/chef/knife/core/windows_bootstrap_context.rb +11 -11
  79. data/lib/chef/knife/exec.rb +2 -2
  80. data/lib/chef/knife/node_policy_set.rb +2 -2
  81. data/lib/chef/knife/node_run_list_add.rb +1 -1
  82. data/lib/chef/knife/node_run_list_remove.rb +1 -1
  83. data/lib/chef/knife/node_run_list_set.rb +1 -1
  84. data/lib/chef/knife/node_show.rb +2 -2
  85. data/lib/chef/knife/role_env_run_list_add.rb +1 -1
  86. data/lib/chef/knife/role_env_run_list_set.rb +1 -1
  87. data/lib/chef/knife/role_run_list_add.rb +1 -1
  88. data/lib/chef/knife/role_run_list_set.rb +1 -1
  89. data/lib/chef/knife/search.rb +0 -1
  90. data/lib/chef/knife/serve.rb +3 -3
  91. data/lib/chef/knife/ssh.rb +18 -3
  92. data/lib/chef/knife/ssl_check.rb +3 -3
  93. data/lib/chef/knife/status.rb +2 -2
  94. data/lib/chef/knife/tag_create.rb +1 -1
  95. data/lib/chef/knife/tag_delete.rb +1 -1
  96. data/lib/chef/knife/user_create.rb +2 -2
  97. data/lib/chef/knife/yaml_convert.rb +1 -1
  98. data/lib/chef/local_mode.rb +2 -2
  99. data/lib/chef/log/syslog.rb +2 -2
  100. data/lib/chef/log/winevt.rb +2 -2
  101. data/lib/chef/mixin/deep_merge.rb +0 -12
  102. data/lib/chef/mixin/openssl_helper.rb +1 -4
  103. data/lib/chef/mixin/powershell_exec.rb +22 -10
  104. data/lib/chef/mixin/powershell_out.rb +12 -5
  105. data/lib/chef/mixin/template.rb +3 -3
  106. data/lib/chef/mixin/uris.rb +4 -2
  107. data/lib/chef/mixin/versioned_api.rb +1 -2
  108. data/lib/chef/monkey_patches/net_http.rb +4 -4
  109. data/lib/chef/node/mixin/immutablize_hash.rb +2 -0
  110. data/lib/chef/node_map.rb +4 -4
  111. data/lib/chef/policy_builder/dynamic.rb +2 -0
  112. data/lib/chef/policy_builder/policyfile.rb +2 -2
  113. data/lib/chef/powershell.rb +3 -2
  114. data/lib/chef/provider.rb +1 -5
  115. data/lib/chef/provider/file.rb +2 -2
  116. data/lib/chef/provider/ifconfig.rb +2 -2
  117. data/lib/chef/provider/ifconfig/debian.rb +33 -15
  118. data/lib/chef/provider/ifconfig/redhat.rb +51 -17
  119. data/lib/chef/provider/launchd.rb +2 -2
  120. data/lib/chef/provider/link.rb +0 -9
  121. data/lib/chef/provider/mount/linux.rb +63 -0
  122. data/lib/chef/provider/package/dpkg.rb +3 -12
  123. data/lib/chef/provider/package/homebrew.rb +1 -1
  124. data/lib/chef/provider/package/rubygems.rb +21 -18
  125. data/lib/chef/provider/package/snap.rb +0 -1
  126. data/lib/chef/provider/package/windows.rb +2 -2
  127. data/lib/chef/provider/package/windows/registry_uninstall_entry.rb +3 -1
  128. data/lib/chef/provider/package/zypper.rb +1 -1
  129. data/lib/chef/provider/powershell_script.rb +12 -1
  130. data/lib/chef/provider/remote_file/content.rb +3 -0
  131. data/lib/chef/provider/remote_file/ftp.rb +6 -4
  132. data/lib/chef/provider/remote_file/sftp.rb +6 -4
  133. data/lib/chef/provider/route.rb +2 -6
  134. data/lib/chef/provider/service/macosx.rb +2 -2
  135. data/lib/chef/provider/service/redhat.rb +1 -1
  136. data/lib/chef/provider/template_finder.rb +2 -10
  137. data/lib/chef/provider/user/dscl.rb +5 -5
  138. data/lib/chef/provider/user/mac.rb +3 -3
  139. data/lib/chef/provider/windows_task.rb +1 -2
  140. data/lib/chef/provider/zypper_repository.rb +2 -2
  141. data/lib/chef/provider_resolver.rb +1 -1
  142. data/lib/chef/providers.rb +1 -0
  143. data/lib/chef/pwsh.rb +64 -0
  144. data/lib/chef/recipe.rb +2 -2
  145. data/lib/chef/resource.rb +2 -2
  146. data/lib/chef/resource/apt_repository.rb +6 -5
  147. data/lib/chef/resource/bff_package.rb +22 -0
  148. data/lib/chef/resource/breakpoint.rb +57 -2
  149. data/lib/chef/resource/build_essential.rb +1 -1
  150. data/lib/chef/resource/cab_package.rb +29 -0
  151. data/lib/chef/resource/chef_client_config.rb +313 -0
  152. data/lib/chef/resource/chef_client_cron.rb +35 -28
  153. data/lib/chef/resource/chef_client_launchd.rb +194 -0
  154. data/lib/chef/resource/chef_client_scheduled_task.rb +24 -21
  155. data/lib/chef/resource/chef_client_systemd_timer.rb +27 -20
  156. data/lib/chef/resource/chef_client_trusted_certificate.rb +101 -0
  157. data/lib/chef/resource/chef_gem.rb +10 -10
  158. data/lib/chef/resource/chef_handler.rb +149 -4
  159. data/lib/chef/resource/chef_sleep.rb +3 -3
  160. data/lib/chef/resource/chef_vault_secret.rb +1 -1
  161. data/lib/chef/resource/cookbook_file.rb +2 -2
  162. data/lib/chef/resource/cron/_cron_shared.rb +1 -0
  163. data/lib/chef/resource/cron/cron_d.rb +2 -3
  164. data/lib/chef/resource/dnf_package.rb +2 -2
  165. data/lib/chef/resource/dsc_resource.rb +0 -1
  166. data/lib/chef/resource/dsc_script.rb +2 -2
  167. data/lib/chef/resource/execute.rb +6 -6
  168. data/lib/chef/resource/file.rb +4 -4
  169. data/lib/chef/resource/gem_package.rb +5 -5
  170. data/lib/chef/resource/homebrew_package.rb +3 -3
  171. data/lib/chef/resource/homebrew_update.rb +5 -5
  172. data/lib/chef/resource/hostname.rb +2 -2
  173. data/lib/chef/resource/kernel_module.rb +1 -1
  174. data/lib/chef/resource/launchd.rb +17 -16
  175. data/lib/chef/resource/locale.rb +2 -2
  176. data/lib/chef/resource/macos_userdefaults.rb +3 -3
  177. data/lib/chef/resource/mount.rb +1 -1
  178. data/lib/chef/resource/notify_group.rb +0 -1
  179. data/lib/chef/resource/ohai.rb +46 -3
  180. data/lib/chef/resource/ohai_hint.rb +33 -0
  181. data/lib/chef/resource/openssl_dhparam.rb +27 -5
  182. data/lib/chef/resource/openssl_ec_private_key.rb +6 -3
  183. data/lib/chef/resource/openssl_ec_public_key.rb +2 -2
  184. data/lib/chef/resource/openssl_rsa_private_key.rb +6 -3
  185. data/lib/chef/resource/openssl_x509_certificate.rb +14 -14
  186. data/lib/chef/resource/openssl_x509_crl.rb +19 -10
  187. data/lib/chef/resource/openssl_x509_request.rb +14 -16
  188. data/lib/chef/resource/osx_profile.rb +77 -13
  189. data/lib/chef/resource/plist.rb +1 -1
  190. data/lib/chef/resource/powershell_package_source.rb +5 -5
  191. data/lib/chef/resource/powershell_script.rb +7 -1
  192. data/lib/chef/resource/reboot.rb +2 -2
  193. data/lib/chef/resource/remote_file.rb +3 -3
  194. data/lib/chef/resource/rhsm_register.rb +22 -10
  195. data/lib/chef/resource/ruby_block.rb +2 -2
  196. data/lib/chef/resource/scm/subversion.rb +2 -2
  197. data/lib/chef/resource/service.rb +3 -3
  198. data/lib/chef/resource/ssh_known_hosts_entry.rb +2 -2
  199. data/lib/chef/resource/support/client.erb +65 -0
  200. data/lib/chef/resource/support/cron.d.erb +1 -1
  201. data/lib/chef/resource/support/cron_access.erb +1 -1
  202. data/lib/chef/resource/support/sudoer.erb +1 -1
  203. data/lib/chef/resource/support/ulimit.erb +1 -1
  204. data/lib/chef/resource/sysctl.rb +1 -5
  205. data/lib/chef/resource/systemd_unit.rb +2 -2
  206. data/lib/chef/resource/template.rb +2 -2
  207. data/lib/chef/resource/timezone.rb +112 -73
  208. data/lib/chef/resource/windows_ad_join.rb +10 -3
  209. data/lib/chef/resource/windows_audit_policy.rb +26 -24
  210. data/lib/chef/resource/windows_certificate.rb +6 -4
  211. data/lib/chef/resource/windows_firewall_profile.rb +22 -20
  212. data/lib/chef/resource/windows_package.rb +28 -5
  213. data/lib/chef/resource/windows_printer.rb +5 -3
  214. data/lib/chef/resource/windows_printer_port.rb +6 -4
  215. data/lib/chef/resource/windows_user_privilege.rb +53 -54
  216. data/lib/chef/resource/windows_workgroup.rb +3 -3
  217. data/lib/chef/resource/yum_package.rb +2 -2
  218. data/lib/chef/resource_reporter.rb +0 -2
  219. data/lib/chef/resources.rb +4 -1
  220. data/lib/chef/run_context.rb +2 -2
  221. data/lib/chef/run_context/cookbook_compiler.rb +1 -1
  222. data/lib/chef/run_lock.rb +2 -2
  223. data/lib/chef/search/query.rb +6 -5
  224. data/lib/chef/shell.rb +31 -26
  225. data/lib/chef/shell/ext.rb +11 -11
  226. data/lib/chef/shell/shell_session.rb +2 -2
  227. data/lib/chef/train_transport.rb +5 -104
  228. data/lib/chef/util/backup.rb +1 -1
  229. data/lib/chef/util/diff.rb +3 -3
  230. data/lib/chef/util/powershell/cmdlet.rb +3 -1
  231. data/lib/chef/util/powershell/ps_credential.rb +18 -14
  232. data/lib/chef/util/threaded_job_queue.rb +0 -2
  233. data/lib/chef/version.rb +1 -1
  234. data/lib/chef/win32/crypto.rb +1 -1
  235. data/lib/chef/win32/file.rb +1 -1
  236. data/lib/chef/win32/registry.rb +1 -2
  237. data/lib/chef/win32/unicode.rb +1 -1
  238. data/spec/data/shef-config.rb +1 -1
  239. data/spec/functional/event_loggers/windows_eventlog_spec.rb +6 -5
  240. data/spec/functional/mixin/powershell_out_spec.rb +9 -1
  241. data/spec/functional/resource/aix_service_spec.rb +2 -2
  242. data/spec/functional/resource/aixinit_service_spec.rb +1 -1
  243. data/spec/functional/resource/insserv_spec.rb +1 -1
  244. data/spec/functional/resource/powershell_script_spec.rb +57 -14
  245. data/spec/functional/resource/user/dscl_spec.rb +1 -1
  246. data/spec/functional/resource/user/mac_user_spec.rb +1 -1
  247. data/spec/functional/resource/windows_task_spec.rb +13 -13
  248. data/spec/functional/version_spec.rb +3 -3
  249. data/spec/integration/client/client_spec.rb +4 -4
  250. data/spec/integration/client/exit_code_spec.rb +3 -2
  251. data/spec/integration/client/ipv6_spec.rb +1 -1
  252. data/spec/integration/knife/{config_list_profiles_spec.rb → config_list_spec.rb} +30 -29
  253. data/spec/integration/knife/{config_get_spec.rb → config_show_spec.rb} +3 -3
  254. data/spec/integration/knife/{config_use_profile_spec.rb → config_use_spec.rb} +53 -10
  255. data/spec/integration/knife/cookbook_api_ipv6_spec.rb +1 -1
  256. data/spec/integration/ohai/ohai_spec.rb +61 -0
  257. data/spec/integration/recipes/remote_directory.rb +1 -1
  258. data/spec/integration/solo/solo_spec.rb +5 -5
  259. data/spec/spec_helper.rb +8 -6
  260. data/spec/stress/win32/file_spec.rb +1 -1
  261. data/spec/support/chef_helpers.rb +2 -2
  262. data/spec/support/matchers/leak.rb +2 -2
  263. data/spec/support/platform_helpers.rb +22 -35
  264. data/spec/support/shared/functional/securable_resource.rb +108 -27
  265. data/spec/support/shared/functional/win32_service.rb +1 -1
  266. data/spec/support/shared/unit/application_dot_d.rb +5 -3
  267. data/spec/tiny_server.rb +0 -1
  268. data/spec/unit/application/client_spec.rb +2 -2
  269. data/spec/unit/application/exit_code_spec.rb +10 -0
  270. data/spec/unit/application_spec.rb +4 -6
  271. data/spec/unit/chef_fs/config_spec.rb +1 -1
  272. data/spec/unit/chef_fs/data_handler/data_bag_item_data_handler.rb +1 -1
  273. data/spec/unit/chef_fs/parallelizer_spec.rb +5 -1
  274. data/spec/unit/chef_fs/path_util_spec.rb +1 -1
  275. data/spec/unit/cookbook/synchronizer_spec.rb +2 -2
  276. data/spec/unit/cookbook_spec.rb +2 -2
  277. data/spec/unit/data_collector/config_validation_spec.rb +208 -0
  278. data/spec/unit/data_collector_spec.rb +6 -117
  279. data/spec/unit/dsl/declare_resource_spec.rb +1 -1
  280. data/spec/unit/file_access_control_spec.rb +1 -1
  281. data/spec/unit/knife/bootstrap_spec.rb +6 -6
  282. data/spec/unit/knife/core/ui_spec.rb +1 -0
  283. data/spec/unit/knife/ssh_spec.rb +2 -2
  284. data/spec/unit/lwrp_spec.rb +3 -3
  285. data/spec/unit/mixin/deep_merge_spec.rb +15 -0
  286. data/spec/unit/mixin/openssl_helper_spec.rb +1 -1
  287. data/spec/unit/mixin/powershell_exec_spec.rb +39 -2
  288. data/spec/unit/mixin/powershell_out_spec.rb +14 -0
  289. data/spec/unit/mixin/securable_spec.rb +2 -2
  290. data/spec/unit/node/immutable_collections_spec.rb +2 -2
  291. data/spec/unit/provider/mount/linux_spec.rb +97 -0
  292. data/spec/unit/provider/package/chocolatey_spec.rb +1 -1
  293. data/spec/unit/provider/package/powershell_spec.rb +1 -1
  294. data/spec/unit/provider/package/rubygems_spec.rb +4 -1
  295. data/spec/unit/provider/powershell_script_spec.rb +11 -0
  296. data/spec/unit/provider/route_spec.rb +0 -2
  297. data/spec/unit/recipe_spec.rb +1 -1
  298. data/spec/unit/resource/chef_client_config_spec.rb +137 -0
  299. data/spec/unit/resource/chef_client_cron_spec.rb +35 -14
  300. data/spec/unit/resource/chef_client_launchd_spec.rb +127 -0
  301. data/spec/unit/resource/chef_client_systemd_timer_spec.rb +36 -1
  302. data/spec/unit/resource/chef_client_trusted_certificate_spec.rb +54 -0
  303. data/spec/unit/resource/launchd_spec.rb +8 -0
  304. data/spec/unit/resource/osx_profile_spec.rb +67 -1
  305. data/spec/unit/resource/powershell_script_spec.rb +2 -2
  306. data/spec/unit/resource/rhsm_register_spec.rb +56 -18
  307. data/spec/unit/resource/timezone_spec.rb +63 -0
  308. data/spec/unit/resource/windows_uac_spec.rb +1 -1
  309. data/spec/unit/resource/windows_user_privilege_spec.rb +55 -0
  310. data/spec/unit/run_lock_spec.rb +5 -1
  311. data/spec/unit/runner_spec.rb +1 -2
  312. data/spec/unit/shell/shell_ext_spec.rb +46 -3
  313. data/spec/unit/shell/shell_session_spec.rb +35 -64
  314. data/spec/unit/shell_spec.rb +16 -19
  315. data/spec/unit/train_transport_spec.rb +14 -13
  316. data/spec/unit/util/selinux_spec.rb +2 -0
  317. data/tasks/rspec.rb +0 -2
  318. metadata +46 -18
  319. data/lib/chef/dist.rb +0 -68
  320. data/spec/integration/knife/config_get_profile_spec.rb +0 -114
@@ -19,13 +19,13 @@ require "spec_helper"
19
19
  require "chef/mixin/shell_out"
20
20
  require "chef/version"
21
21
  require "ohai/version"
22
- require "chef/dist"
22
+ require "chef-utils/dist"
23
23
 
24
24
  describe "Chef Versions", :executables do
25
25
  include Chef::Mixin::ShellOut
26
- let(:chef_dir) { File.join(File.dirname(__FILE__), "..", "..") }
26
+ let(:chef_dir) { File.join(__dir__, "..", "..") }
27
27
 
28
- binaries = [ Chef::Dist::CLIENT, "chef-shell", "chef-apply", "knife", Chef::Dist::SOLOEXEC ]
28
+ binaries = [ ChefUtils::Dist::Infra::CLIENT, "chef-shell", "chef-apply", "knife", ChefUtils::Dist::Solo::EXEC ]
29
29
 
30
30
  binaries.each do |binary|
31
31
  it "#{binary} version should be sane" do
@@ -3,7 +3,7 @@ require "support/shared/integration/integration_helper"
3
3
  require "chef/mixin/shell_out"
4
4
  require "tiny_server"
5
5
  require "tmpdir"
6
- require "chef/dist"
6
+ require "chef-utils/dist"
7
7
 
8
8
  describe "chef-client" do
9
9
 
@@ -34,7 +34,7 @@ describe "chef-client" do
34
34
  include IntegrationSupport
35
35
  include Chef::Mixin::ShellOut
36
36
 
37
- let(:chef_dir) { File.join(File.dirname(__FILE__), "..", "..", "..", "bin") }
37
+ let(:chef_dir) { File.join(__dir__, "..", "..", "..", "bin") }
38
38
 
39
39
  # Invoke `chef-client` as `ruby PATH/TO/chef-client`. This ensures the
40
40
  # following constraints are satisfied:
@@ -45,8 +45,8 @@ describe "chef-client" do
45
45
  # machine that has omnibus chef installed. In that case we need to ensure
46
46
  # we're running `chef-client` from the source tree and not the external one.
47
47
  # cf. CHEF-4914
48
- let(:chef_client) { "bundle exec #{Chef::Dist::CLIENT} --minimal-ohai" }
49
- let(:chef_solo) { "bundle exec #{Chef::Dist::SOLOEXEC} --legacy-mode --minimal-ohai" }
48
+ let(:chef_client) { "bundle exec #{ChefUtils::Dist::Infra::CLIENT} --minimal-ohai" }
49
+ let(:chef_solo) { "bundle exec #{ChefUtils::Dist::Solo::EXEC} --legacy-mode --minimal-ohai" }
50
50
 
51
51
  when_the_repository "has a cookbook with a no-op recipe" do
52
52
  before { file "cookbooks/x/recipes/default.rb", "" }
@@ -5,13 +5,14 @@ require "chef/mixin/shell_out"
5
5
  require "tiny_server"
6
6
  require "tmpdir"
7
7
  require "chef/platform"
8
+ require "chef-utils/dist"
8
9
 
9
10
  describe "chef-client" do
10
11
 
11
12
  include IntegrationSupport
12
13
  include Chef::Mixin::ShellOut
13
14
 
14
- let(:chef_dir) { File.join(File.dirname(__FILE__), "..", "..", "..", "bin") }
15
+ let(:chef_dir) { File.join(__dir__, "..", "..", "..", "bin") }
15
16
 
16
17
  # Invoke `chef-client` as `ruby PATH/TO/chef-client`. This ensures the
17
18
  # following constraints are satisfied:
@@ -22,7 +23,7 @@ describe "chef-client" do
22
23
  # machine that has omnibus chef installed. In that case we need to ensure
23
24
  # we're running `chef-client` from the source tree and not the external one.
24
25
  # cf. CHEF-4914
25
- let(:chef_client) { "bundle exec #{Chef::Dist::CLIENT} --no-fork --minimal-ohai" }
26
+ let(:chef_client) { "bundle exec #{ChefUtils::Dist::Infra::CLIENT} --no-fork --minimal-ohai" }
26
27
 
27
28
  let(:critical_env_vars) { %w{PATH RUBYOPT BUNDLE_GEMFILE GEM_PATH}.map { |o| "#{o}=#{ENV[o]}" } .join(" ") }
28
29
 
@@ -74,7 +74,7 @@ describe "chef-client" do
74
74
  basic_config_file
75
75
  end
76
76
 
77
- let(:chef_dir) { File.join(File.dirname(__FILE__), "..", "..", "..", "bin") }
77
+ let(:chef_dir) { File.join(__dir__, "..", "..", "..", "bin") }
78
78
 
79
79
  let(:chef_client_cmd) { %Q{bundle exec chef-client --minimal-ohai -c "#{path_to("config/client.rb")}" -lwarn} }
80
80
 
@@ -17,7 +17,7 @@ require "spec_helper"
17
17
  require "support/shared/integration/integration_helper"
18
18
  require "support/shared/context/config"
19
19
 
20
- describe "knife config list-profiles", :workstation do
20
+ describe "knife config list", :workstation do
21
21
  include IntegrationSupport
22
22
  include KnifeSupport
23
23
 
@@ -25,14 +25,14 @@ describe "knife config list-profiles", :workstation do
25
25
 
26
26
  when_the_repository("has a custom env") do
27
27
  let(:cmd_args) { [] }
28
- let(:knife_list_profiles) do
29
- knife("config", "list-profiles", *cmd_args, instance_filter: lambda { |instance|
28
+ let(:knife_list) do
29
+ knife("config", "list", *cmd_args, instance_filter: lambda { |instance|
30
30
  # Fake the failsafe check because this command doesn't actually process knife.rb.
31
31
  $__KNIFE_INTEGRATION_FAILSAFE_CHECK << " ole"
32
32
  allow(File).to receive(:file?).and_call_original
33
33
  })
34
34
  end
35
- subject { knife_list_profiles.stdout }
35
+ subject { knife_list.stdout }
36
36
 
37
37
  around do |ex|
38
38
  # Store and reset the value of some env vars.
@@ -40,7 +40,7 @@ describe "knife config list-profiles", :workstation do
40
40
  old_wd = Dir.pwd
41
41
  # Clear these out because they are cached permanently.
42
42
  ChefConfig::PathHelper.class_exec { remove_class_variable(:@@home_dir) }
43
- Chef::Knife::ConfigListProfiles.reset_config_loader!
43
+ Chef::Knife::ConfigList.reset_config_loader!
44
44
  begin
45
45
  ex.run
46
46
  ensure
@@ -57,6 +57,7 @@ describe "knife config list-profiles", :workstation do
57
57
  Dir.chdir(path_to("repo"))
58
58
  ENV[ChefUtils.windows? ? "CD" : "PWD"] = Dir.pwd
59
59
  ENV["HOME"] = path_to(".")
60
+ allow(TTY::Screen).to receive(:width).and_return(200)
60
61
  end
61
62
 
62
63
  # NOTE: The funky formatting with # at the end of the line of some of the
@@ -64,13 +65,13 @@ describe "knife config list-profiles", :workstation do
64
65
  # substantial trailing whitespace in most cases which many editors "helpfully" remove.
65
66
 
66
67
  context "with no credentials file" do
67
- subject { knife_list_profiles.stderr }
68
+ subject { knife_list.stderr }
68
69
  it { is_expected.to eq "FATAL: No profiles found, #{path_to(".chef/credentials")} does not exist or is empty\n" }
69
70
  end
70
71
 
71
72
  context "with an empty credentials file" do
72
73
  before { file(".chef/credentials", "") }
73
- subject { knife_list_profiles.stderr }
74
+ subject { knife_list.stderr }
74
75
  it { is_expected.to eq "FATAL: No profiles found, #{path_to(".chef/credentials")} does not exist or is empty\n" }
75
76
  end
76
77
 
@@ -82,9 +83,9 @@ describe "knife config list-profiles", :workstation do
82
83
  chef_server_url = "https://example.com/organizations/testorg"
83
84
  EOH
84
85
  it { is_expected.to eq <<~EOH.delete("#") }
85
- Profile Client Key Server #
86
- ----------------------------------------------------------------------------------#
87
- *default testuser ~/.chef/testkey.pem https://example.com/organizations/testorg#
86
+ Profile Client Key Server #
87
+ --------------------------------------------------------------------------------#
88
+ *default testuser ~/.chef/testkey.pem https://example.com/organizations/testorg #
88
89
  EOH
89
90
  end
90
91
 
@@ -106,11 +107,11 @@ describe "knife config list-profiles", :workstation do
106
107
  chef_server_url = "https://example.com/organizations/testorg"
107
108
  EOH
108
109
  it { is_expected.to eq <<~EOH.delete("#") }
109
- Profile Client Key Server #
110
- ----------------------------------------------------------------------------------#
111
- *default testuser ~/.chef/testkey.pem https://example.com/organizations/testorg#
112
- prod testuser ~/.chef/testkey.pem https://example.com/organizations/prod #
113
- qa qauser ~/src/qauser.pem https://example.com/organizations/testorg#
110
+ Profile Client Key Server #
111
+ --------------------------------------------------------------------------------#
112
+ *default testuser ~/.chef/testkey.pem https://example.com/organizations/testorg #
113
+ prod testuser ~/.chef/testkey.pem https://example.com/organizations/prod #
114
+ qa qauser ~/src/qauser.pem https://example.com/organizations/testorg #
114
115
  EOH
115
116
  end
116
117
 
@@ -133,11 +134,11 @@ describe "knife config list-profiles", :workstation do
133
134
  chef_server_url = "https://example.com/organizations/testorg"
134
135
  EOH
135
136
  it { is_expected.to eq <<~EOH.delete("#") }
136
- Profile Client Key Server #
137
- ----------------------------------------------------------------------------------#
138
- default testuser ~/.chef/testkey.pem https://example.com/organizations/testorg#
139
- *prod testuser ~/.chef/testkey.pem https://example.com/organizations/prod #
140
- qa qauser ~/src/qauser.pem https://example.com/organizations/testorg#
137
+ Profile Client Key Server #
138
+ --------------------------------------------------------------------------------#
139
+ default testuser ~/.chef/testkey.pem https://example.com/organizations/testorg #
140
+ *prod testuser ~/.chef/testkey.pem https://example.com/organizations/prod #
141
+ qa qauser ~/src/qauser.pem https://example.com/organizations/testorg #
141
142
  EOH
142
143
  end
143
144
 
@@ -160,11 +161,11 @@ describe "knife config list-profiles", :workstation do
160
161
  chef_server_url = "https://example.com/organizations/testorg"
161
162
  EOH
162
163
  it { is_expected.to eq <<~EOH.delete("#") }
163
- Profile Client Key Server #
164
- ---------------------------------------------------------------------------------#
165
- default testuser ~/.chef/testkey.pem https://example.com/organizations/testorg#
166
- prod testuser ~/.chef/testkey.pem https://example.com/organizations/prod #
167
- qa qauser ~/src/qauser.pem https://example.com/organizations/testorg#
164
+ Profile Client Key Server #
165
+ --------------------------------------------------------------------------------#
166
+ default testuser ~/.chef/testkey.pem https://example.com/organizations/testorg #
167
+ prod testuser ~/.chef/testkey.pem https://example.com/organizations/prod #
168
+ qa qauser ~/src/qauser.pem https://example.com/organizations/testorg #
168
169
  EOH
169
170
  end
170
171
 
@@ -173,7 +174,7 @@ describe "knife config list-profiles", :workstation do
173
174
  [default]
174
175
  chef_server_url = "https://example.com/organizations/testorg"
175
176
  EOH
176
- it { is_expected.to match %r{^*default .*? https://example.com/organizations/testorg$} }
177
+ it { is_expected.to match %r{^*default .*? https://example.com/organizations/testorg} }
177
178
  end
178
179
 
179
180
  context "with -i" do
@@ -183,9 +184,9 @@ describe "knife config list-profiles", :workstation do
183
184
  chef_server_url = "https://example.com/organizations/testorg"
184
185
  EOH
185
186
  it { is_expected.to eq <<~EOH.delete("#") }
186
- Profile Client Key Server #
187
- ----------------------------------------------------------------#
188
- *default https://example.com/organizations/testorg#
187
+ Profile Client Key Server #
188
+ --------------------------------------------------------------#
189
+ *default https://example.com/organizations/testorg #
189
190
  EOH
190
191
  end
191
192
 
@@ -17,7 +17,7 @@ require "spec_helper"
17
17
  require "support/shared/integration/integration_helper"
18
18
  require "support/shared/context/config"
19
19
 
20
- describe "knife config get", :workstation do
20
+ describe "knife config show", :workstation do
21
21
  include IntegrationSupport
22
22
  include KnifeSupport
23
23
 
@@ -27,7 +27,7 @@ describe "knife config get", :workstation do
27
27
 
28
28
  when_the_repository("has a custom env") do
29
29
  subject do
30
- cmd = knife("config", "get", *cmd_args, instance_filter: lambda { |instance|
30
+ cmd = knife("config", "show", *cmd_args, instance_filter: lambda { |instance|
31
31
  # Clear the stub set up in KnifeSupport.
32
32
  allow(File).to receive(:file?).and_call_original
33
33
  # Lies, damn lies, and config files. We need to allow normal config loading
@@ -47,7 +47,7 @@ describe "knife config get", :workstation do
47
47
  ChefConfig::PathHelper.per_tool_home_environment = "KNIFE_HOME"
48
48
  # Clear these out because they are cached permanently.
49
49
  ChefConfig::PathHelper.class_exec { remove_class_variable(:@@home_dir) }
50
- Chef::Knife::ConfigGet.reset_config_loader!
50
+ Chef::Knife::ConfigShow.reset_config_loader!
51
51
  begin
52
52
  ex.run
53
53
  ensure
@@ -17,7 +17,7 @@ require "spec_helper"
17
17
  require "support/shared/integration/integration_helper"
18
18
  require "support/shared/context/config"
19
19
 
20
- describe "knife config use-profile", :workstation do
20
+ describe "knife config use", :workstation do
21
21
  include IntegrationSupport
22
22
  include KnifeSupport
23
23
 
@@ -26,15 +26,15 @@ describe "knife config use-profile", :workstation do
26
26
  let(:cmd_args) { [] }
27
27
 
28
28
  when_the_repository("has a custom env") do
29
- let(:knife_use_profile) do
30
- knife("config", "use-profile", *cmd_args, instance_filter: lambda { |instance|
29
+ let(:knife_use) do
30
+ knife("config", "use", *cmd_args, instance_filter: lambda { |instance|
31
31
  # Fake the failsafe check because this command doesn't actually process knife.rb.
32
32
  $__KNIFE_INTEGRATION_FAILSAFE_CHECK << " ole"
33
33
  allow(File).to receive(:file?).and_call_original
34
34
  })
35
35
  end
36
36
 
37
- subject { knife_use_profile.stdout }
37
+ subject { knife_use.stdout }
38
38
 
39
39
  around do |ex|
40
40
  # Store and reset the value of some env vars.
@@ -45,7 +45,7 @@ describe "knife config use-profile", :workstation do
45
45
  ChefConfig::PathHelper.per_tool_home_environment = "KNIFE_HOME"
46
46
  # Clear these out because they are cached permanently.
47
47
  ChefConfig::PathHelper.class_exec { remove_class_variable(:@@home_dir) }
48
- Chef::Knife::ConfigUseProfile.reset_config_loader!
48
+ Chef::Knife::ConfigUse.reset_config_loader!
49
49
  begin
50
50
  ex.run
51
51
  ensure
@@ -68,8 +68,51 @@ describe "knife config use-profile", :workstation do
68
68
  end
69
69
 
70
70
  context "with no argument" do
71
- subject { knife_use_profile.stderr }
72
- it { is_expected.to eq "FATAL: You must specify a profile\n" }
71
+ context "with no configuration" do
72
+ it { is_expected.to eq "default\n" }
73
+ end
74
+
75
+ context "with --profile" do
76
+ let(:cmd_args) { %w{--profile production} }
77
+ it { is_expected.to eq "production\n" }
78
+ end
79
+
80
+ context "with an environment variable" do
81
+ around do |ex|
82
+ old_chef_profile = ENV["CHEF_PROFILE"]
83
+ begin
84
+ ENV["CHEF_PROFILE"] = "staging"
85
+ ex.run
86
+ ensure
87
+ ENV["CHEF_PROFILE"] = old_chef_profile
88
+ end
89
+ end
90
+
91
+ it { is_expected.to eq "staging\n" }
92
+ end
93
+
94
+ context "with a context file" do
95
+ before { file(".chef/context", "development\n") }
96
+ it { is_expected.to eq "development\n" }
97
+ end
98
+
99
+ context "with a context file under $CHEF_HOME" do
100
+ before do
101
+ file("chefhome/.chef/context", "other\n")
102
+ ENV["CHEF_HOME"] = path_to("chefhome")
103
+ end
104
+
105
+ it { is_expected.to eq "other\n" }
106
+ end
107
+
108
+ context "with a context file under $KNIFE_HOME" do
109
+ before do
110
+ file("knifehome/.chef/context", "other\n")
111
+ ENV["KNIFE_HOME"] = path_to("knifehome")
112
+ end
113
+
114
+ it { is_expected.to eq "other\n" }
115
+ end
73
116
  end
74
117
 
75
118
  context "with an argument" do
@@ -88,14 +131,14 @@ describe "knife config use-profile", :workstation do
88
131
 
89
132
  context "with no credentials file" do
90
133
  let(:cmd_args) { %w{production} }
91
- subject { knife_use_profile.stderr }
134
+ subject { knife_use.stderr }
92
135
  it { is_expected.to eq "FATAL: No profiles found, #{path_to(".chef/credentials")} does not exist or is empty\n" }
93
136
  end
94
137
 
95
138
  context "with an empty credentials file" do
96
139
  let(:cmd_args) { %w{production} }
97
140
  before { file(".chef/credentials", "") }
98
- subject { knife_use_profile.stderr }
141
+ subject { knife_use.stderr }
99
142
  it { is_expected.to eq "FATAL: No profiles found, #{path_to(".chef/credentials")} does not exist or is empty\n" }
100
143
  end
101
144
 
@@ -107,7 +150,7 @@ describe "knife config use-profile", :workstation do
107
150
  client_key = "testkey.pem"
108
151
  chef_server_url = "https://example.com/organizations/testorg"
109
152
  EOH
110
- subject { knife_use_profile }
153
+ subject { knife_use }
111
154
  it { expect { subject }.to raise_error ChefConfig::ConfigurationError, "Profile staging doesn't exist. Please add it to #{path_to(".chef/credentials")} and if it is profile with DNS name check that you are not missing single quotes around it as per docs https://docs.chef.io/workstation/knife_setup/#knife-profiles." }
112
155
  end
113
156
 
@@ -62,7 +62,7 @@ describe "Knife cookbook API integration with IPv6", :workstation, :not_supporte
62
62
  Dir.mktmpdir
63
63
  end
64
64
 
65
- let(:chef_dir) { File.join(File.dirname(__FILE__), "..", "..", "..", "bin") }
65
+ let(:chef_dir) { File.join(__dir__, "..", "..", "..", "bin") }
66
66
  let(:knife) { "ruby '#{chef_dir}/knife'" }
67
67
 
68
68
  let(:knife_config_flag) { "-c '#{path_to("config/knife.rb")}'" }
@@ -0,0 +1,61 @@
1
+ require "spec_helper"
2
+ require "chef/mixin/shell_out"
3
+ require "benchmark" unless defined?(Benchmark)
4
+
5
+ describe "ohai" do
6
+ include Chef::Mixin::ShellOut
7
+
8
+ let(:ohai) { "bundle exec ohai" }
9
+
10
+ describe "testing ohai performance" do
11
+ # The purpose of this test is to generally find misconfigured DNS on
12
+ # CI testers. If this fails, it is probably because the forward+reverse
13
+ # DNS lookup that node[:hostname] needs is timing out and failing.
14
+ #
15
+ # If it is failing spuriously, it may mean DNS is failing spuriously, the
16
+ # best solution will be to make sure that `hostname -f`-like behavior hits
17
+ # /etc/hosts and not DNS.
18
+ #
19
+ # If it still fails supriously, it is possible that the server has high
20
+ # CPU load (e.g. due to background processes) which are contending with the
21
+ # running tests (disable the screensaver on servers, stop playing Fortnite
22
+ # while you're running tests, etc).
23
+ #
24
+ # If this just fails due to I/O being very slow and ruby being very slow to
25
+ # startup then that still indicates that the tester configuration needs
26
+ # fixing. The fact that this will fail on a windows box on a virt that doesn't
27
+ # use an SSD is because we have a higher bar for the tests to run successfully
28
+ # and that configuration is broken, so this test is red for a reason.
29
+ #
30
+ # This will probably fail on raspberry pi's or something like that as well. That
31
+ # is not a bug. We will never accept a raspberry pi as a CI tester for our
32
+ # software. Feel free to manually delete and thereby skip this file in your
33
+ # own testing harness, but that is not our concern, we are testing behavior
34
+ # that is critical to our infrastructure and must run in our tests.
35
+ #
36
+ # XXX: unfortunately this is so slow on our windows testers (~9 seconds on one
37
+ # tester) that we can't enable it for windows unless we get some better perf there.
38
+ #
39
+ it "the hostname plugin must return in under 4 seconds (see comments in code)" do
40
+ # unfortunately this doesn't look stable enough to enable
41
+ skip "we need to do more performance work on windows and s390x testers before this can be enabled"
42
+ delta = Benchmark.realtime do
43
+ shell_out!("#{ohai} hostname")
44
+ end
45
+ expect(delta).to be < 4
46
+ end
47
+
48
+ # The purpose of this is to give some indication of if shell_out is slow or
49
+ # if the hostname plugin itself is slow. If this test is also failing that we
50
+ # almost certainly have some kind of issue with DNS timeouts, etc. If this
51
+ # test succeeds and the other one fails, then it can be some kind of shelling-out
52
+ # issue or poor performance due to I/O on starting up ruby to run ohai, etc.
53
+ #
54
+ it "the hostname plugin must return in under 2 seconds when called from pure ruby" do
55
+ delta = Benchmark.realtime do
56
+ Ohai::System.new.all_plugins(["hostname"])
57
+ end
58
+ expect(delta).to be < 2
59
+ end
60
+ end
61
+ end
@@ -5,7 +5,7 @@ describe Chef::Resource::RemoteDirectory do
5
5
  include Chef::Mixin::ShellOut
6
6
 
7
7
  # Until Cheffish::RSpec has cookbook support, we have to run the whole client
8
- let(:chef_dir) { File.join(File.dirname(__FILE__), "..", "..", "..", "bin") }
8
+ let(:chef_dir) { File.join(__dir__, "..", "..", "..", "bin") }
9
9
 
10
10
  # Invoke `chef-client` as `ruby PATH/TO/chef-client`. This ensures the
11
11
  # following constraints are satisfied:
@@ -5,20 +5,20 @@ require "chef/run_lock"
5
5
  require "chef/config"
6
6
  require "timeout"
7
7
  require "fileutils"
8
+ require "chef-utils"
8
9
  require "chef/win32/security" if ChefUtils.windows?
9
- require "chef/dist"
10
10
 
11
- describe Chef::Dist::SOLOEXEC do
11
+ describe ChefUtils::Dist::Solo::EXEC do
12
12
  include IntegrationSupport
13
13
  include Chef::Mixin::ShellOut
14
14
 
15
- let(:chef_dir) { File.join(File.dirname(__FILE__), "..", "..", "..") }
15
+ let(:chef_dir) { File.join(__dir__, "..", "..", "..") }
16
16
 
17
17
  let(:cookbook_x_100_metadata_rb) { cb_metadata("x", "1.0.0") }
18
18
 
19
19
  let(:cookbook_ancient_100_metadata_rb) { cb_metadata("ancient", "1.0.0") }
20
20
 
21
- let(:chef_solo) { "bundle exec #{Chef::Dist::SOLOEXEC} --legacy-mode --minimal-ohai" }
21
+ let(:chef_solo) { "bundle exec #{ChefUtils::Dist::Solo::EXEC} --legacy-mode --minimal-ohai" }
22
22
 
23
23
  when_the_repository "creates nodes" do
24
24
  let(:nodes_dir) { File.join(@repository_dir, "nodes") }
@@ -183,7 +183,7 @@ describe Chef::Dist::SOLOEXEC do
183
183
  # run_lock gets stuck we can discover it.
184
184
  expect do
185
185
  Timeout.timeout(120) do
186
- chef_dir = File.join(File.dirname(__FILE__), "..", "..", "..")
186
+ chef_dir = File.join(__dir__, "..", "..", "..")
187
187
 
188
188
  threads = []
189
189