chef 16.3.38-universal-mingw32 → 16.5.64-universal-mingw32

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (405) 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-universal-mingw32.gemspec +0 -1
  6. data/chef.gemspec +2 -1
  7. data/distro/templates/powershell/chef/chef.psm1.erb +18 -18
  8. data/ext/win32-eventlog/Rakefile +2 -2
  9. data/ext/win32-eventlog/chef-log.man.erb +4 -4
  10. data/lib/chef/action_collection.rb +4 -0
  11. data/lib/chef/api_client/registration.rb +2 -2
  12. data/lib/chef/application.rb +19 -17
  13. data/lib/chef/application/apply.rb +17 -12
  14. data/lib/chef/application/base.rb +26 -23
  15. data/lib/chef/application/client.rb +10 -4
  16. data/lib/chef/application/exit_code.rb +13 -4
  17. data/lib/chef/application/knife.rb +22 -11
  18. data/lib/chef/application/solo.rb +2 -1
  19. data/lib/chef/application/windows_service.rb +39 -39
  20. data/lib/chef/application/windows_service_manager.rb +6 -6
  21. data/lib/chef/chef_class.rb +0 -1
  22. data/lib/chef/chef_fs/chef_fs_data_store.rb +54 -54
  23. data/lib/chef/chef_fs/file_system/chef_server/acl_entry.rb +10 -10
  24. data/lib/chef/chef_fs/file_system/chef_server/organization_invites_entry.rb +8 -8
  25. data/lib/chef/chef_fs/file_system/chef_server/organization_members_entry.rb +8 -8
  26. data/lib/chef/chef_fs/file_system/repository/chef_repository_file_system_cookbook_dir.rb +2 -2
  27. data/lib/chef/chef_fs/file_system/repository/chef_repository_file_system_cookbook_entry.rb +1 -1
  28. data/lib/chef/chef_fs/file_system/repository/chef_repository_file_system_root_dir.rb +18 -18
  29. data/lib/chef/chef_fs/file_system/repository/directory.rb +1 -1
  30. data/lib/chef/chef_fs/file_system/repository/file_system_entry.rb +1 -1
  31. data/lib/chef/chef_fs/knife.rb +2 -2
  32. data/lib/chef/chef_fs/parallelizer.rb +0 -1
  33. data/lib/chef/client.rb +21 -22
  34. data/lib/chef/cookbook/cookbook_version_loader.rb +1 -1
  35. data/lib/chef/cookbook/synchronizer.rb +2 -2
  36. data/lib/chef/cookbook_site_streaming_uploader.rb +13 -11
  37. data/lib/chef/cookbook_uploader.rb +1 -1
  38. data/lib/chef/data_collector.rb +6 -5
  39. data/lib/chef/data_collector/config_validation.rb +22 -13
  40. data/lib/chef/data_collector/run_end_message.rb +13 -3
  41. data/lib/chef/data_collector/run_start_message.rb +1 -1
  42. data/lib/chef/deprecated.rb +1 -1
  43. data/lib/chef/deprecation/warnings.rb +2 -2
  44. data/lib/chef/digester.rb +2 -2
  45. data/lib/chef/dsl/chef_vault.rb +1 -1
  46. data/lib/chef/dsl/data_query.rb +2 -2
  47. data/lib/chef/dsl/platform_introspection.rb +9 -9
  48. data/lib/chef/encrypted_data_bag_item.rb +3 -4
  49. data/lib/chef/encrypted_data_bag_item/decryptor.rb +3 -3
  50. data/lib/chef/encrypted_data_bag_item/encryptor.rb +3 -3
  51. data/lib/chef/environment.rb +4 -4
  52. data/lib/chef/event_loggers/windows_eventlog.rb +2 -2
  53. data/lib/chef/exceptions.rb +5 -5
  54. data/lib/chef/file_access_control/windows.rb +5 -1
  55. data/lib/chef/file_content_management/tempfile.rb +9 -9
  56. data/lib/chef/formatters/doc.rb +7 -6
  57. data/lib/chef/formatters/error_inspectors/api_error_formatting.rb +6 -5
  58. data/lib/chef/formatters/error_inspectors/node_load_error_inspector.rb +3 -3
  59. data/lib/chef/formatters/error_inspectors/registration_error_inspector.rb +9 -9
  60. data/lib/chef/formatters/error_inspectors/resource_failure_inspector.rb +2 -2
  61. data/lib/chef/formatters/error_inspectors/run_list_expansion_error_inspector.rb +3 -3
  62. data/lib/chef/formatters/minimal.rb +5 -4
  63. data/lib/chef/handler.rb +2 -0
  64. data/lib/chef/http.rb +15 -13
  65. data/lib/chef/http/auth_credentials.rb +5 -1
  66. data/lib/chef/http/authenticator.rb +3 -1
  67. data/lib/chef/http/basic_client.rb +4 -2
  68. data/lib/chef/http/decompressor.rb +1 -1
  69. data/lib/chef/http/http_request.rb +7 -5
  70. data/lib/chef/http/socketless_chef_zero_client.rb +5 -2
  71. data/lib/chef/http/ssl_policies.rb +1 -1
  72. data/lib/chef/json_compat.rb +2 -2
  73. data/lib/chef/knife.rb +4 -4
  74. data/lib/chef/knife/bootstrap.rb +18 -16
  75. data/lib/chef/knife/bootstrap/chef_vault_handler.rb +1 -1
  76. data/lib/chef/knife/bootstrap/templates/chef-full.erb +3 -3
  77. data/lib/chef/knife/bootstrap/templates/windows-chef-client-msi.erb +7 -7
  78. data/lib/chef/knife/client_create.rb +3 -3
  79. data/lib/chef/knife/config_get.rb +8 -97
  80. data/lib/chef/knife/config_get_profile.rb +9 -9
  81. data/lib/chef/knife/config_list.rb +139 -0
  82. data/lib/chef/knife/config_list_profiles.rb +8 -98
  83. data/lib/chef/knife/config_show.rb +127 -0
  84. data/lib/chef/knife/config_use.rb +61 -0
  85. data/lib/chef/knife/config_use_profile.rb +9 -24
  86. data/lib/chef/knife/configure.rb +4 -2
  87. data/lib/chef/knife/cookbook_download.rb +1 -1
  88. data/lib/chef/knife/cookbook_metadata.rb +1 -1
  89. data/lib/chef/knife/cookbook_upload.rb +23 -23
  90. data/lib/chef/knife/core/bootstrap_context.rb +2 -2
  91. data/lib/chef/knife/core/generic_presenter.rb +1 -1
  92. data/lib/chef/knife/core/hashed_command_loader.rb +2 -2
  93. data/lib/chef/knife/core/object_loader.rb +1 -1
  94. data/lib/chef/knife/core/windows_bootstrap_context.rb +42 -34
  95. data/lib/chef/knife/delete.rb +15 -15
  96. data/lib/chef/knife/exec.rb +4 -4
  97. data/lib/chef/knife/node_show.rb +2 -2
  98. data/lib/chef/knife/serve.rb +3 -3
  99. data/lib/chef/knife/ssh.rb +22 -7
  100. data/lib/chef/knife/ssl_check.rb +3 -3
  101. data/lib/chef/knife/status.rb +2 -2
  102. data/lib/chef/knife/user_create.rb +2 -2
  103. data/lib/chef/knife/xargs.rb +19 -19
  104. data/lib/chef/knife/yaml_convert.rb +1 -1
  105. data/lib/chef/local_mode.rb +2 -2
  106. data/lib/chef/log/syslog.rb +2 -2
  107. data/lib/chef/log/winevt.rb +2 -2
  108. data/lib/chef/mixin/checksum.rb +0 -1
  109. data/lib/chef/mixin/deep_merge.rb +35 -18
  110. data/lib/chef/mixin/openssl_helper.rb +4 -5
  111. data/lib/chef/mixin/shell_out.rb +1 -1
  112. data/lib/chef/mixin/template.rb +2 -2
  113. data/lib/chef/mixin/uris.rb +2 -2
  114. data/lib/chef/mixin/versioned_api.rb +1 -2
  115. data/lib/chef/mixin/which.rb +1 -1
  116. data/lib/chef/monkey_patches/net_http.rb +4 -4
  117. data/lib/chef/monkey_patches/webrick-utils.rb +10 -10
  118. data/lib/chef/node/attribute.rb +2 -4
  119. data/lib/chef/node_map.rb +2 -2
  120. data/lib/chef/platform/service_helpers.rb +1 -1
  121. data/lib/chef/policy_builder/policyfile.rb +2 -2
  122. data/lib/chef/property.rb +1 -1
  123. data/lib/chef/provider.rb +0 -4
  124. data/lib/chef/provider/cron/unix.rb +0 -2
  125. data/lib/chef/provider/file.rb +2 -2
  126. data/lib/chef/provider/git.rb +5 -5
  127. data/lib/chef/provider/group.rb +0 -2
  128. data/lib/chef/provider/group/suse.rb +5 -5
  129. data/lib/chef/provider/ifconfig.rb +1 -4
  130. data/lib/chef/provider/launchd.rb +2 -2
  131. data/lib/chef/provider/mount.rb +0 -2
  132. data/lib/chef/provider/mount/linux.rb +63 -0
  133. data/lib/chef/provider/package.rb +0 -2
  134. data/lib/chef/provider/package/rubygems.rb +22 -19
  135. data/lib/chef/provider/package/snap.rb +1 -2
  136. data/lib/chef/provider/package/windows.rb +2 -2
  137. data/lib/chef/provider/package/windows/registry_uninstall_entry.rb +12 -10
  138. data/lib/chef/provider/package/zypper.rb +1 -1
  139. data/lib/chef/provider/powershell_script.rb +21 -5
  140. data/lib/chef/provider/remote_file/content.rb +3 -0
  141. data/lib/chef/provider/remote_file/ftp.rb +6 -4
  142. data/lib/chef/provider/remote_file/sftp.rb +6 -4
  143. data/lib/chef/provider/route.rb +2 -6
  144. data/lib/chef/provider/service/arch.rb +1 -1
  145. data/lib/chef/provider/service/debian.rb +1 -1
  146. data/lib/chef/provider/service/gentoo.rb +2 -2
  147. data/lib/chef/provider/service/macosx.rb +4 -4
  148. data/lib/chef/provider/service/openbsd.rb +1 -4
  149. data/lib/chef/provider/service/redhat.rb +2 -2
  150. data/lib/chef/provider/service/upstart.rb +1 -1
  151. data/lib/chef/provider/service/windows.rb +10 -10
  152. data/lib/chef/provider/systemd_unit.rb +0 -2
  153. data/lib/chef/provider/template/content.rb +1 -0
  154. data/lib/chef/provider/template_finder.rb +2 -10
  155. data/lib/chef/provider/user/dscl.rb +5 -5
  156. data/lib/chef/provider/user/mac.rb +10 -10
  157. data/lib/chef/provider/windows_task.rb +1 -5
  158. data/lib/chef/provider/zypper_repository.rb +2 -3
  159. data/lib/chef/provider_resolver.rb +1 -1
  160. data/lib/chef/providers.rb +1 -1
  161. data/lib/chef/recipe.rb +2 -2
  162. data/lib/chef/resource.rb +7 -11
  163. data/lib/chef/resource/apt_repository.rb +2 -11
  164. data/lib/chef/resource/bff_package.rb +22 -0
  165. data/lib/chef/resource/breakpoint.rb +57 -2
  166. data/lib/chef/resource/build_essential.rb +1 -1
  167. data/lib/chef/resource/cab_package.rb +29 -0
  168. data/lib/chef/resource/chef_client_cron.rb +32 -25
  169. data/lib/chef/resource/chef_client_launchd.rb +194 -0
  170. data/lib/chef/resource/chef_client_scheduled_task.rb +21 -18
  171. data/lib/chef/resource/chef_client_systemd_timer.rb +26 -19
  172. data/lib/chef/resource/chef_client_trusted_certificate.rb +101 -0
  173. data/lib/chef/resource/chef_gem.rb +10 -10
  174. data/lib/chef/resource/chef_handler.rb +148 -4
  175. data/lib/chef/resource/chef_sleep.rb +2 -2
  176. data/lib/chef/resource/chef_vault_secret.rb +14 -14
  177. data/lib/chef/resource/cookbook_file.rb +2 -2
  178. data/lib/chef/resource/cron/cron_d.rb +0 -1
  179. data/lib/chef/resource/dnf_package.rb +2 -2
  180. data/lib/chef/resource/dsc_resource.rb +0 -1
  181. data/lib/chef/resource/dsc_script.rb +2 -2
  182. data/lib/chef/resource/execute.rb +8 -9
  183. data/lib/chef/resource/file.rb +4 -4
  184. data/lib/chef/resource/gem_package.rb +5 -5
  185. data/lib/chef/resource/homebrew_package.rb +3 -3
  186. data/lib/chef/resource/homebrew_update.rb +7 -7
  187. data/lib/chef/resource/hostname.rb +19 -19
  188. data/lib/chef/resource/launchd.rb +2 -1
  189. data/lib/chef/resource/locale.rb +2 -2
  190. data/lib/chef/resource/macos_userdefaults.rb +3 -3
  191. data/lib/chef/resource/notify_group.rb +0 -1
  192. data/lib/chef/resource/ohai.rb +46 -3
  193. data/lib/chef/resource/ohai_hint.rb +33 -0
  194. data/lib/chef/resource/openssl_dhparam.rb +29 -5
  195. data/lib/chef/resource/openssl_ec_private_key.rb +8 -3
  196. data/lib/chef/resource/openssl_ec_public_key.rb +4 -2
  197. data/lib/chef/resource/openssl_rsa_private_key.rb +8 -3
  198. data/lib/chef/resource/openssl_rsa_public_key.rb +2 -0
  199. data/lib/chef/resource/openssl_x509_certificate.rb +38 -35
  200. data/lib/chef/resource/openssl_x509_crl.rb +21 -10
  201. data/lib/chef/resource/openssl_x509_request.rb +37 -36
  202. data/lib/chef/resource/osx_profile.rb +292 -6
  203. data/lib/chef/resource/plist.rb +1 -1
  204. data/lib/chef/resource/powershell_package_source.rb +6 -6
  205. data/lib/chef/resource/powershell_script.rb +24 -30
  206. data/lib/chef/resource/reboot.rb +2 -2
  207. data/lib/chef/resource/remote_file.rb +3 -3
  208. data/lib/chef/resource/rhsm_register.rb +22 -10
  209. data/lib/chef/resource/ruby_block.rb +2 -2
  210. data/lib/chef/resource/scm/subversion.rb +2 -2
  211. data/lib/chef/resource/service.rb +3 -3
  212. data/lib/chef/resource/ssh_known_hosts_entry.rb +2 -2
  213. data/lib/chef/resource/sudo.rb +1 -1
  214. data/lib/chef/resource/support/cron.d.erb +1 -1
  215. data/lib/chef/resource/support/cron_access.erb +1 -1
  216. data/lib/chef/resource/support/sudoer.erb +1 -1
  217. data/lib/chef/resource/support/ulimit.erb +1 -1
  218. data/lib/chef/resource/sysctl.rb +6 -10
  219. data/lib/chef/resource/systemd_unit.rb +2 -2
  220. data/lib/chef/resource/template.rb +2 -2
  221. data/lib/chef/resource/timezone.rb +112 -73
  222. data/lib/chef/resource/windows_ad_join.rb +12 -3
  223. data/lib/chef/resource/windows_audit_policy.rb +3 -0
  224. data/lib/chef/resource/windows_auto_run.rb +2 -0
  225. data/lib/chef/resource/windows_certificate.rb +8 -4
  226. data/lib/chef/resource/windows_dfs_folder.rb +2 -0
  227. data/lib/chef/resource/windows_dfs_namespace.rb +2 -0
  228. data/lib/chef/resource/windows_dfs_server.rb +2 -0
  229. data/lib/chef/resource/windows_dns_record.rb +10 -7
  230. data/lib/chef/resource/windows_dns_zone.rb +12 -7
  231. data/lib/chef/resource/windows_feature.rb +2 -0
  232. data/lib/chef/resource/windows_feature_dism.rb +10 -0
  233. data/lib/chef/resource/windows_feature_powershell.rb +14 -2
  234. data/lib/chef/resource/windows_firewall_profile.rb +24 -20
  235. data/lib/chef/resource/windows_firewall_rule.rb +5 -3
  236. data/lib/chef/resource/windows_font.rb +3 -1
  237. data/lib/chef/resource/windows_package.rb +28 -5
  238. data/lib/chef/resource/windows_pagefile.rb +4 -0
  239. data/lib/chef/resource/windows_printer.rb +22 -21
  240. data/lib/chef/resource/windows_printer_port.rb +20 -17
  241. data/lib/chef/resource/windows_security_policy.rb +2 -0
  242. data/lib/chef/resource/windows_share.rb +5 -3
  243. data/lib/chef/resource/windows_shortcut.rb +2 -0
  244. data/lib/chef/resource/windows_uac.rb +2 -0
  245. data/lib/chef/resource/windows_user_privilege.rb +54 -53
  246. data/lib/chef/resource/windows_workgroup.rb +5 -6
  247. data/lib/chef/resource/yum_package.rb +2 -2
  248. data/lib/chef/resource_collection/stepable_iterator.rb +1 -2
  249. data/lib/chef/resources.rb +3 -1
  250. data/lib/chef/role.rb +2 -2
  251. data/lib/chef/run_context.rb +2 -2
  252. data/lib/chef/run_context/cookbook_compiler.rb +21 -21
  253. data/lib/chef/run_lock.rb +2 -2
  254. data/lib/chef/run_status.rb +2 -6
  255. data/lib/chef/search/query.rb +4 -5
  256. data/lib/chef/server_api_versions.rb +4 -0
  257. data/lib/chef/shell.rb +32 -27
  258. data/lib/chef/shell/ext.rb +11 -11
  259. data/lib/chef/shell/shell_session.rb +2 -2
  260. data/lib/chef/train_transport.rb +5 -104
  261. data/lib/chef/util/backup.rb +1 -1
  262. data/lib/chef/util/diff.rb +14 -14
  263. data/lib/chef/util/powershell/cmdlet.rb +4 -2
  264. data/lib/chef/util/powershell/ps_credential.rb +18 -14
  265. data/lib/chef/util/threaded_job_queue.rb +0 -2
  266. data/lib/chef/version.rb +1 -1
  267. data/lib/chef/win32/crypto.rb +1 -1
  268. data/lib/chef/win32/file.rb +2 -2
  269. data/lib/chef/win32/file/version_info.rb +5 -5
  270. data/lib/chef/win32/registry.rb +1 -2
  271. data/spec/data/shef-config.rb +1 -1
  272. data/spec/data/ssl/chef-rspec.cert +15 -15
  273. data/spec/functional/event_loggers/windows_eventlog_spec.rb +6 -5
  274. data/spec/functional/resource/aix_service_spec.rb +2 -2
  275. data/spec/functional/resource/aixinit_service_spec.rb +8 -8
  276. data/spec/functional/resource/bff_spec.rb +2 -2
  277. data/spec/functional/resource/cookbook_file_spec.rb +1 -1
  278. data/spec/functional/resource/dsc_resource_spec.rb +1 -1
  279. data/spec/functional/resource/dsc_script_spec.rb +0 -1
  280. data/spec/functional/resource/group_spec.rb +6 -6
  281. data/spec/functional/resource/insserv_spec.rb +5 -5
  282. data/spec/functional/resource/link_spec.rb +20 -20
  283. data/spec/functional/resource/powershell_script_spec.rb +4 -4
  284. data/spec/functional/resource/rpm_spec.rb +2 -2
  285. data/spec/functional/resource/user/dscl_spec.rb +1 -1
  286. data/spec/functional/resource/user/mac_user_spec.rb +1 -1
  287. data/spec/functional/resource/windows_certificate_spec.rb +3 -3
  288. data/spec/functional/resource/windows_font_spec.rb +49 -0
  289. data/spec/functional/resource/windows_security_policy_spec.rb +0 -3
  290. data/spec/functional/resource/windows_task_spec.rb +13 -13
  291. data/spec/functional/run_lock_spec.rb +24 -24
  292. data/spec/functional/version_spec.rb +3 -3
  293. data/spec/functional/win32/registry_spec.rb +8 -8
  294. data/spec/functional/win32/service_manager_spec.rb +1 -1
  295. data/spec/integration/client/client_spec.rb +4 -4
  296. data/spec/integration/client/exit_code_spec.rb +3 -2
  297. data/spec/integration/client/ipv6_spec.rb +1 -1
  298. data/spec/integration/knife/common_options_spec.rb +12 -12
  299. data/spec/integration/knife/config_list_spec.rb +220 -0
  300. data/spec/integration/knife/config_show_spec.rb +192 -0
  301. data/spec/integration/knife/config_use_spec.rb +198 -0
  302. data/spec/integration/knife/cookbook_api_ipv6_spec.rb +1 -1
  303. data/spec/integration/knife/diff_spec.rb +3 -1
  304. data/spec/integration/knife/download_spec.rb +3 -1
  305. data/spec/integration/knife/serve_spec.rb +5 -5
  306. data/spec/integration/knife/upload_spec.rb +3 -1
  307. data/spec/integration/ohai/ohai_spec.rb +61 -0
  308. data/spec/integration/recipes/lwrp_inline_resources_spec.rb +1 -1
  309. data/spec/integration/recipes/remote_directory.rb +1 -1
  310. data/spec/integration/solo/solo_spec.rb +5 -5
  311. data/spec/spec_helper.rb +12 -9
  312. data/spec/stress/win32/file_spec.rb +1 -1
  313. data/spec/support/chef_helpers.rb +2 -2
  314. data/spec/support/matchers/leak.rb +2 -2
  315. data/spec/support/platform_helpers.rb +17 -35
  316. data/spec/support/platforms/win32/spec_service.rb +1 -1
  317. data/spec/support/shared/functional/directory_resource.rb +1 -1
  318. data/spec/support/shared/functional/execute_resource.rb +1 -1
  319. data/spec/support/shared/functional/file_resource.rb +20 -20
  320. data/spec/support/shared/functional/securable_resource.rb +108 -27
  321. data/spec/support/shared/functional/win32_service.rb +2 -2
  322. data/spec/support/shared/functional/windows_script.rb +3 -3
  323. data/spec/support/shared/integration/integration_helper.rb +22 -52
  324. data/spec/support/shared/unit/application_dot_d.rb +5 -3
  325. data/spec/support/shared/unit/script_resource.rb +6 -20
  326. data/spec/support/shared/unit/windows_script_resource.rb +15 -28
  327. data/spec/tiny_server.rb +0 -1
  328. data/spec/unit/application/client_spec.rb +2 -2
  329. data/spec/unit/application/exit_code_spec.rb +10 -0
  330. data/spec/unit/application_spec.rb +4 -6
  331. data/spec/unit/chef_fs/parallelizer_spec.rb +5 -1
  332. data/spec/unit/chef_fs/path_util_spec.rb +1 -1
  333. data/spec/unit/cookbook/synchronizer_spec.rb +2 -2
  334. data/spec/unit/cookbook_spec.rb +2 -2
  335. data/spec/unit/data_collector/config_validation_spec.rb +208 -0
  336. data/spec/unit/data_collector_spec.rb +28 -113
  337. data/spec/unit/dsl/declare_resource_spec.rb +1 -1
  338. data/spec/unit/environment_spec.rb +7 -7
  339. data/spec/unit/file_access_control_spec.rb +1 -1
  340. data/spec/unit/http/api_versions_spec.rb +19 -1
  341. data/spec/unit/knife/bootstrap_spec.rb +20 -20
  342. data/spec/unit/knife/cookbook_download_spec.rb +4 -4
  343. data/spec/unit/knife/cookbook_metadata_from_file_spec.rb +1 -1
  344. data/spec/unit/knife/core/hashed_command_loader_spec.rb +3 -3
  345. data/spec/unit/knife/core/ui_spec.rb +1 -0
  346. data/spec/unit/knife/core/windows_bootstrap_context_spec.rb +21 -12
  347. data/spec/unit/knife/ssh_spec.rb +2 -2
  348. data/spec/unit/knife/supermarket_share_spec.rb +1 -1
  349. data/spec/unit/lwrp_spec.rb +3 -3
  350. data/spec/unit/mixin/deep_merge_spec.rb +15 -0
  351. data/spec/unit/mixin/openssl_helper_spec.rb +1 -1
  352. data/spec/unit/mixin/powershell_exec_spec.rb +1 -1
  353. data/spec/unit/mixin/securable_spec.rb +2 -2
  354. data/spec/unit/mixin/template_spec.rb +30 -30
  355. data/spec/unit/mixin/windows_architecture_helper_spec.rb +4 -4
  356. data/spec/unit/node/immutable_collections_spec.rb +8 -4
  357. data/spec/unit/node_spec.rb +5 -5
  358. data/spec/unit/provider/mount/linux_spec.rb +97 -0
  359. data/spec/unit/provider/package/chocolatey_spec.rb +1 -1
  360. data/spec/unit/provider/package/powershell_spec.rb +1 -1
  361. data/spec/unit/provider/package/rubygems_spec.rb +4 -1
  362. data/spec/unit/provider/powershell_script_spec.rb +11 -4
  363. data/spec/unit/provider/remote_directory_spec.rb +9 -9
  364. data/spec/unit/provider/route_spec.rb +0 -2
  365. data/spec/unit/provider/service/arch_service_spec.rb +3 -2
  366. data/spec/unit/provider/service/debian_service_spec.rb +1 -1
  367. data/spec/unit/provider/service/gentoo_service_spec.rb +7 -7
  368. data/spec/unit/provider/service/macosx_spec.rb +3 -3
  369. data/spec/unit/provider/service/redhat_spec.rb +2 -2
  370. data/spec/unit/provider/service/upstart_service_spec.rb +3 -3
  371. data/spec/unit/provider_resolver_spec.rb +6 -6
  372. data/spec/unit/recipe_spec.rb +1 -1
  373. data/spec/unit/resource/batch_spec.rb +6 -6
  374. data/spec/unit/resource/chef_client_cron_spec.rb +35 -14
  375. data/spec/unit/resource/chef_client_launchd_spec.rb +127 -0
  376. data/spec/unit/resource/chef_client_systemd_timer_spec.rb +36 -1
  377. data/spec/unit/resource/chef_client_trusted_certificate_spec.rb +54 -0
  378. data/spec/unit/resource/execute_spec.rb +113 -118
  379. data/spec/unit/resource/launchd_spec.rb +8 -0
  380. data/spec/unit/resource/osx_profile_spec.rb +299 -0
  381. data/spec/unit/resource/powershell_script_spec.rb +11 -29
  382. data/spec/unit/resource/rhsm_register_spec.rb +56 -18
  383. data/spec/unit/resource/script_spec.rb +6 -1
  384. data/spec/unit/resource/timezone_spec.rb +63 -0
  385. data/spec/unit/resource/windows_feature_powershell_spec.rb +30 -4
  386. data/spec/unit/resource/windows_uac_spec.rb +1 -1
  387. data/spec/unit/resource/windows_user_privilege_spec.rb +55 -0
  388. data/spec/unit/role_spec.rb +11 -11
  389. data/spec/unit/run_lock_spec.rb +5 -1
  390. data/spec/unit/runner_spec.rb +1 -2
  391. data/spec/unit/server_api_spec.rb +43 -16
  392. data/spec/unit/shell/shell_ext_spec.rb +46 -3
  393. data/spec/unit/shell/shell_session_spec.rb +35 -64
  394. data/spec/unit/shell_spec.rb +16 -19
  395. data/spec/unit/train_transport_spec.rb +14 -13
  396. data/spec/unit/util/selinux_spec.rb +2 -0
  397. data/tasks/rspec.rb +1 -3
  398. metadata +42 -33
  399. data/lib/chef/dist.rb +0 -68
  400. data/lib/chef/provider/osx_profile.rb +0 -255
  401. data/spec/integration/knife/config_get_profile_spec.rb +0 -113
  402. data/spec/integration/knife/config_get_spec.rb +0 -191
  403. data/spec/integration/knife/config_list_profiles_spec.rb +0 -218
  404. data/spec/integration/knife/config_use_profile_spec.rb +0 -154
  405. data/spec/unit/provider/osx_profile_spec.rb +0 -255
@@ -20,7 +20,13 @@
20
20
  require_relative "base"
21
21
  require_relative "../handler/error_report"
22
22
  require_relative "../workstation_config_loader"
23
- require "uri" unless defined?(URI)
23
+ autoload :URI, "uri"
24
+ require "chef-utils" unless defined?(ChefUtils)
25
+ module Mixlib
26
+ module Authentication
27
+ autoload :Log, "mixlib/authentication"
28
+ end
29
+ end
24
30
 
25
31
  # DO NOT MAKE EDITS, see Chef::Application::Base
26
32
  #
@@ -45,7 +51,7 @@ class Chef::Application::Client < Chef::Application::Base
45
51
  option :pid_file,
46
52
  short: "-P PID_FILE",
47
53
  long: "--pid PIDFILE",
48
- description: "Set the PID file location, for the #{Chef::Dist::CLIENT} daemon process. Defaults to /tmp/chef-client.pid.",
54
+ description: "Set the PID file location, for the #{ChefUtils::Dist::Infra::CLIENT} daemon process. Defaults to /tmp/chef-client.pid.",
49
55
  proc: nil
50
56
 
51
57
  option :runlist,
@@ -100,7 +106,7 @@ class Chef::Application::Client < Chef::Application::Base
100
106
  tarball_path = File.join(Chef::Config.chef_repo_path, "recipes.tgz")
101
107
  fetch_recipe_tarball(Chef::Config[:recipe_url], tarball_path)
102
108
  Mixlib::Archive.new(tarball_path).extract(Chef::Config.chef_repo_path, perms: false, ignore: /^\.$/)
103
- config_path = File.join(Chef::Config.chef_repo_path, "#{Chef::Dist::USER_CONF_DIR}/config.rb")
109
+ config_path = File.join(Chef::Config.chef_repo_path, "#{ChefUtils::Dist::Infra::USER_CONF_DIR}/config.rb")
104
110
  Chef::Config.from_string(IO.read(config_path), config_path) if File.file?(config_path)
105
111
  end
106
112
  end
@@ -147,7 +153,7 @@ class Chef::Application::Client < Chef::Application::Base
147
153
  if config[:local_mode]
148
154
  config[:config_file] = Chef::WorkstationConfigLoader.new(nil, Chef::Log).config_location
149
155
  else
150
- config[:config_file] = Chef::Config.platform_specific_path("#{Chef::Dist::CONF_DIR}/client.rb")
156
+ config[:config_file] = Chef::Config.platform_specific_path("#{ChefConfig::Config.etc_chef_dir}/client.rb")
151
157
  end
152
158
  end
153
159
 
@@ -22,7 +22,7 @@ class Chef
22
22
  # These are the exit codes defined in Chef RFC 062
23
23
  # https://github.com/chef/chef-rfc/blob/master/rfc062-exit-status.md
24
24
  class ExitCode
25
- require_relative "../dist"
25
+ require "chef-utils/dist" unless defined?(ChefUtils::Dist)
26
26
 
27
27
  # -1 is defined as DEPRECATED_FAILURE in RFC 062, so it is
28
28
  # not enumerated in an active constant.
@@ -36,6 +36,7 @@ class Chef
36
36
  REBOOT_NEEDED: 37,
37
37
  REBOOT_FAILED: 41,
38
38
  # 42 was used by audit mode and should not be reused
39
+ CONFIG_FAILURE: 43,
39
40
  CLIENT_UPGRADED: 213,
40
41
  }.freeze
41
42
 
@@ -79,6 +80,8 @@ class Chef
79
80
  VALID_RFC_062_EXIT_CODES[:REBOOT_NEEDED]
80
81
  elsif reboot_failed?(exception)
81
82
  VALID_RFC_062_EXIT_CODES[:REBOOT_FAILED]
83
+ elsif configuration_failure?(exception)
84
+ VALID_RFC_062_EXIT_CODES[:CONFIG_FAILURE]
82
85
  elsif client_upgraded?(exception)
83
86
  VALID_RFC_062_EXIT_CODES[:CLIENT_UPGRADED]
84
87
  else
@@ -104,6 +107,12 @@ class Chef
104
107
  end
105
108
  end
106
109
 
110
+ def configuration_failure?(exception)
111
+ resolve_exception_array(exception).any? do |e|
112
+ e.is_a? Chef::Exceptions::ConfigurationError
113
+ end
114
+ end
115
+
107
116
  def client_upgraded?(exception)
108
117
  resolve_exception_array(exception).any? do |e|
109
118
  e.is_a? Chef::Exceptions::ClientUpgraded
@@ -144,9 +153,9 @@ class Chef
144
153
  end
145
154
 
146
155
  def non_standard_exit_code_warning(exit_code)
147
- "#{Chef::Dist::CLIENT} attempted to exit with a non-standard exit code of #{exit_code}." \
148
- " The #{Chef::Dist::PRODUCT} Exit Codes design document (https://github.com/chef/chef-rfc/blob/master/rfc062-exit-status.md)" \
149
- " defines the exit codes that should be used with #{Chef::Dist::CLIENT}. Chef::Application::ExitCode defines" \
156
+ "#{ChefUtils::Dist::Infra::CLIENT} attempted to exit with a non-standard exit code of #{exit_code}." \
157
+ " The #{ChefUtils::Dist::Infra::PRODUCT} Exit Codes design document (https://github.com/chef/chef-rfc/blob/master/rfc062-exit-status.md)" \
158
+ " defines the exit codes that should be used with #{ChefUtils::Dist::Infra::CLIENT}. Chef::Application::ExitCode defines" \
150
159
  " valid exit codes Non-standard exit codes are redefined as GENERIC_FAILURE."
151
160
  end
152
161
 
@@ -19,8 +19,10 @@ require_relative "../knife"
19
19
  require_relative "../application"
20
20
  require "mixlib/log"
21
21
  require "ohai/config"
22
- require "chef/monkey_patches/net_http.rb"
23
- require_relative "../dist"
22
+ module Net
23
+ autoload :HTTP, File.expand_path("../monkey_patches/net_http", __dir__)
24
+ end
25
+ require "chef-utils/dist" unless defined?(ChefUtils::Dist)
24
26
 
25
27
  class Chef::Application::Knife < Chef::Application
26
28
 
@@ -59,7 +61,7 @@ class Chef::Application::Knife < Chef::Application
59
61
  option :environment,
60
62
  short: "-E ENVIRONMENT",
61
63
  long: "--environment ENVIRONMENT",
62
- description: "Set the #{Chef::Dist::PRODUCT} environment (except for in searches, where this will be flagrantly ignored)."
64
+ description: "Set the #{ChefUtils::Dist::Infra::PRODUCT} environment (except for in searches, where this will be flagrantly ignored)."
63
65
 
64
66
  option :editor,
65
67
  short: "-e EDITOR",
@@ -84,18 +86,18 @@ class Chef::Application::Knife < Chef::Application
84
86
  option :node_name,
85
87
  short: "-u USER",
86
88
  long: "--user USER",
87
- description: "#{Chef::Dist::SERVER_PRODUCT} API client username."
89
+ description: "#{ChefUtils::Dist::Server::PRODUCT} API client username."
88
90
 
89
91
  option :client_key,
90
92
  short: "-k KEY",
91
93
  long: "--key KEY",
92
- description: "#{Chef::Dist::SERVER_PRODUCT} API client key.",
94
+ description: "#{ChefUtils::Dist::Server::PRODUCT} API client key.",
93
95
  proc: lambda { |path| File.expand_path(path, Dir.pwd) }
94
96
 
95
97
  option :chef_server_url,
96
98
  short: "-s URL",
97
99
  long: "--server-url URL",
98
- description: "#{Chef::Dist::SERVER_PRODUCT} URL."
100
+ description: "#{ChefUtils::Dist::Server::PRODUCT} URL."
99
101
 
100
102
  option :yes,
101
103
  short: "-y",
@@ -120,16 +122,16 @@ class Chef::Application::Knife < Chef::Application
120
122
  option :local_mode,
121
123
  short: "-z",
122
124
  long: "--local-mode",
123
- description: "Point knife commands at local repository instead of #{Chef::Dist::SERVER_PRODUCT}.",
125
+ description: "Point knife commands at local repository instead of #{ChefUtils::Dist::Server::PRODUCT}.",
124
126
  boolean: true
125
127
 
126
128
  option :chef_zero_host,
127
129
  long: "--chef-zero-host HOST",
128
- description: "Host to start #{Chef::Dist::ZERO} on."
130
+ description: "Host to start #{ChefUtils::Dist::Zero::PRODUCT} on."
129
131
 
130
132
  option :chef_zero_port,
131
133
  long: "--chef-zero-port PORT",
132
- description: "Port (or port range) to start #{Chef::Dist::ZERO} on. Port ranges like 1000,1010 or 8889-9999 will try all given ports until one works."
134
+ description: "Port (or port range) to start #{ChefUtils::Dist::Zero::PRODUCT} on. Port ranges like 1000,1010 or 8889-9999 will try all given ports until one works."
133
135
 
134
136
  option :listen,
135
137
  long: "--[no-]listen",
@@ -139,9 +141,9 @@ class Chef::Application::Knife < Chef::Application
139
141
  option :version,
140
142
  short: "-v",
141
143
  long: "--version",
142
- description: "Show #{Chef::Dist::PRODUCT} version.",
144
+ description: "Show #{ChefUtils::Dist::Infra::PRODUCT} version.",
143
145
  boolean: true,
144
- proc: lambda { |v| puts "#{Chef::Dist::PRODUCT}: #{::Chef::VERSION}" },
146
+ proc: lambda { |v| puts "#{ChefUtils::Dist::Infra::PRODUCT}: #{::Chef::VERSION}" },
145
147
  exit: 0
146
148
 
147
149
  option :fips,
@@ -214,6 +216,15 @@ class Chef::Application::Knife < Chef::Application
214
216
  rescue OptionParser::InvalidOption => e
215
217
  puts "#{e}\n"
216
218
  end
219
+
220
+ if want_help?
221
+ puts "#{ChefUtils::Dist::Infra::PRODUCT}: #{Chef::VERSION}"
222
+ puts
223
+ puts "Docs: #{ChefUtils::Dist::Org::KNIFE_DOCS}"
224
+ puts "Patents: #{ChefUtils::Dist::Org::PATENTS}"
225
+ puts
226
+ end
227
+
217
228
  puts opt_parser
218
229
  puts
219
230
  Chef::Knife.list_commands
@@ -21,6 +21,7 @@ require_relative "../../chef"
21
21
  require_relative "client"
22
22
  require "fileutils" unless defined?(FileUtils)
23
23
  require "pathname" unless defined?(Pathname)
24
+ require "chef-utils" unless defined?(ChefUtils)
24
25
 
25
26
  # DO NOT MAKE EDITS, see Chef::Application::Base
26
27
  #
@@ -33,7 +34,7 @@ class Chef::Application::Solo < Chef::Application::Base
33
34
  option :config_file,
34
35
  short: "-c CONFIG",
35
36
  long: "--config CONFIG",
36
- default: Chef::Config.platform_specific_path("#{Chef::Dist::CONF_DIR}/solo.rb"),
37
+ default: Chef::Config.platform_specific_path("#{ChefConfig::Config.etc_chef_dir}/solo.rb"),
37
38
  description: "The configuration file to use."
38
39
 
39
40
  unless ChefUtils.windows?
@@ -29,7 +29,7 @@ require "socket" unless defined?(Socket)
29
29
  require "uri" unless defined?(URI)
30
30
  require "win32/daemon"
31
31
  require_relative "../mixin/shell_out"
32
- require_relative "../dist"
32
+ require "chef-utils/dist" unless defined?(ChefUtils::Dist)
33
33
 
34
34
  class Chef
35
35
  class Application
@@ -41,7 +41,7 @@ class Chef
41
41
  short: "-c CONFIG",
42
42
  long: "--config CONFIG",
43
43
  default: "#{Chef::Config.etc_chef_dir}/client.rb",
44
- description: "The configuration file to use for #{Chef::Dist::PRODUCT} runs."
44
+ description: "The configuration file to use for #{ChefUtils::Dist::Infra::PRODUCT} runs."
45
45
 
46
46
  option :log_location,
47
47
  short: "-L LOGLOCATION",
@@ -57,7 +57,7 @@ class Chef
57
57
  option :interval,
58
58
  short: "-i SECONDS",
59
59
  long: "--interval SECONDS",
60
- description: "Set the number of seconds to wait between #{Chef::Dist::PRODUCT} runs.",
60
+ description: "Set the number of seconds to wait between #{ChefUtils::Dist::Infra::PRODUCT} runs.",
61
61
  proc: lambda { |s| s.to_i }
62
62
 
63
63
  DEFAULT_LOG_LOCATION ||= "#{Chef::Config.c_chef_dir}/client.log".freeze
@@ -67,7 +67,7 @@ class Chef
67
67
  @service_signal = ConditionVariable.new
68
68
 
69
69
  reconfigure
70
- Chef::Log.info("#{Chef::Dist::CLIENT} Service initialized")
70
+ Chef::Log.info("#{ChefUtils::Dist::Infra::CLIENT} Service initialized")
71
71
  end
72
72
 
73
73
  def service_main(*startup_parameters)
@@ -78,33 +78,33 @@ class Chef
78
78
  while running?
79
79
  # Grab the service_action_mutex to make a chef-client run
80
80
  @service_action_mutex.synchronize do
81
- begin
82
- Chef::Log.info("Next #{Chef::Dist::CLIENT} run will happen in #{timeout} seconds")
83
- @service_signal.wait(@service_action_mutex, timeout)
84
-
85
- # Continue only if service is RUNNING
86
- next if state != RUNNING
87
-
88
- # Reconfigure each time through to pick up any changes in the client file
89
- Chef::Log.info("Reconfiguring with startup parameters")
90
- reconfigure(startup_parameters)
91
- timeout = Chef::Config[:interval]
92
-
93
- # Honor splay sleep config
94
- timeout += rand Chef::Config[:splay]
95
-
96
- # run chef-client only if service is in RUNNING state
97
- next if state != RUNNING
98
-
99
- Chef::Log.info("#{Chef::Dist::CLIENT} service is starting a #{Chef::Dist::CLIENT} run...")
100
- run_chef_client
101
- rescue SystemExit => e
102
- # Do not raise any of the errors here in order to
103
- # prevent service crash
104
- Chef::Log.error("#{e.class}: #{e}")
105
- rescue Exception => e
106
- Chef::Log.error("#{e.class}: #{e}")
107
- end
81
+
82
+ Chef::Log.info("Next #{ChefUtils::Dist::Infra::CLIENT} run will happen in #{timeout} seconds")
83
+ @service_signal.wait(@service_action_mutex, timeout)
84
+
85
+ # Continue only if service is RUNNING
86
+ next if state != RUNNING
87
+
88
+ # Reconfigure each time through to pick up any changes in the client file
89
+ Chef::Log.info("Reconfiguring with startup parameters")
90
+ reconfigure(startup_parameters)
91
+ timeout = Chef::Config[:interval]
92
+
93
+ # Honor splay sleep config
94
+ timeout += rand Chef::Config[:splay]
95
+
96
+ # run chef-client only if service is in RUNNING state
97
+ next if state != RUNNING
98
+
99
+ Chef::Log.info("#{ChefUtils::Dist::Infra::CLIENT} service is starting a #{ChefUtils::Dist::Infra::CLIENT} run...")
100
+ run_chef_client
101
+ rescue SystemExit => e
102
+ # Do not raise any of the errors here in order to
103
+ # prevent service crash
104
+ Chef::Log.error("#{e.class}: #{e}")
105
+ rescue Exception => e
106
+ Chef::Log.error("#{e.class}: #{e}")
107
+
108
108
  end
109
109
  end
110
110
 
@@ -131,12 +131,12 @@ class Chef
131
131
  break
132
132
  else
133
133
  unless run_warning_displayed
134
- Chef::Log.info("Currently a #{Chef::Dist::PRODUCT} run is happening on this system.")
134
+ Chef::Log.info("Currently a #{ChefUtils::Dist::Infra::PRODUCT} run is happening on this system.")
135
135
  Chef::Log.info("Service will stop when run is completed.")
136
136
  run_warning_displayed = true
137
137
  end
138
138
 
139
- Chef::Log.trace("Waiting for #{Chef::Dist::PRODUCT} run...")
139
+ Chef::Log.trace("Waiting for #{ChefUtils::Dist::Infra::PRODUCT} run...")
140
140
  sleep 1
141
141
  end
142
142
  end
@@ -150,7 +150,7 @@ class Chef
150
150
  # since this is a PAUSE signal.
151
151
 
152
152
  if @service_action_mutex.locked?
153
- Chef::Log.info("Currently a #{Chef::Dist::PRODUCT} run is happening.")
153
+ Chef::Log.info("Currently a #{ChefUtils::Dist::Infra::PRODUCT} run is happening.")
154
154
  Chef::Log.info("Service will pause once it's completed.")
155
155
  else
156
156
  Chef::Log.info("Service is pausing....")
@@ -185,7 +185,7 @@ class Chef
185
185
  # The log_location and config_file of the parent process is passed to the new chef-client process.
186
186
  # We need to add the --no-fork, as by default it is set to fork=true.
187
187
 
188
- Chef::Log.info "Starting #{Chef::Dist::CLIENT} in a new process"
188
+ Chef::Log.info "Starting #{ChefUtils::Dist::Infra::CLIENT} in a new process"
189
189
  # Pass config params to the new process
190
190
  config_params = " --no-fork"
191
191
  config_params += " -c #{Chef::Config[:config_file]}" unless Chef::Config[:config_file].nil?
@@ -197,20 +197,20 @@ class Chef
197
197
  # Starts a new process and waits till the process exits
198
198
 
199
199
  result = shell_out(
200
- "#{Chef::Dist::CLIENT}.bat #{config_params}",
200
+ "#{ChefUtils::Dist::Infra::CLIENT}.bat #{config_params}",
201
201
  timeout: Chef::Config[:windows_service][:watchdog_timeout],
202
202
  logger: Chef::Log
203
203
  )
204
204
  Chef::Log.trace (result.stdout).to_s
205
205
  Chef::Log.trace (result.stderr).to_s
206
206
  rescue Mixlib::ShellOut::CommandTimeout => e
207
- Chef::Log.error "#{Chef::Dist::CLIENT} timed out\n(#{e})"
207
+ Chef::Log.error "#{ChefUtils::Dist::Infra::CLIENT} timed out\n(#{e})"
208
208
  Chef::Log.error(<<-EOF)
209
- Your #{Chef::Dist::CLIENT} run timed out. You can increase the time #{Chef::Dist::CLIENT} is given
209
+ Your #{ChefUtils::Dist::Infra::CLIENT} run timed out. You can increase the time #{ChefUtils::Dist::Infra::CLIENT} is given
210
210
  to complete by configuring windows_service.watchdog_timeout in your client.rb.
211
211
  EOF
212
212
  rescue Mixlib::ShellOut::ShellCommandFailed => e
213
- Chef::Log.warn "Not able to start #{Chef::Dist::CLIENT} in new process (#{e})"
213
+ Chef::Log.warn "Not able to start #{ChefUtils::Dist::Infra::CLIENT} in new process (#{e})"
214
214
  rescue => e
215
215
  Chef::Log.error e
216
216
  ensure
@@ -21,7 +21,7 @@ if RUBY_PLATFORM.match?(/mswin|mingw32|windows/)
21
21
  end
22
22
  require_relative "../config"
23
23
  require "mixlib/cli" unless defined?(Mixlib::CLI)
24
- require_relative "../dist"
24
+ require "chef-utils/dist" unless defined?(ChefUtils::Dist)
25
25
 
26
26
  class Chef
27
27
  class Application
@@ -41,18 +41,18 @@ class Chef
41
41
  short: "-a ACTION",
42
42
  long: "--action ACTION",
43
43
  default: "status",
44
- description: "Action to carry out on #{Chef::Dist::SHORT}-service (install, uninstall, status, start, stop, pause, or resume)."
44
+ description: "Action to carry out on #{ChefUtils::Dist::Infra::SHORT}-service (install, uninstall, status, start, stop, pause, or resume)."
45
45
 
46
46
  option :config_file,
47
47
  short: "-c CONFIG",
48
48
  long: "--config CONFIG",
49
49
  default: "#{ChefConfig::Config.c_chef_dir}/client.rb",
50
- description: "The configuration file to use for #{Chef::Dist::PRODUCT} runs."
50
+ description: "The configuration file to use for #{ChefUtils::Dist::Infra::PRODUCT} runs."
51
51
 
52
52
  option :log_location,
53
53
  short: "-L LOGLOCATION",
54
54
  long: "--logfile LOGLOCATION",
55
- description: "Set the log file location for #{Chef::Dist::SHORT}-service."
55
+ description: "Set the log file location for #{ChefUtils::Dist::Infra::SHORT}-service."
56
56
 
57
57
  option :help,
58
58
  short: "-h",
@@ -66,9 +66,9 @@ class Chef
66
66
  option :version,
67
67
  short: "-v",
68
68
  long: "--version",
69
- description: "Show #{Chef::Dist::PRODUCT} version.",
69
+ description: "Show #{ChefUtils::Dist::Infra::PRODUCT} version.",
70
70
  boolean: true,
71
- proc: lambda { |v| puts "#{Chef::Dist::PRODUCT}: #{::Chef::VERSION}" },
71
+ proc: lambda { |v| puts "#{ChefUtils::Dist::Infra::PRODUCT}: #{::Chef::VERSION}" },
72
72
  exit: 0
73
73
 
74
74
  def initialize(service_options)
@@ -32,7 +32,6 @@ require_relative "platform/provider_handler_map"
32
32
  require_relative "platform/resource_handler_map"
33
33
  require_relative "deprecated"
34
34
  require_relative "event_dispatch/dsl"
35
- require_relative "deprecated"
36
35
 
37
36
  class Chef
38
37
  class << self
@@ -172,11 +172,11 @@ class Chef
172
172
  @memory_store.create_dir(path, name, *options)
173
173
  else
174
174
  with_parent_dir(path + [name], *options) do |parent, name|
175
- begin
176
- parent.create_child(name, nil)
177
- rescue Chef::ChefFS::FileSystem::AlreadyExistsError => e
178
- raise ChefZero::DataStore::DataAlreadyExistsError.new(to_zero_path(e.entry), e)
179
- end
175
+
176
+ parent.create_child(name, nil)
177
+ rescue Chef::ChefFS::FileSystem::AlreadyExistsError => e
178
+ raise ChefZero::DataStore::DataAlreadyExistsError.new(to_zero_path(e.entry), e)
179
+
180
180
  end
181
181
  end
182
182
  end
@@ -251,11 +251,11 @@ class Chef
251
251
  end
252
252
 
253
253
  with_parent_dir(path + [name], *options) do |parent, name|
254
- begin
255
- parent.create_child(name, data)
256
- rescue Chef::ChefFS::FileSystem::AlreadyExistsError => e
257
- raise ChefZero::DataStore::DataAlreadyExistsError.new(to_zero_path(e.entry), e)
258
- end
254
+
255
+ parent.create_child(name, data)
256
+ rescue Chef::ChefFS::FileSystem::AlreadyExistsError => e
257
+ raise ChefZero::DataStore::DataAlreadyExistsError.new(to_zero_path(e.entry), e)
258
+
259
259
  end
260
260
  end
261
261
  end
@@ -349,11 +349,11 @@ class Chef
349
349
 
350
350
  else
351
351
  with_entry(path) do |entry|
352
- begin
353
- entry.read
354
- rescue Chef::ChefFS::FileSystem::NotFoundError => e
355
- raise ChefZero::DataStore::DataNotFoundError.new(to_zero_path(e.entry), e)
356
- end
352
+
353
+ entry.read
354
+ rescue Chef::ChefFS::FileSystem::NotFoundError => e
355
+ raise ChefZero::DataStore::DataNotFoundError.new(to_zero_path(e.entry), e)
356
+
357
357
  end
358
358
  end
359
359
  end
@@ -433,15 +433,15 @@ class Chef
433
433
 
434
434
  else
435
435
  with_entry(path) do |entry|
436
- begin
437
- if %w{cookbooks cookbook_artifacts}.include?(path[0]) && path.length >= 3
438
- entry.delete(true)
439
- else
440
- entry.delete(false)
441
- end
442
- rescue Chef::ChefFS::FileSystem::NotFoundError => e
443
- raise ChefZero::DataStore::DataNotFoundError.new(to_zero_path(e.entry), e)
436
+
437
+ if %w{cookbooks cookbook_artifacts}.include?(path[0]) && path.length >= 3
438
+ entry.delete(true)
439
+ else
440
+ entry.delete(false)
444
441
  end
442
+ rescue Chef::ChefFS::FileSystem::NotFoundError => e
443
+ raise ChefZero::DataStore::DataNotFoundError.new(to_zero_path(e.entry), e)
444
+
445
445
  end
446
446
  end
447
447
  end
@@ -471,11 +471,11 @@ class Chef
471
471
 
472
472
  else
473
473
  with_entry(path) do |entry|
474
- begin
475
- entry.delete(options.include?(:recursive))
476
- rescue Chef::ChefFS::FileSystem::NotFoundError => e
477
- raise ChefZero::DataStore::DataNotFoundError.new(to_zero_path(e.entry), e)
478
- end
474
+
475
+ entry.delete(options.include?(:recursive))
476
+ rescue Chef::ChefFS::FileSystem::NotFoundError => e
477
+ raise ChefZero::DataStore::DataNotFoundError.new(to_zero_path(e.entry), e)
478
+
479
479
  end
480
480
  end
481
481
  end
@@ -487,11 +487,11 @@ class Chef
487
487
  # LIST /policies
488
488
  elsif path == [ "policies" ]
489
489
  with_entry([ path[0] ]) do |policies|
490
- begin
491
- policies.children.map { |policy| policy.name[0..-6].rpartition("-")[0] }.uniq
492
- rescue Chef::ChefFS::FileSystem::NotFoundError
493
- []
494
- end
490
+
491
+ policies.children.map { |policy| policy.name[0..-6].rpartition("-")[0] }.uniq
492
+ rescue Chef::ChefFS::FileSystem::NotFoundError
493
+ []
494
+
495
495
  end
496
496
 
497
497
  # LIST /policies/POLICY/revisions
@@ -524,19 +524,19 @@ class Chef
524
524
 
525
525
  elsif %w{cookbooks cookbook_artifacts}.include?(path[0]) && path.length == 1
526
526
  with_entry(path) do |entry|
527
- begin
528
- if path[0] == "cookbook_artifacts"
529
- entry.children.map { |child| child.name.rpartition("-")[0] }.uniq
530
- elsif chef_fs.versioned_cookbooks
531
- # /cookbooks/name-version -> /cookbooks/name
532
- entry.children.map { |child| split_name_version(child.name)[0] }.uniq
533
- else
534
- entry.children.map(&:name)
535
- end
536
- rescue Chef::ChefFS::FileSystem::NotFoundError
537
- # If the cookbooks dir doesn't exist, we have no cookbooks (not 404)
538
- []
527
+
528
+ if path[0] == "cookbook_artifacts"
529
+ entry.children.map { |child| child.name.rpartition("-")[0] }.uniq
530
+ elsif chef_fs.versioned_cookbooks
531
+ # /cookbooks/name-version -> /cookbooks/name
532
+ entry.children.map { |child| split_name_version(child.name)[0] }.uniq
533
+ else
534
+ entry.children.map(&:name)
539
535
  end
536
+ rescue Chef::ChefFS::FileSystem::NotFoundError
537
+ # If the cookbooks dir doesn't exist, we have no cookbooks (not 404)
538
+ []
539
+
540
540
  end
541
541
 
542
542
  elsif %w{cookbooks cookbook_artifacts}.include?(path[0]) && path.length == 2
@@ -560,16 +560,16 @@ class Chef
560
560
 
561
561
  else
562
562
  result = with_entry(path) do |entry|
563
- begin
564
- entry.children.map { |c| zero_filename(c) }.sort
565
- rescue Chef::ChefFS::FileSystem::NotFoundError => e
566
- # /cookbooks, /data, etc. never return 404
567
- if path_always_exists?(path)
568
- []
569
- else
570
- raise ChefZero::DataStore::DataNotFoundError.new(to_zero_path(e.entry), e)
571
- end
563
+
564
+ entry.children.map { |c| zero_filename(c) }.sort
565
+ rescue Chef::ChefFS::FileSystem::NotFoundError => e
566
+ # /cookbooks, /data, etc. never return 404
567
+ if path_always_exists?(path)
568
+ []
569
+ else
570
+ raise ChefZero::DataStore::DataNotFoundError.new(to_zero_path(e.entry), e)
572
571
  end
572
+
573
573
  end
574
574
 
575
575
  # Older versions of chef-zero do not understand policies and cookbook_artifacts,