chef 16.10.8 → 17.0.242

Sign up to get free protection for your applications and to get access to all the features.
Files changed (618) hide show
  1. checksums.yaml +4 -4
  2. data/Gemfile +9 -10
  3. data/README.md +1 -1
  4. data/Rakefile +13 -2
  5. data/chef-universal-mingw32.gemspec +1 -1
  6. data/chef.gemspec +7 -9
  7. data/lib/chef/application/base.rb +1 -1
  8. data/lib/chef/applications.rb +0 -1
  9. data/lib/chef/chef_fs/command_line.rb +5 -2
  10. data/lib/chef/chef_fs/file_system.rb +9 -10
  11. data/lib/chef/client.rb +2 -2
  12. data/lib/chef/compliance/default_attributes.rb +10 -5
  13. data/lib/chef/compliance/fetcher/automate.rb +15 -11
  14. data/lib/chef/compliance/reporter/automate.rb +17 -7
  15. data/lib/chef/compliance/reporter/chef_server_automate.rb +11 -6
  16. data/lib/chef/compliance/reporter/cli.rb +77 -0
  17. data/lib/chef/compliance/reporter/compliance_enforcer.rb +4 -0
  18. data/lib/chef/compliance/reporter/json_file.rb +8 -1
  19. data/lib/chef/compliance/runner.rb +71 -28
  20. data/lib/chef/cookbook/synchronizer.rb +3 -5
  21. data/lib/chef/cookbook_loader.rb +2 -4
  22. data/lib/chef/cookbook_uploader.rb +0 -1
  23. data/lib/chef/data_bag_item.rb +11 -2
  24. data/lib/chef/delayed_evaluator.rb +4 -0
  25. data/lib/chef/deprecated.rb +4 -0
  26. data/lib/chef/dsl/chef_vault.rb +6 -6
  27. data/lib/chef/dsl/reboot_pending.rb +1 -2
  28. data/lib/chef/formatters/error_inspectors/resource_failure_inspector.rb +20 -22
  29. data/lib/chef/group.rb +75 -0
  30. data/lib/chef/mixin/get_source_from_package.rb +1 -1
  31. data/lib/chef/node/attribute.rb +6 -4
  32. data/lib/chef/node/immutable_collections.rb +13 -0
  33. data/lib/chef/node/mixin/deep_merge_cache.rb +11 -7
  34. data/lib/chef/org.rb +3 -2
  35. data/lib/chef/property.rb +18 -0
  36. data/lib/chef/provider.rb +1 -1
  37. data/lib/chef/provider/cron.rb +1 -1
  38. data/lib/chef/provider/execute.rb +2 -1
  39. data/lib/chef/provider/file.rb +2 -2
  40. data/lib/chef/provider/git.rb +5 -7
  41. data/lib/chef/provider/group/groupadd.rb +3 -3
  42. data/lib/chef/provider/group/groupmod.rb +3 -3
  43. data/lib/chef/provider/group/pw.rb +3 -3
  44. data/lib/chef/provider/ifconfig.rb +2 -2
  45. data/lib/chef/provider/link.rb +2 -2
  46. data/lib/chef/provider/mount.rb +12 -7
  47. data/lib/chef/provider/mount/aix.rb +3 -3
  48. data/lib/chef/provider/mount/mount.rb +6 -6
  49. data/lib/chef/provider/mount/windows.rb +1 -1
  50. data/lib/chef/provider/package.rb +17 -21
  51. data/lib/chef/provider/package/apt.rb +27 -1
  52. data/lib/chef/provider/package/deb.rb +3 -3
  53. data/lib/chef/provider/package/dnf/dnf_helper.py +5 -1
  54. data/lib/chef/provider/package/portage.rb +2 -2
  55. data/lib/chef/provider/package/rubygems.rb +11 -17
  56. data/lib/chef/provider/package/windows.rb +2 -4
  57. data/lib/chef/provider/package/yum/yum_helper.py +5 -1
  58. data/lib/chef/provider/route.rb +2 -2
  59. data/lib/chef/provider/service.rb +6 -6
  60. data/lib/chef/provider/service/aixinit.rb +1 -1
  61. data/lib/chef/provider/service/debian.rb +1 -1
  62. data/lib/chef/provider/service/freebsd.rb +15 -21
  63. data/lib/chef/provider/service/macosx.rb +7 -7
  64. data/lib/chef/provider/service/systemd.rb +43 -14
  65. data/lib/chef/provider/service/upstart.rb +2 -13
  66. data/lib/chef/provider/service/windows.rb +12 -12
  67. data/lib/chef/provider/subversion.rb +10 -12
  68. data/lib/chef/provider/systemd_unit.rb +36 -10
  69. data/lib/chef/provider/template/content.rb +2 -6
  70. data/lib/chef/provider/user.rb +2 -2
  71. data/lib/chef/provider/user/dscl.rb +1 -1
  72. data/lib/chef/provider/user/mac.rb +17 -20
  73. data/lib/chef/provider/user/pw.rb +1 -1
  74. data/lib/chef/provider/user/windows.rb +1 -1
  75. data/lib/chef/provider/zypper_repository.rb +2 -2
  76. data/lib/chef/providers.rb +0 -1
  77. data/lib/chef/resource/alternatives.rb +6 -6
  78. data/lib/chef/resource/apt_package.rb +1 -1
  79. data/lib/chef/resource/apt_preference.rb +2 -2
  80. data/lib/chef/resource/apt_repository.rb +6 -6
  81. data/lib/chef/resource/apt_update.rb +3 -2
  82. data/lib/chef/resource/archive_file.rb +2 -3
  83. data/lib/chef/resource/breakpoint.rb +1 -1
  84. data/lib/chef/resource/build_essential.rb +2 -6
  85. data/lib/chef/resource/chef_client_config.rb +2 -2
  86. data/lib/chef/resource/chef_client_cron.rb +5 -5
  87. data/lib/chef/resource/chef_client_launchd.rb +4 -4
  88. data/lib/chef/resource/chef_client_scheduled_task.rb +1 -1
  89. data/lib/chef/resource/chef_client_systemd_timer.rb +2 -2
  90. data/lib/chef/resource/chef_handler.rb +3 -7
  91. data/lib/chef/resource/chef_sleep.rb +1 -1
  92. data/lib/chef/resource/chef_vault_secret.rb +3 -8
  93. data/lib/chef/resource/chocolatey_config.rb +2 -6
  94. data/lib/chef/resource/chocolatey_feature.rb +2 -6
  95. data/lib/chef/resource/chocolatey_source.rb +4 -10
  96. data/lib/chef/resource/cron/_cron_shared.rb +2 -2
  97. data/lib/chef/resource/cron_access.rb +2 -4
  98. data/lib/chef/resource/dmg_package.rb +6 -10
  99. data/lib/chef/resource/dpkg_package.rb +1 -1
  100. data/lib/chef/resource/execute.rb +6 -1
  101. data/lib/chef/resource/file.rb +1 -1
  102. data/lib/chef/resource/group.rb +2 -2
  103. data/lib/chef/resource/homebrew_cask.rb +2 -6
  104. data/lib/chef/resource/homebrew_tap.rb +2 -6
  105. data/lib/chef/resource/hostname.rb +21 -17
  106. data/lib/chef/resource/http_request.rb +1 -1
  107. data/lib/chef/resource/kernel_module.rb +6 -17
  108. data/lib/chef/resource/locale.rb +2 -3
  109. data/lib/chef/resource/lwrp_base.rb +4 -0
  110. data/lib/chef/resource/macos_userdefaults.rb +10 -14
  111. data/lib/chef/resource/mdadm.rb +53 -7
  112. data/lib/chef/resource/mount.rb +2 -1
  113. data/lib/chef/resource/openssl_ec_private_key.rb +2 -2
  114. data/lib/chef/resource/openssl_rsa_private_key.rb +1 -1
  115. data/lib/chef/resource/openssl_x509_certificate.rb +2 -2
  116. data/lib/chef/resource/plist.rb +7 -7
  117. data/lib/chef/resource/powershell_script.rb +1 -1
  118. data/lib/chef/resource/remote_file.rb +1 -1
  119. data/lib/chef/resource/rhsm_errata.rb +16 -1
  120. data/lib/chef/resource/rhsm_errata_level.rb +10 -1
  121. data/lib/chef/resource/rhsm_register.rb +12 -6
  122. data/lib/chef/resource/rhsm_repo.rb +2 -6
  123. data/lib/chef/resource/rhsm_subscription.rb +2 -6
  124. data/lib/chef/resource/scm/git.rb +1 -1
  125. data/lib/chef/resource/sudo.rb +6 -6
  126. data/lib/chef/resource/sysctl.rb +2 -6
  127. data/lib/chef/resource/systemd_unit.rb +2 -2
  128. data/lib/chef/resource/template.rb +1 -1
  129. data/lib/chef/resource/timezone.rb +1 -3
  130. data/lib/chef/resource/user/mac_user.rb +1 -1
  131. data/lib/chef/resource/user_ulimit.rb +2 -2
  132. data/lib/chef/resource/windows_ad_join.rb +2 -6
  133. data/lib/chef/resource/windows_audit_policy.rb +1 -1
  134. data/lib/chef/resource/windows_auto_run.rb +2 -5
  135. data/lib/chef/resource/windows_certificate.rb +207 -73
  136. data/lib/chef/resource/windows_dfs_folder.rb +2 -6
  137. data/lib/chef/resource/windows_dfs_namespace.rb +2 -6
  138. data/lib/chef/resource/windows_dfs_server.rb +1 -3
  139. data/lib/chef/resource/windows_dns_record.rb +2 -6
  140. data/lib/chef/resource/windows_dns_zone.rb +2 -6
  141. data/lib/chef/resource/windows_env.rb +5 -4
  142. data/lib/chef/resource/windows_feature.rb +3 -9
  143. data/lib/chef/resource/windows_feature_dism.rb +2 -6
  144. data/lib/chef/resource/windows_feature_powershell.rb +3 -3
  145. data/lib/chef/resource/windows_firewall_profile.rb +4 -4
  146. data/lib/chef/resource/windows_firewall_rule.rb +2 -5
  147. data/lib/chef/resource/windows_font.rb +2 -4
  148. data/lib/chef/resource/windows_pagefile.rb +2 -6
  149. data/lib/chef/resource/windows_path.rb +2 -2
  150. data/lib/chef/resource/windows_printer.rb +4 -4
  151. data/lib/chef/resource/windows_printer_port.rb +6 -6
  152. data/lib/chef/resource/windows_security_policy.rb +53 -40
  153. data/lib/chef/resource/windows_share.rb +14 -21
  154. data/lib/chef/resource/windows_shortcut.rb +4 -6
  155. data/lib/chef/resource/windows_task.rb +17 -5
  156. data/lib/chef/resource/windows_uac.rb +1 -1
  157. data/lib/chef/resource/windows_user_privilege.rb +4 -4
  158. data/lib/chef/resource/windows_workgroup.rb +1 -2
  159. data/lib/chef/resources.rb +0 -1
  160. data/lib/chef/user.rb +0 -1
  161. data/lib/chef/user_v1.rb +3 -4
  162. data/lib/chef/util/dsc/configuration_generator.rb +1 -0
  163. data/lib/chef/util/dsc/local_configuration_manager.rb +1 -1
  164. data/lib/chef/version.rb +1 -1
  165. data/lib/chef/win32/registry.rb +4 -2
  166. data/spec/data/cookbooks/openldap/libraries/openldap.rb +1 -1
  167. data/spec/data/lwrp/resources/bar.rb +2 -0
  168. data/spec/data/lwrp/resources/buck_passer.rb +1 -0
  169. data/spec/data/lwrp/resources/buck_passer_2.rb +1 -0
  170. data/spec/data/lwrp/resources/embedded_resource_accesses_providers_scope.rb +1 -0
  171. data/spec/data/lwrp/resources/foo.rb +2 -0
  172. data/spec/data/lwrp/resources/inline_compiler.rb +1 -0
  173. data/spec/data/lwrp/resources/monkey_name_printer.rb +1 -0
  174. data/spec/data/lwrp/resources/paint_drying_watcher.rb +1 -0
  175. data/spec/data/lwrp/resources/thumb_twiddler.rb +1 -0
  176. data/spec/data/lwrp/resources_with_default_attributes/nodeattr.rb +2 -0
  177. data/spec/data/lwrp_const_scoping/resources/conflict.rb +1 -0
  178. data/spec/data/lwrp_override/resources/foo.rb +1 -0
  179. data/spec/data/rubygems.org/nonexistent_gem-info +1 -0
  180. data/spec/data/rubygems.org/sexp_processor-info +49 -0
  181. data/spec/data/run_context/cookbooks/circular-dep1/resources/resource.rb +1 -0
  182. data/spec/data/run_context/cookbooks/circular-dep2/resources/resource.rb +1 -0
  183. data/spec/data/run_context/cookbooks/dependency1/resources/resource.rb +1 -0
  184. data/spec/data/run_context/cookbooks/dependency2/resources/resource.rb +1 -0
  185. data/spec/data/run_context/cookbooks/no-default-attr/resources/resource.rb +1 -0
  186. data/spec/data/run_context/cookbooks/test-with-circular-deps/resources/resource.rb +2 -0
  187. data/spec/data/run_context/cookbooks/test-with-deps/resources/resource.rb +1 -0
  188. data/spec/data/run_context/cookbooks/test/resources/resource.rb +2 -0
  189. data/spec/functional/dsl/registry_helper_spec.rb +1 -1
  190. data/spec/functional/resource/aixinit_service_spec.rb +7 -7
  191. data/spec/functional/resource/apt_package_spec.rb +1 -1
  192. data/spec/functional/resource/chocolatey_package_spec.rb +13 -0
  193. data/spec/functional/resource/cron_spec.rb +1 -1
  194. data/spec/functional/resource/dnf_package_spec.rb +4 -1
  195. data/spec/functional/resource/registry_spec.rb +8 -8
  196. data/spec/functional/resource/user/mac_user_spec.rb +2 -2
  197. data/spec/functional/resource/windows_certificate_spec.rb +92 -35
  198. data/spec/functional/version_spec.rb +1 -1
  199. data/spec/functional/win32/registry_spec.rb +1 -1
  200. data/spec/integration/client/client_spec.rb +5 -2
  201. data/spec/integration/client/exit_code_spec.rb +1 -1
  202. data/spec/integration/client/ipv6_spec.rb +1 -1
  203. data/spec/integration/compliance/compliance_spec.rb +3 -2
  204. data/spec/integration/ohai/ohai_spec.rb +7 -6
  205. data/spec/integration/recipes/accumulator_spec.rb +13 -1
  206. data/spec/integration/recipes/lwrp_inline_resources_spec.rb +5 -1
  207. data/spec/integration/recipes/lwrp_spec.rb +3 -1
  208. data/spec/integration/recipes/notifies_spec.rb +15 -1
  209. data/spec/integration/recipes/notifying_block_spec.rb +2 -1
  210. data/spec/integration/recipes/recipe_dsl_spec.rb +9 -9
  211. data/spec/integration/recipes/unified_mode_spec.rb +1 -1
  212. data/spec/integration/recipes/use_partial_spec.rb +4 -1
  213. data/spec/spec_helper.rb +11 -13
  214. data/spec/support/chef_helpers.rb +0 -16
  215. data/spec/support/lib/chef/resource/with_state.rb +0 -1
  216. data/spec/support/lib/chef/resource/zen_follower.rb +0 -1
  217. data/spec/support/lib/chef/resource/zen_master.rb +0 -1
  218. data/spec/support/matchers/leak.rb +7 -9
  219. data/spec/support/platform_helpers.rb +5 -8
  220. data/spec/support/shared/integration/integration_helper.rb +0 -1
  221. data/spec/support/shared/unit/provider/file.rb +14 -0
  222. data/spec/support/shared/unit/script_resource.rb +2 -2
  223. data/spec/unit/application/solo_spec.rb +2 -2
  224. data/spec/unit/chef_fs/diff_spec.rb +1 -1
  225. data/spec/unit/chef_fs/file_system_spec.rb +1 -1
  226. data/spec/unit/compliance/fetcher/automate_spec.rb +5 -13
  227. data/spec/unit/compliance/reporter/automate_spec.rb +26 -2
  228. data/spec/unit/compliance/reporter/chef_server_automate_spec.rb +20 -0
  229. data/spec/unit/compliance/reporter/compliance_enforcer_spec.rb +1 -0
  230. data/spec/unit/compliance/runner_spec.rb +84 -9
  231. data/spec/unit/data_bag_item_spec.rb +1 -6
  232. data/spec/unit/dsl/reboot_pending_spec.rb +2 -2
  233. data/spec/unit/dsl/registry_helper_spec.rb +1 -1
  234. data/spec/unit/lwrp_spec.rb +1 -1
  235. data/spec/unit/mixin/params_validate_spec.rb +4 -3
  236. data/spec/unit/node/attribute_spec.rb +1 -1
  237. data/spec/unit/node_spec.rb +78 -0
  238. data/spec/unit/org_group_spec.rb +45 -0
  239. data/spec/unit/property_spec.rb +23 -22
  240. data/spec/unit/provider/cron_spec.rb +1 -1
  241. data/spec/unit/provider/group/gpasswd_spec.rb +2 -2
  242. data/spec/unit/provider/group/groupmod_spec.rb +2 -2
  243. data/spec/unit/provider/group/pw_spec.rb +2 -2
  244. data/spec/unit/provider/group_spec.rb +1 -1
  245. data/spec/unit/provider/mount/mount_spec.rb +52 -0
  246. data/spec/unit/provider/package/apt_spec.rb +84 -18
  247. data/spec/unit/provider/package/deb_spec.rb +3 -3
  248. data/spec/unit/provider/package/rubygems_spec.rb +21 -33
  249. data/spec/unit/provider/service/arch_service_spec.rb +1 -0
  250. data/spec/unit/provider/service/debian_service_spec.rb +1 -0
  251. data/spec/unit/provider/service/macosx_spec.rb +5 -5
  252. data/spec/unit/provider/service/systemd_service_spec.rb +138 -23
  253. data/spec/unit/provider/service/upstart_service_spec.rb +0 -29
  254. data/spec/unit/provider/service/windows_spec.rb +2 -2
  255. data/spec/unit/provider/subversion_spec.rb +2 -2
  256. data/spec/unit/provider/systemd_unit_spec.rb +79 -60
  257. data/spec/unit/provider/zypper_repository_spec.rb +2 -2
  258. data/spec/unit/provider_spec.rb +0 -8
  259. data/spec/unit/resource/chef_client_cron_spec.rb +8 -8
  260. data/spec/unit/resource/powershell_script_spec.rb +2 -2
  261. data/spec/unit/resource/windows_task_spec.rb +1 -1
  262. data/spec/unit/user_spec.rb +1 -1
  263. data/spec/unit/user_v1_spec.rb +6 -4
  264. data/tasks/rspec.rb +16 -8
  265. metadata +21 -384
  266. data/bin/knife +0 -24
  267. data/lib/chef/application/knife.rb +0 -234
  268. data/lib/chef/application/windows_service.rb +0 -338
  269. data/lib/chef/application/windows_service_manager.rb +0 -205
  270. data/lib/chef/chef_fs/knife.rb +0 -160
  271. data/lib/chef/chef_fs/parallelizer.rb +0 -102
  272. data/lib/chef/chef_fs/parallelizer/flatten_enumerable.rb +0 -35
  273. data/lib/chef/chef_fs/parallelizer/parallel_enumerable.rb +0 -278
  274. data/lib/chef/cookbook_site_streaming_uploader.rb +0 -244
  275. data/lib/chef/knife.rb +0 -665
  276. data/lib/chef/knife/acl_add.rb +0 -57
  277. data/lib/chef/knife/acl_base.rb +0 -183
  278. data/lib/chef/knife/acl_bulk_add.rb +0 -78
  279. data/lib/chef/knife/acl_bulk_remove.rb +0 -83
  280. data/lib/chef/knife/acl_remove.rb +0 -62
  281. data/lib/chef/knife/acl_show.rb +0 -56
  282. data/lib/chef/knife/bootstrap.rb +0 -1192
  283. data/lib/chef/knife/bootstrap/chef_vault_handler.rb +0 -162
  284. data/lib/chef/knife/bootstrap/client_builder.rb +0 -212
  285. data/lib/chef/knife/bootstrap/templates/README.md +0 -11
  286. data/lib/chef/knife/bootstrap/templates/chef-full.erb +0 -242
  287. data/lib/chef/knife/bootstrap/templates/windows-chef-client-msi.erb +0 -278
  288. data/lib/chef/knife/bootstrap/train_connector.rb +0 -336
  289. data/lib/chef/knife/client_bulk_delete.rb +0 -104
  290. data/lib/chef/knife/client_create.rb +0 -101
  291. data/lib/chef/knife/client_delete.rb +0 -62
  292. data/lib/chef/knife/client_edit.rb +0 -52
  293. data/lib/chef/knife/client_key_create.rb +0 -73
  294. data/lib/chef/knife/client_key_delete.rb +0 -80
  295. data/lib/chef/knife/client_key_edit.rb +0 -83
  296. data/lib/chef/knife/client_key_list.rb +0 -73
  297. data/lib/chef/knife/client_key_show.rb +0 -80
  298. data/lib/chef/knife/client_list.rb +0 -41
  299. data/lib/chef/knife/client_reregister.rb +0 -58
  300. data/lib/chef/knife/client_show.rb +0 -48
  301. data/lib/chef/knife/config_get.rb +0 -39
  302. data/lib/chef/knife/config_get_profile.rb +0 -37
  303. data/lib/chef/knife/config_list.rb +0 -139
  304. data/lib/chef/knife/config_list_profiles.rb +0 -37
  305. data/lib/chef/knife/config_show.rb +0 -127
  306. data/lib/chef/knife/config_use.rb +0 -61
  307. data/lib/chef/knife/config_use_profile.rb +0 -47
  308. data/lib/chef/knife/configure.rb +0 -150
  309. data/lib/chef/knife/configure_client.rb +0 -48
  310. data/lib/chef/knife/cookbook_bulk_delete.rb +0 -71
  311. data/lib/chef/knife/cookbook_delete.rb +0 -151
  312. data/lib/chef/knife/cookbook_download.rb +0 -142
  313. data/lib/chef/knife/cookbook_list.rb +0 -47
  314. data/lib/chef/knife/cookbook_metadata.rb +0 -106
  315. data/lib/chef/knife/cookbook_metadata_from_file.rb +0 -49
  316. data/lib/chef/knife/cookbook_show.rb +0 -98
  317. data/lib/chef/knife/cookbook_upload.rb +0 -292
  318. data/lib/chef/knife/core/bootstrap_context.rb +0 -264
  319. data/lib/chef/knife/core/cookbook_scm_repo.rb +0 -159
  320. data/lib/chef/knife/core/formatting_options.rb +0 -49
  321. data/lib/chef/knife/core/gem_glob_loader.rb +0 -138
  322. data/lib/chef/knife/core/generic_presenter.rb +0 -232
  323. data/lib/chef/knife/core/hashed_command_loader.rb +0 -100
  324. data/lib/chef/knife/core/node_editor.rb +0 -130
  325. data/lib/chef/knife/core/node_presenter.rb +0 -133
  326. data/lib/chef/knife/core/object_loader.rb +0 -115
  327. data/lib/chef/knife/core/status_presenter.rb +0 -147
  328. data/lib/chef/knife/core/subcommand_loader.rb +0 -203
  329. data/lib/chef/knife/core/text_formatter.rb +0 -85
  330. data/lib/chef/knife/core/ui.rb +0 -338
  331. data/lib/chef/knife/core/windows_bootstrap_context.rb +0 -406
  332. data/lib/chef/knife/data_bag_create.rb +0 -81
  333. data/lib/chef/knife/data_bag_delete.rb +0 -49
  334. data/lib/chef/knife/data_bag_edit.rb +0 -74
  335. data/lib/chef/knife/data_bag_from_file.rb +0 -113
  336. data/lib/chef/knife/data_bag_list.rb +0 -42
  337. data/lib/chef/knife/data_bag_secret_options.rb +0 -122
  338. data/lib/chef/knife/data_bag_show.rb +0 -69
  339. data/lib/chef/knife/delete.rb +0 -125
  340. data/lib/chef/knife/deps.rb +0 -156
  341. data/lib/chef/knife/diff.rb +0 -83
  342. data/lib/chef/knife/download.rb +0 -84
  343. data/lib/chef/knife/edit.rb +0 -88
  344. data/lib/chef/knife/environment_compare.rb +0 -128
  345. data/lib/chef/knife/environment_create.rb +0 -52
  346. data/lib/chef/knife/environment_delete.rb +0 -44
  347. data/lib/chef/knife/environment_edit.rb +0 -44
  348. data/lib/chef/knife/environment_from_file.rb +0 -84
  349. data/lib/chef/knife/environment_list.rb +0 -41
  350. data/lib/chef/knife/environment_show.rb +0 -47
  351. data/lib/chef/knife/exec.rb +0 -99
  352. data/lib/chef/knife/group_add.rb +0 -55
  353. data/lib/chef/knife/group_create.rb +0 -49
  354. data/lib/chef/knife/group_destroy.rb +0 -53
  355. data/lib/chef/knife/group_list.rb +0 -43
  356. data/lib/chef/knife/group_remove.rb +0 -56
  357. data/lib/chef/knife/group_show.rb +0 -49
  358. data/lib/chef/knife/key_create.rb +0 -112
  359. data/lib/chef/knife/key_create_base.rb +0 -50
  360. data/lib/chef/knife/key_delete.rb +0 -55
  361. data/lib/chef/knife/key_edit.rb +0 -118
  362. data/lib/chef/knife/key_edit_base.rb +0 -55
  363. data/lib/chef/knife/key_list.rb +0 -90
  364. data/lib/chef/knife/key_list_base.rb +0 -45
  365. data/lib/chef/knife/key_show.rb +0 -53
  366. data/lib/chef/knife/list.rb +0 -177
  367. data/lib/chef/knife/node_bulk_delete.rb +0 -75
  368. data/lib/chef/knife/node_create.rb +0 -47
  369. data/lib/chef/knife/node_delete.rb +0 -46
  370. data/lib/chef/knife/node_edit.rb +0 -70
  371. data/lib/chef/knife/node_environment_set.rb +0 -53
  372. data/lib/chef/knife/node_from_file.rb +0 -51
  373. data/lib/chef/knife/node_list.rb +0 -44
  374. data/lib/chef/knife/node_policy_set.rb +0 -79
  375. data/lib/chef/knife/node_run_list_add.rb +0 -104
  376. data/lib/chef/knife/node_run_list_remove.rb +0 -67
  377. data/lib/chef/knife/node_run_list_set.rb +0 -66
  378. data/lib/chef/knife/node_show.rb +0 -63
  379. data/lib/chef/knife/null.rb +0 -12
  380. data/lib/chef/knife/raw.rb +0 -123
  381. data/lib/chef/knife/recipe_list.rb +0 -32
  382. data/lib/chef/knife/rehash.rb +0 -50
  383. data/lib/chef/knife/role_bulk_delete.rb +0 -66
  384. data/lib/chef/knife/role_create.rb +0 -53
  385. data/lib/chef/knife/role_delete.rb +0 -46
  386. data/lib/chef/knife/role_edit.rb +0 -45
  387. data/lib/chef/knife/role_env_run_list_add.rb +0 -87
  388. data/lib/chef/knife/role_env_run_list_clear.rb +0 -55
  389. data/lib/chef/knife/role_env_run_list_remove.rb +0 -57
  390. data/lib/chef/knife/role_env_run_list_replace.rb +0 -60
  391. data/lib/chef/knife/role_env_run_list_set.rb +0 -70
  392. data/lib/chef/knife/role_from_file.rb +0 -51
  393. data/lib/chef/knife/role_list.rb +0 -42
  394. data/lib/chef/knife/role_run_list_add.rb +0 -87
  395. data/lib/chef/knife/role_run_list_clear.rb +0 -55
  396. data/lib/chef/knife/role_run_list_remove.rb +0 -56
  397. data/lib/chef/knife/role_run_list_replace.rb +0 -60
  398. data/lib/chef/knife/role_run_list_set.rb +0 -69
  399. data/lib/chef/knife/role_show.rb +0 -48
  400. data/lib/chef/knife/search.rb +0 -194
  401. data/lib/chef/knife/serve.rb +0 -65
  402. data/lib/chef/knife/show.rb +0 -72
  403. data/lib/chef/knife/ssh.rb +0 -645
  404. data/lib/chef/knife/ssl_check.rb +0 -284
  405. data/lib/chef/knife/ssl_fetch.rb +0 -161
  406. data/lib/chef/knife/status.rb +0 -95
  407. data/lib/chef/knife/supermarket_download.rb +0 -121
  408. data/lib/chef/knife/supermarket_install.rb +0 -192
  409. data/lib/chef/knife/supermarket_list.rb +0 -76
  410. data/lib/chef/knife/supermarket_search.rb +0 -53
  411. data/lib/chef/knife/supermarket_share.rb +0 -166
  412. data/lib/chef/knife/supermarket_show.rb +0 -66
  413. data/lib/chef/knife/supermarket_unshare.rb +0 -61
  414. data/lib/chef/knife/tag_create.rb +0 -52
  415. data/lib/chef/knife/tag_delete.rb +0 -60
  416. data/lib/chef/knife/tag_list.rb +0 -47
  417. data/lib/chef/knife/upload.rb +0 -86
  418. data/lib/chef/knife/user_create.rb +0 -107
  419. data/lib/chef/knife/user_delete.rb +0 -44
  420. data/lib/chef/knife/user_dissociate.rb +0 -42
  421. data/lib/chef/knife/user_edit.rb +0 -52
  422. data/lib/chef/knife/user_invite_add.rb +0 -43
  423. data/lib/chef/knife/user_invite_list.rb +0 -34
  424. data/lib/chef/knife/user_invite_rescind.rb +0 -63
  425. data/lib/chef/knife/user_key_create.rb +0 -73
  426. data/lib/chef/knife/user_key_delete.rb +0 -80
  427. data/lib/chef/knife/user_key_edit.rb +0 -83
  428. data/lib/chef/knife/user_key_list.rb +0 -73
  429. data/lib/chef/knife/user_key_show.rb +0 -80
  430. data/lib/chef/knife/user_list.rb +0 -42
  431. data/lib/chef/knife/user_reregister.rb +0 -59
  432. data/lib/chef/knife/user_show.rb +0 -48
  433. data/lib/chef/knife/xargs.rb +0 -282
  434. data/lib/chef/knife/yaml_convert.rb +0 -91
  435. data/lib/chef/resource/user/dscl_user.rb +0 -35
  436. data/spec/data/knife-home/.chef/plugins/knife/example_home_subcommand.rb +0 -0
  437. data/spec/data/knife-site-subcommands/plugins/knife/example_subcommand.rb +0 -0
  438. data/spec/data/knife_subcommand/test_explicit_category.rb +0 -7
  439. data/spec/data/knife_subcommand/test_name_mapping.rb +0 -4
  440. data/spec/data/knife_subcommand/test_yourself.rb +0 -21
  441. data/spec/functional/knife/configure_spec.rb +0 -33
  442. data/spec/functional/knife/cookbook_delete_spec.rb +0 -156
  443. data/spec/functional/knife/exec_spec.rb +0 -55
  444. data/spec/functional/knife/rehash_spec.rb +0 -39
  445. data/spec/functional/knife/smoke_test.rb +0 -42
  446. data/spec/functional/knife/ssh_spec.rb +0 -352
  447. data/spec/functional/resource/user/dscl_spec.rb +0 -188
  448. data/spec/functional/resource/windows_service_spec.rb +0 -105
  449. data/spec/functional/win32/service_manager_spec.rb +0 -220
  450. data/spec/integration/knife/chef_fs_data_store_spec.rb +0 -557
  451. data/spec/integration/knife/chef_repo_path_spec.rb +0 -962
  452. data/spec/integration/knife/chef_repository_file_system_spec.rb +0 -200
  453. data/spec/integration/knife/chefignore_spec.rb +0 -301
  454. data/spec/integration/knife/client_bulk_delete_spec.rb +0 -131
  455. data/spec/integration/knife/client_create_spec.rb +0 -70
  456. data/spec/integration/knife/client_delete_spec.rb +0 -64
  457. data/spec/integration/knife/client_key_create_spec.rb +0 -66
  458. data/spec/integration/knife/client_key_delete_spec.rb +0 -43
  459. data/spec/integration/knife/client_key_list_spec.rb +0 -61
  460. data/spec/integration/knife/client_key_show_spec.rb +0 -45
  461. data/spec/integration/knife/client_list_spec.rb +0 -49
  462. data/spec/integration/knife/client_show_spec.rb +0 -37
  463. data/spec/integration/knife/common_options_spec.rb +0 -174
  464. data/spec/integration/knife/config_list_spec.rb +0 -220
  465. data/spec/integration/knife/config_show_spec.rb +0 -192
  466. data/spec/integration/knife/config_use_spec.rb +0 -198
  467. data/spec/integration/knife/cookbook_api_ipv6_spec.rb +0 -113
  468. data/spec/integration/knife/cookbook_bulk_delete_spec.rb +0 -65
  469. data/spec/integration/knife/cookbook_download_spec.rb +0 -72
  470. data/spec/integration/knife/cookbook_list_spec.rb +0 -55
  471. data/spec/integration/knife/cookbook_show_spec.rb +0 -149
  472. data/spec/integration/knife/cookbook_upload_spec.rb +0 -128
  473. data/spec/integration/knife/data_bag_create_spec.rb +0 -125
  474. data/spec/integration/knife/data_bag_delete_spec.rb +0 -59
  475. data/spec/integration/knife/data_bag_edit_spec.rb +0 -105
  476. data/spec/integration/knife/data_bag_from_file_spec.rb +0 -116
  477. data/spec/integration/knife/data_bag_list_spec.rb +0 -44
  478. data/spec/integration/knife/data_bag_show_spec.rb +0 -95
  479. data/spec/integration/knife/delete_spec.rb +0 -1018
  480. data/spec/integration/knife/deps_spec.rb +0 -703
  481. data/spec/integration/knife/diff_spec.rb +0 -605
  482. data/spec/integration/knife/download_spec.rb +0 -1336
  483. data/spec/integration/knife/environment_compare_spec.rb +0 -75
  484. data/spec/integration/knife/environment_create_spec.rb +0 -41
  485. data/spec/integration/knife/environment_delete_spec.rb +0 -37
  486. data/spec/integration/knife/environment_from_file_spec.rb +0 -116
  487. data/spec/integration/knife/environment_list_spec.rb +0 -42
  488. data/spec/integration/knife/environment_show_spec.rb +0 -77
  489. data/spec/integration/knife/list_spec.rb +0 -1060
  490. data/spec/integration/knife/node_bulk_delete_spec.rb +0 -52
  491. data/spec/integration/knife/node_create_spec.rb +0 -47
  492. data/spec/integration/knife/node_delete_spec.rb +0 -48
  493. data/spec/integration/knife/node_environment_set_spec.rb +0 -46
  494. data/spec/integration/knife/node_from_file_spec.rb +0 -59
  495. data/spec/integration/knife/node_list_spec.rb +0 -45
  496. data/spec/integration/knife/node_run_list_add_spec.rb +0 -54
  497. data/spec/integration/knife/node_run_list_remove_spec.rb +0 -36
  498. data/spec/integration/knife/node_run_list_set_spec.rb +0 -41
  499. data/spec/integration/knife/node_show_spec.rb +0 -36
  500. data/spec/integration/knife/raw_spec.rb +0 -297
  501. data/spec/integration/knife/redirection_spec.rb +0 -64
  502. data/spec/integration/knife/role_bulk_delete_spec.rb +0 -52
  503. data/spec/integration/knife/role_create_spec.rb +0 -41
  504. data/spec/integration/knife/role_delete_spec.rb +0 -48
  505. data/spec/integration/knife/role_from_file_spec.rb +0 -96
  506. data/spec/integration/knife/role_list_spec.rb +0 -45
  507. data/spec/integration/knife/role_show_spec.rb +0 -51
  508. data/spec/integration/knife/search_node_spec.rb +0 -40
  509. data/spec/integration/knife/serve_spec.rb +0 -92
  510. data/spec/integration/knife/show_spec.rb +0 -197
  511. data/spec/integration/knife/upload_spec.rb +0 -1617
  512. data/spec/support/shared/functional/knife.rb +0 -37
  513. data/spec/support/shared/functional/win32_service.rb +0 -57
  514. data/spec/support/shared/integration/knife_support.rb +0 -192
  515. data/spec/support/shared/unit/knife_shared.rb +0 -39
  516. data/spec/unit/application/knife_spec.rb +0 -241
  517. data/spec/unit/chef_fs/parallelizer_spec.rb +0 -479
  518. data/spec/unit/cookbook_site_streaming_uploader_spec.rb +0 -198
  519. data/spec/unit/knife/bootstrap/chef_vault_handler_spec.rb +0 -152
  520. data/spec/unit/knife/bootstrap/client_builder_spec.rb +0 -207
  521. data/spec/unit/knife/bootstrap/train_connector_spec.rb +0 -244
  522. data/spec/unit/knife/bootstrap_spec.rb +0 -2220
  523. data/spec/unit/knife/client_bulk_delete_spec.rb +0 -166
  524. data/spec/unit/knife/client_create_spec.rb +0 -169
  525. data/spec/unit/knife/client_delete_spec.rb +0 -99
  526. data/spec/unit/knife/client_edit_spec.rb +0 -53
  527. data/spec/unit/knife/client_list_spec.rb +0 -34
  528. data/spec/unit/knife/client_reregister_spec.rb +0 -62
  529. data/spec/unit/knife/client_show_spec.rb +0 -52
  530. data/spec/unit/knife/configure_client_spec.rb +0 -81
  531. data/spec/unit/knife/configure_spec.rb +0 -190
  532. data/spec/unit/knife/cookbook_bulk_delete_spec.rb +0 -87
  533. data/spec/unit/knife/cookbook_delete_spec.rb +0 -239
  534. data/spec/unit/knife/cookbook_download_spec.rb +0 -255
  535. data/spec/unit/knife/cookbook_list_spec.rb +0 -88
  536. data/spec/unit/knife/cookbook_metadata_from_file_spec.rb +0 -72
  537. data/spec/unit/knife/cookbook_metadata_spec.rb +0 -182
  538. data/spec/unit/knife/cookbook_show_spec.rb +0 -253
  539. data/spec/unit/knife/cookbook_upload_spec.rb +0 -364
  540. data/spec/unit/knife/core/bootstrap_context_spec.rb +0 -287
  541. data/spec/unit/knife/core/cookbook_scm_repo_spec.rb +0 -187
  542. data/spec/unit/knife/core/gem_glob_loader_spec.rb +0 -209
  543. data/spec/unit/knife/core/hashed_command_loader_spec.rb +0 -112
  544. data/spec/unit/knife/core/node_editor_spec.rb +0 -211
  545. data/spec/unit/knife/core/object_loader_spec.rb +0 -81
  546. data/spec/unit/knife/core/status_presenter_spec.rb +0 -54
  547. data/spec/unit/knife/core/subcommand_loader_spec.rb +0 -64
  548. data/spec/unit/knife/core/ui_spec.rb +0 -656
  549. data/spec/unit/knife/core/windows_bootstrap_context_spec.rb +0 -238
  550. data/spec/unit/knife/data_bag_create_spec.rb +0 -175
  551. data/spec/unit/knife/data_bag_edit_spec.rb +0 -126
  552. data/spec/unit/knife/data_bag_from_file_spec.rb +0 -174
  553. data/spec/unit/knife/data_bag_secret_options_spec.rb +0 -173
  554. data/spec/unit/knife/data_bag_show_spec.rb +0 -139
  555. data/spec/unit/knife/environment_compare_spec.rb +0 -112
  556. data/spec/unit/knife/environment_create_spec.rb +0 -91
  557. data/spec/unit/knife/environment_delete_spec.rb +0 -71
  558. data/spec/unit/knife/environment_edit_spec.rb +0 -79
  559. data/spec/unit/knife/environment_from_file_spec.rb +0 -90
  560. data/spec/unit/knife/environment_list_spec.rb +0 -54
  561. data/spec/unit/knife/environment_show_spec.rb +0 -52
  562. data/spec/unit/knife/key_create_spec.rb +0 -223
  563. data/spec/unit/knife/key_delete_spec.rb +0 -133
  564. data/spec/unit/knife/key_edit_spec.rb +0 -264
  565. data/spec/unit/knife/key_helper.rb +0 -74
  566. data/spec/unit/knife/key_list_spec.rb +0 -216
  567. data/spec/unit/knife/key_show_spec.rb +0 -126
  568. data/spec/unit/knife/node_bulk_delete_spec.rb +0 -94
  569. data/spec/unit/knife/node_delete_spec.rb +0 -77
  570. data/spec/unit/knife/node_edit_spec.rb +0 -116
  571. data/spec/unit/knife/node_environment_set_spec.rb +0 -61
  572. data/spec/unit/knife/node_from_file_spec.rb +0 -59
  573. data/spec/unit/knife/node_list_spec.rb +0 -62
  574. data/spec/unit/knife/node_policy_set_spec.rb +0 -122
  575. data/spec/unit/knife/node_run_list_add_spec.rb +0 -145
  576. data/spec/unit/knife/node_run_list_remove_spec.rb +0 -106
  577. data/spec/unit/knife/node_run_list_set_spec.rb +0 -115
  578. data/spec/unit/knife/node_show_spec.rb +0 -65
  579. data/spec/unit/knife/raw_spec.rb +0 -43
  580. data/spec/unit/knife/role_bulk_delete_spec.rb +0 -80
  581. data/spec/unit/knife/role_create_spec.rb +0 -80
  582. data/spec/unit/knife/role_delete_spec.rb +0 -67
  583. data/spec/unit/knife/role_edit_spec.rb +0 -77
  584. data/spec/unit/knife/role_env_run_list_add_spec.rb +0 -217
  585. data/spec/unit/knife/role_env_run_list_clear_spec.rb +0 -94
  586. data/spec/unit/knife/role_env_run_list_remove_spec.rb +0 -102
  587. data/spec/unit/knife/role_env_run_list_replace_spec.rb +0 -105
  588. data/spec/unit/knife/role_env_run_list_set_spec.rb +0 -99
  589. data/spec/unit/knife/role_from_file_spec.rb +0 -69
  590. data/spec/unit/knife/role_list_spec.rb +0 -54
  591. data/spec/unit/knife/role_run_list_add_spec.rb +0 -179
  592. data/spec/unit/knife/role_run_list_clear_spec.rb +0 -84
  593. data/spec/unit/knife/role_run_list_remove_spec.rb +0 -92
  594. data/spec/unit/knife/role_run_list_replace_spec.rb +0 -98
  595. data/spec/unit/knife/role_run_list_set_spec.rb +0 -89
  596. data/spec/unit/knife/role_show_spec.rb +0 -59
  597. data/spec/unit/knife/ssh_spec.rb +0 -403
  598. data/spec/unit/knife/ssl_check_spec.rb +0 -256
  599. data/spec/unit/knife/ssl_fetch_spec.rb +0 -222
  600. data/spec/unit/knife/status_spec.rb +0 -112
  601. data/spec/unit/knife/supermarket_download_spec.rb +0 -152
  602. data/spec/unit/knife/supermarket_install_spec.rb +0 -202
  603. data/spec/unit/knife/supermarket_list_spec.rb +0 -70
  604. data/spec/unit/knife/supermarket_search_spec.rb +0 -85
  605. data/spec/unit/knife/supermarket_share_spec.rb +0 -208
  606. data/spec/unit/knife/supermarket_unshare_spec.rb +0 -78
  607. data/spec/unit/knife/tag_create_spec.rb +0 -23
  608. data/spec/unit/knife/tag_delete_spec.rb +0 -25
  609. data/spec/unit/knife/tag_list_spec.rb +0 -23
  610. data/spec/unit/knife/user_create_spec.rb +0 -184
  611. data/spec/unit/knife/user_delete_spec.rb +0 -46
  612. data/spec/unit/knife/user_edit_spec.rb +0 -48
  613. data/spec/unit/knife/user_list_spec.rb +0 -36
  614. data/spec/unit/knife/user_reregister_spec.rb +0 -56
  615. data/spec/unit/knife/user_show_spec.rb +0 -46
  616. data/spec/unit/knife_spec.rb +0 -634
  617. data/spec/unit/provider/user/dscl_spec.rb +0 -699
  618. data/spec/unit/windows_service_spec.rb +0 -118
@@ -45,7 +45,7 @@ class Chef
45
45
  priority_ok = @current_resource.priority == @new_resource.priority
46
46
  end
47
47
  if @current_resource.enabled && priority_ok
48
- logger.trace("#{@new_resource} already enabled - nothing to do")
48
+ logger.debug("#{@new_resource} already enabled - nothing to do")
49
49
  else
50
50
  converge_by("enable service #{@new_resource}") do
51
51
  enable_service
@@ -138,7 +138,7 @@ class Chef
138
138
  priority_ok = @current_resource.priority == new_resource.priority
139
139
  end
140
140
  if current_resource.enabled && priority_ok
141
- logger.trace("#{new_resource} already enabled - nothing to do")
141
+ logger.debug("#{new_resource} already enabled - nothing to do")
142
142
  else
143
143
  converge_by("enable service #{new_resource}") do
144
144
  enable_service
@@ -130,27 +130,21 @@ class Chef
130
130
  # The variable name used in /etc/rc.conf for enabling this service
131
131
  def service_enable_variable_name
132
132
  @service_enable_variable_name ||=
133
- begin
134
- # Look for name="foo" in the shell script @init_command. Use this for determining the variable name in /etc/rc.conf
135
- # corresponding to this service
136
- # For example: to enable the service mysql-server with the init command /usr/local/etc/rc.d/mysql-server, you need
137
- # to set mysql_enable="YES" in /etc/rc.conf$
138
- if init_command
139
- ::File.open(init_command) do |rcscript|
140
- rcscript.each_line do |line|
141
- if line =~ /^name="?(\w+)"?/
142
- return $1 + "_enable"
143
- end
133
+ if init_command
134
+ ::File.open(init_command) do |rcscript|
135
+ rcscript.each_line do |line|
136
+ if line =~ /^name="?(\w+)"?/
137
+ return $1 + "_enable"
144
138
  end
145
139
  end
146
- # some scripts support multiple instances through symlinks such as openvpn.
147
- # We should get the service name from rcvar.
148
- logger.trace("name=\"service\" not found at #{init_command}. falling back to rcvar")
149
- shell_out!("#{init_command} rcvar").stdout[/(\w+_enable)=/, 1]
150
- else
151
- # for why-run mode when the rcd_script is not there yet
152
- new_resource.service_name
153
140
  end
141
+ # some scripts support multiple instances through symlinks such as openvpn.
142
+ # We should get the service name from rcvar.
143
+ logger.trace("name=\"service\" not found at #{init_command}. falling back to rcvar")
144
+ shell_out!("#{init_command} rcvar").stdout[/(\w+_enable)=/, 1]
145
+ else
146
+ # for why-run mode when the rcd_script is not there yet
147
+ new_resource.service_name
154
148
  end
155
149
  end
156
150
 
@@ -161,9 +155,9 @@ class Chef
161
155
  case line
162
156
  when /^#{Regexp.escape(var_name)}="(\w+)"/
163
157
  enabled_state_found!
164
- if $1 =~ /^yes$/i
158
+ if $1.casecmp?("yes")
165
159
  current_resource.enabled true
166
- elsif $1 =~ /^(no|none)$/i
160
+ elsif $1.casecmp?("no") || $1.casecmp?("none")
167
161
  current_resource.enabled false
168
162
  end
169
163
  end
@@ -171,7 +165,7 @@ class Chef
171
165
  end
172
166
 
173
167
  if current_resource.enabled.nil?
174
- logger.trace("#{new_resource.name} enable/disable state unknown")
168
+ logger.debug("#{new_resource.name} enable/disable state unknown")
175
169
  current_resource.enabled false
176
170
  end
177
171
  end
@@ -105,7 +105,7 @@ class Chef
105
105
 
106
106
  def start_service
107
107
  if @current_resource.running
108
- logger.trace("#{@new_resource} already running, not starting")
108
+ logger.debug("#{@new_resource} already running, not starting")
109
109
  else
110
110
  if @new_resource.start_command
111
111
  super
@@ -117,7 +117,7 @@ class Chef
117
117
 
118
118
  def stop_service
119
119
  unless @current_resource.running
120
- logger.trace("#{@new_resource} not running, not stopping")
120
+ logger.debug("#{@new_resource} not running, not stopping")
121
121
  else
122
122
  if @new_resource.stop_command
123
123
  super
@@ -153,7 +153,7 @@ class Chef
153
153
  #
154
154
  def enable_service
155
155
  if @current_resource.enabled
156
- logger.trace("#{@new_resource} already enabled, not enabling")
156
+ logger.debug("#{@new_resource} already enabled, not enabling")
157
157
  else
158
158
  load_service
159
159
  end
@@ -161,7 +161,7 @@ class Chef
161
161
 
162
162
  def disable_service
163
163
  unless @current_resource.enabled
164
- logger.trace("#{@new_resource} not enabled, not disabling")
164
+ logger.debug("#{@new_resource} not enabled, not disabling")
165
165
  else
166
166
  unload_service
167
167
  end
@@ -169,12 +169,12 @@ class Chef
169
169
 
170
170
  def load_service
171
171
  session = @session_type ? "-S #{@session_type} " : ""
172
- cmd = "launchctl load -w " + session + @plist
172
+ cmd = "/bin/launchctl load -w " + session + @plist
173
173
  shell_out_as_user(cmd)
174
174
  end
175
175
 
176
176
  def unload_service
177
- cmd = "launchctl unload -w " + @plist
177
+ cmd = "/bin/launchctl unload -w " + @plist
178
178
  shell_out_as_user(cmd)
179
179
  end
180
180
 
@@ -190,7 +190,7 @@ class Chef
190
190
  def set_service_status
191
191
  return if @plist.nil? || @service_label.to_s.empty?
192
192
 
193
- cmd = "launchctl list #{@service_label}"
193
+ cmd = "/bin/launchctl list #{@service_label}"
194
194
  res = shell_out_as_user(cmd)
195
195
 
196
196
  if res.exitstatus == 0
@@ -76,6 +76,30 @@ class Chef::Provider::Service::Systemd < Chef::Provider::Service::Simple
76
76
  end
77
77
  end
78
78
 
79
+ def systemd_service_status
80
+ @systemd_service_status ||= begin
81
+ # Collect all the status information for a service and returns it at once
82
+ options, args = get_systemctl_options_args
83
+ s = shell_out!(systemctl_path, args, "show", "-p", "UnitFileState", "-p", "ActiveState", new_resource.service_name, options)
84
+ # e.g. /bin/systemctl --system show -p UnitFileState -p ActiveState sshd.service
85
+ # Returns something like:
86
+ # ActiveState=active
87
+ # UnitFileState=enabled
88
+ status = {}
89
+ s.stdout.each_line do |line|
90
+ k, v = line.strip.split("=")
91
+ status[k] = v
92
+ end
93
+
94
+ # Assert requisite keys exist
95
+ unless status.key?("UnitFileState") && status.key?("ActiveState")
96
+ raise Chef::Exceptions::Service, "'#{systemctl_path} show' not reporting status for #{new_resource.service_name}!"
97
+ end
98
+
99
+ status
100
+ end
101
+ end
102
+
79
103
  def get_systemctl_options_args
80
104
  if new_resource.user
81
105
  raise NotImplementedError, "#{new_resource} does not support the user property on a target_mode host (yet)" if Chef::Config.target_mode?
@@ -98,7 +122,7 @@ class Chef::Provider::Service::Systemd < Chef::Provider::Service::Simple
98
122
 
99
123
  def start_service
100
124
  if current_resource.running
101
- logger.trace("#{new_resource} already running, not starting")
125
+ logger.debug("#{new_resource} already running, not starting")
102
126
  else
103
127
  if new_resource.start_command
104
128
  super
@@ -111,7 +135,7 @@ class Chef::Provider::Service::Systemd < Chef::Provider::Service::Simple
111
135
 
112
136
  def stop_service
113
137
  unless current_resource.running
114
- logger.trace("#{new_resource} not running, not stopping")
138
+ logger.debug("#{new_resource} not running, not stopping")
115
139
  else
116
140
  if new_resource.stop_command
117
141
  super
@@ -146,7 +170,7 @@ class Chef::Provider::Service::Systemd < Chef::Provider::Service::Simple
146
170
 
147
171
  def enable_service
148
172
  if current_resource.masked || current_resource.indirect
149
- logger.trace("#{new_resource} cannot be enabled: it is masked or indirect")
173
+ logger.debug("#{new_resource} cannot be enabled: it is masked or indirect")
150
174
  return
151
175
  end
152
176
  options, args = get_systemctl_options_args
@@ -155,7 +179,7 @@ class Chef::Provider::Service::Systemd < Chef::Provider::Service::Simple
155
179
 
156
180
  def disable_service
157
181
  if current_resource.masked || current_resource.indirect
158
- logger.trace("#{new_resource} cannot be disabled: it is masked or indirect")
182
+ logger.debug("#{new_resource} cannot be disabled: it is masked or indirect")
159
183
  return
160
184
  end
161
185
  options, args = get_systemctl_options_args
@@ -173,25 +197,30 @@ class Chef::Provider::Service::Systemd < Chef::Provider::Service::Simple
173
197
  end
174
198
 
175
199
  def is_active?
176
- options, args = get_systemctl_options_args
177
- shell_out(systemctl_path, args, "is-active", new_resource.service_name, "--quiet", **options).exitstatus == 0
200
+ # Note: "activating" is not active (as with type=notify or a oneshot)
201
+ systemd_service_status["ActiveState"] == "active"
178
202
  end
179
203
 
180
204
  def is_enabled?
181
- options, args = get_systemctl_options_args
182
- shell_out(systemctl_path, args, "is-enabled", new_resource.service_name, "--quiet", **options).exitstatus == 0
205
+ # if the service is in sysv compat mode, shellout to determine if enabled
206
+ if systemd_service_status["UnitFileState"] == "bad"
207
+ options, args = get_systemctl_options_args
208
+ return shell_out(systemctl_path, args, "is-enabled", new_resource.service_name, "--quiet", **options).exitstatus == 0
209
+ end
210
+ # See https://github.com/systemd/systemd/blob/master/src/systemctl/systemctl-is-enabled.c
211
+ # Note: enabled-runtime is excluded because this is volatile, and the state of enabled-runtime
212
+ # specifically means that the service is not enabled
213
+ %w{enabled static generated alias indirect}.include?(systemd_service_status["UnitFileState"])
183
214
  end
184
215
 
185
216
  def is_indirect?
186
- options, args = get_systemctl_options_args
187
- s = shell_out(systemctl_path, args, "is-enabled", new_resource.service_name, **options)
188
- s.stdout.include?("indirect")
217
+ systemd_service_status["UnitFileState"] == "indirect"
189
218
  end
190
219
 
191
220
  def is_masked?
192
- options, args = get_systemctl_options_args
193
- s = shell_out(systemctl_path, args, "is-enabled", new_resource.service_name, **options)
194
- s.exitstatus != 0 && s.stdout.include?("masked")
221
+ # Note: masked-runtime is excluded, because runtime is volatile, and
222
+ # because masked-runtime is not masked.
223
+ systemd_service_status["UnitFileState"] == "masked"
195
224
  end
196
225
 
197
226
  private
@@ -28,10 +28,6 @@ class Chef
28
28
  # to maintain a local state of service across restart's internal calls
29
29
  attr_accessor :upstart_service_running
30
30
 
31
- provides :service, platform_family: "debian", override: true do
32
- upstart?
33
- end
34
-
35
31
  UPSTART_STATE_FORMAT = %r{\S+ \(?(start|stop)?\)? ?[/ ](\w+)}.freeze
36
32
 
37
33
  # Returns true if the configs for the service name has upstart variable
@@ -65,15 +61,8 @@ class Chef
65
61
  end
66
62
  end
67
63
 
68
- platform, version = Chef::Platform.find_platform_and_version(run_context.node)
69
- if platform == "ubuntu" && (8.04..9.04).cover?(version.to_f)
70
- @upstart_job_dir = "/etc/event.d"
71
- @upstart_conf_suffix = ""
72
- else
73
- @upstart_job_dir = "/etc/init"
74
- @upstart_conf_suffix = ".conf"
75
- end
76
-
64
+ @upstart_job_dir = "/etc/init"
65
+ @upstart_conf_suffix = ".conf"
77
66
  @command_success = true # new_resource.status_command= false, means upstart used
78
67
  @config_file_found = true
79
68
  @upstart_command_success = true
@@ -85,7 +85,7 @@ class Chef::Provider::Service::Windows < Chef::Provider::Service
85
85
 
86
86
  state = current_state
87
87
  if state == RUNNING
88
- logger.trace "#{@new_resource} already started - nothing to do"
88
+ logger.debug "#{@new_resource} already started - nothing to do"
89
89
  elsif state == START_PENDING
90
90
  logger.trace "#{@new_resource} already sent start signal - waiting for start"
91
91
  wait_for_state(RUNNING)
@@ -114,7 +114,7 @@ class Chef::Provider::Service::Windows < Chef::Provider::Service
114
114
  raise Chef::Exceptions::Service, "Service #{@new_resource} can't be started from state [#{state}]"
115
115
  end
116
116
  else
117
- logger.trace "#{@new_resource} does not exist - nothing to do"
117
+ logger.debug "#{@new_resource} does not exist - nothing to do"
118
118
  end
119
119
  end
120
120
 
@@ -133,7 +133,7 @@ class Chef::Provider::Service::Windows < Chef::Provider::Service
133
133
  end
134
134
  @new_resource.updated_by_last_action(true)
135
135
  elsif state == STOPPED
136
- logger.trace "#{@new_resource} already stopped - nothing to do"
136
+ logger.debug "#{@new_resource} already stopped - nothing to do"
137
137
  elsif state == STOP_PENDING
138
138
  logger.trace "#{@new_resource} already sent stop signal - waiting for stop"
139
139
  wait_for_state(STOPPED)
@@ -141,7 +141,7 @@ class Chef::Provider::Service::Windows < Chef::Provider::Service
141
141
  raise Chef::Exceptions::Service, "Service #{@new_resource} can't be stopped from state [#{state}]"
142
142
  end
143
143
  else
144
- logger.trace "#{@new_resource} does not exist - nothing to do"
144
+ logger.debug "#{@new_resource} does not exist - nothing to do"
145
145
  end
146
146
  end
147
147
 
@@ -156,7 +156,7 @@ class Chef::Provider::Service::Windows < Chef::Provider::Service
156
156
  end
157
157
  @new_resource.updated_by_last_action(true)
158
158
  else
159
- logger.trace "#{@new_resource} does not exist - nothing to do"
159
+ logger.debug "#{@new_resource} does not exist - nothing to do"
160
160
  end
161
161
  end
162
162
 
@@ -164,7 +164,7 @@ class Chef::Provider::Service::Windows < Chef::Provider::Service
164
164
  if Win32::Service.exists?(@new_resource.service_name)
165
165
  set_startup_type(:automatic)
166
166
  else
167
- logger.trace "#{@new_resource} does not exist - nothing to do"
167
+ logger.debug "#{@new_resource} does not exist - nothing to do"
168
168
  end
169
169
  end
170
170
 
@@ -172,13 +172,13 @@ class Chef::Provider::Service::Windows < Chef::Provider::Service
172
172
  if Win32::Service.exists?(@new_resource.service_name)
173
173
  set_startup_type(:disabled)
174
174
  else
175
- logger.trace "#{@new_resource} does not exist - nothing to do"
175
+ logger.debug "#{@new_resource} does not exist - nothing to do"
176
176
  end
177
177
  end
178
178
 
179
179
  action :create do
180
180
  if Win32::Service.exists?(new_resource.service_name)
181
- logger.trace "#{new_resource} already exists - nothing to do"
181
+ logger.debug "#{new_resource} already exists - nothing to do"
182
182
  return
183
183
  end
184
184
 
@@ -191,7 +191,7 @@ class Chef::Provider::Service::Windows < Chef::Provider::Service
191
191
 
192
192
  action :delete do
193
193
  unless Win32::Service.exists?(new_resource.service_name)
194
- logger.trace "#{new_resource} does not exist - nothing to do"
194
+ logger.debug "#{new_resource} does not exist - nothing to do"
195
195
  return
196
196
  end
197
197
 
@@ -222,7 +222,7 @@ class Chef::Provider::Service::Windows < Chef::Provider::Service
222
222
  logger.info("#{@new_resource} enabled")
223
223
  end
224
224
  else
225
- logger.trace("#{@new_resource} already enabled - nothing to do")
225
+ logger.debug("#{@new_resource} already enabled - nothing to do")
226
226
  end
227
227
  load_new_resource_state
228
228
  @new_resource.enabled(true)
@@ -235,7 +235,7 @@ class Chef::Provider::Service::Windows < Chef::Provider::Service
235
235
  logger.info("#{@new_resource} disabled")
236
236
  end
237
237
  else
238
- logger.trace("#{@new_resource} already disabled - nothing to do")
238
+ logger.debug("#{@new_resource} already disabled - nothing to do")
239
239
  end
240
240
  load_new_resource_state
241
241
  @new_resource.enabled(false)
@@ -248,7 +248,7 @@ class Chef::Provider::Service::Windows < Chef::Provider::Service
248
248
  set_startup_type(startup_type)
249
249
  end
250
250
  else
251
- logger.trace("#{@new_resource} startup_type already #{startup_type} - nothing to do")
251
+ logger.debug("#{@new_resource} startup_type already #{startup_type} - nothing to do")
252
252
  end
253
253
 
254
254
  converge_delayed_start
@@ -61,7 +61,7 @@ class Chef
61
61
  shell_out!(checkout_command, run_options)
62
62
  end
63
63
  else
64
- logger.trace "#{new_resource} checkout destination #{new_resource.destination} already exists or is a non-empty directory - nothing to do"
64
+ logger.debug "#{new_resource} checkout destination #{new_resource.destination} already exists or is a non-empty directory - nothing to do"
65
65
  end
66
66
  end
67
67
 
@@ -69,7 +69,7 @@ class Chef
69
69
  if target_dir_non_existent_or_empty?
70
70
  action_force_export
71
71
  else
72
- logger.trace "#{new_resource} export destination #{new_resource.destination} already exists or is a non-empty directory - nothing to do"
72
+ logger.debug "#{new_resource} export destination #{new_resource.destination} already exists or is a non-empty directory - nothing to do"
73
73
  end
74
74
  end
75
75
 
@@ -121,16 +121,14 @@ class Chef
121
121
  # up the revision id by asking the server
122
122
  # If the specified revision is an integer, trust it.
123
123
  def revision_int
124
- @revision_int ||= begin
125
- if /^\d+$/.match?(new_resource.revision)
126
- new_resource.revision
127
- else
128
- command = scm(:info, new_resource.repository, new_resource.svn_info_args, authentication, "-r#{new_resource.revision}")
129
- svn_info = shell_out!(command, run_options(cwd: cwd, returns: [0, 1])).stdout
130
-
131
- extract_revision_info(svn_info)
132
- end
133
- end
124
+ @revision_int ||= if /^\d+$/.match?(new_resource.revision)
125
+ new_resource.revision
126
+ else
127
+ command = scm(:info, new_resource.repository, new_resource.svn_info_args, authentication, "-r#{new_resource.revision}")
128
+ svn_info = shell_out!(command, run_options(cwd: cwd, returns: [0, 1])).stdout
129
+
130
+ extract_revision_info(svn_info)
131
+ end
134
132
  end
135
133
 
136
134
  alias :revision_slug :revision_int
@@ -55,6 +55,26 @@ class Chef
55
55
  end
56
56
  end
57
57
 
58
+ def systemd_unit_status
59
+ @systemd_unit_status ||= begin
60
+ # Collect all the status information for a unit and return it at once
61
+ # This may fail if we are managing a template unit (e.g. with '@'), in which case
62
+ # we just ignore the error because unit status is irrelevant in that case
63
+ s = shell_out(*systemctl_cmd, "show", "-p", "UnitFileState", "-p", "ActiveState", new_resource.unit_name, systemctl_opts)
64
+ # e.g. /bin/systemctl --system show -p UnitFileState -p ActiveState syslog.socket
65
+ # Returns something like:
66
+ # ActiveState=inactive
67
+ # UnitFileState=static
68
+ status = {}
69
+ s.stdout.each_line do |line|
70
+ k, v = line.strip.split("=")
71
+ status[k] = v
72
+ end
73
+
74
+ status
75
+ end
76
+ end
77
+
58
78
  action :create do
59
79
  if current_resource.content != new_resource.to_ini
60
80
  converge_by("creating unit: #{new_resource.unit_name}") do
@@ -87,10 +107,10 @@ class Chef
87
107
 
88
108
  action :enable do
89
109
  if current_resource.static
90
- logger.trace("#{new_resource.unit_name} is a static unit, enabling is a NOP.")
110
+ logger.debug("#{new_resource.unit_name} is a static unit, enabling is a NOP.")
91
111
  end
92
112
  if current_resource.indirect
93
- logger.trace("#{new_resource.unit_name} is an indirect unit, enabling is a NOP.")
113
+ logger.debug("#{new_resource.unit_name} is an indirect unit, enabling is a NOP.")
94
114
  end
95
115
 
96
116
  unless current_resource.enabled || current_resource.static || current_resource.indirect
@@ -103,11 +123,11 @@ class Chef
103
123
 
104
124
  action :disable do
105
125
  if current_resource.static
106
- logger.trace("#{new_resource.unit_name} is a static unit, disabling is a NOP.")
126
+ logger.debug("#{new_resource.unit_name} is a static unit, disabling is a NOP.")
107
127
  end
108
128
 
109
129
  if current_resource.indirect
110
- logger.trace("#{new_resource.unit_name} is an indirect unit, enabling is a NOP.")
130
+ logger.debug("#{new_resource.unit_name} is an indirect unit, enabling is a NOP.")
111
131
  end
112
132
 
113
133
  if current_resource.enabled && !current_resource.static && !current_resource.indirect
@@ -175,7 +195,7 @@ class Chef
175
195
  logger.info("#{new_resource} reloaded")
176
196
  end
177
197
  else
178
- logger.trace("#{new_resource.unit_name} is not active, skipping reload.")
198
+ logger.debug("#{new_resource.unit_name} is not active, skipping reload.")
179
199
  end
180
200
  end
181
201
 
@@ -201,23 +221,29 @@ class Chef
201
221
  end
202
222
 
203
223
  def active?
204
- systemctl_execute("is-active", new_resource.unit_name).exitstatus == 0
224
+ # Note: "activating" is not active (as with type=notify or a oneshot)
225
+ systemd_unit_status["ActiveState"] == "active"
205
226
  end
206
227
 
207
228
  def enabled?
208
- systemctl_execute("is-enabled", new_resource.unit_name).exitstatus == 0
229
+ # See https://github.com/systemd/systemd/blob/master/src/systemctl/systemctl-is-enabled.c
230
+ # Note: enabled-runtime is excluded because this is volatile, and the state of enabled-runtime
231
+ # specifically means that the service is not enabled
232
+ %w{enabled static generated alias indirect}.include?(systemd_unit_status["UnitFileState"])
209
233
  end
210
234
 
211
235
  def masked?
212
- systemctl_execute("status", new_resource.unit_name).stdout.include?("masked")
236
+ # Note: masked-runtime is excluded, because runtime is volatile, and
237
+ # because masked-runtime is not masked.
238
+ systemd_unit_status["UnitFileState"] == "masked"
213
239
  end
214
240
 
215
241
  def static?
216
- systemctl_execute("is-enabled", new_resource.unit_name).stdout.include?("static")
242
+ systemd_unit_status["UnitFileState"] == "static"
217
243
  end
218
244
 
219
245
  def indirect?
220
- systemctl_execute("is-enabled", new_resource.unit_name).stdout.include?("indirect")
246
+ systemd_unit_status["UnitFileState"] == "indirect"
221
247
  end
222
248
 
223
249
  private