chef 12.0.0.alpha.2-x86-mingw32 → 12.0.0.rc.0-x86-mingw32
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- data/CONTRIBUTING.md +9 -0
- data/README.md +1 -1
- data/Rakefile +12 -0
- data/bin/chef-service-manager +1 -1
- data/bin/chef-windows-service +35 -0
- data/distro/common/html/_sources/ctl_chef_server.txt +307 -10
- data/distro/common/html/ctl_chef_client.html +3 -7
- data/distro/common/html/ctl_chef_server.html +609 -41
- data/distro/common/html/ctl_chef_shell.html +2 -2
- data/distro/common/html/ctl_chef_solo.html +1 -1
- data/distro/common/html/index.html +13 -13
- data/distro/common/html/knife.html +10 -10
- data/distro/common/html/knife_bootstrap.html +8 -8
- data/distro/common/html/knife_client.html +12 -12
- data/distro/common/html/knife_common_options.html +7 -7
- data/distro/common/html/knife_configure.html +3 -3
- data/distro/common/html/knife_cookbook.html +19 -19
- data/distro/common/html/knife_cookbook_site.html +28 -28
- data/distro/common/html/knife_data_bag.html +28 -13
- data/distro/common/html/knife_delete.html +2 -2
- data/distro/common/html/knife_deps.html +3 -3
- data/distro/common/html/knife_diff.html +4 -4
- data/distro/common/html/knife_download.html +3 -3
- data/distro/common/html/knife_edit.html +2 -2
- data/distro/common/html/knife_environment.html +14 -14
- data/distro/common/html/knife_exec.html +11 -11
- data/distro/common/html/knife_index_rebuild.html +2 -2
- data/distro/common/html/knife_list.html +3 -3
- data/distro/common/html/knife_node.html +23 -23
- data/distro/common/html/knife_raw.html +4 -4
- data/distro/common/html/knife_recipe_list.html +3 -3
- data/distro/common/html/knife_role.html +11 -11
- data/distro/common/html/knife_search.html +4 -4
- data/distro/common/html/knife_serve.html +3 -3
- data/distro/common/html/knife_show.html +3 -3
- data/distro/common/html/knife_ssh.html +7 -7
- data/distro/common/html/knife_ssl_check.html +7 -7
- data/distro/common/html/knife_ssl_fetch.html +9 -9
- data/distro/common/html/knife_status.html +3 -3
- data/distro/common/html/knife_tag.html +9 -9
- data/distro/common/html/knife_upload.html +3 -3
- data/distro/common/html/knife_user.html +9 -9
- data/distro/common/html/knife_using.html +11 -11
- data/distro/common/html/knife_xargs.html +14 -5
- data/distro/common/html/search.html +2 -2
- data/distro/common/html/searchindex.js +1 -1
- data/distro/common/man/man1/chef-shell.1 +2 -2
- data/distro/common/man/man1/knife-bootstrap.1 +7 -7
- data/distro/common/man/man1/knife-client.1 +10 -10
- data/distro/common/man/man1/knife-configure.1 +5 -5
- data/distro/common/man/man1/knife-cookbook-site.1 +24 -24
- data/distro/common/man/man1/knife-cookbook.1 +12 -12
- data/distro/common/man/man1/knife-data-bag.1 +34 -10
- data/distro/common/man/man1/knife-delete.1 +5 -5
- data/distro/common/man/man1/knife-deps.1 +5 -5
- data/distro/common/man/man1/knife-diff.1 +7 -7
- data/distro/common/man/man1/knife-download.1 +5 -5
- data/distro/common/man/man1/knife-edit.1 +5 -5
- data/distro/common/man/man1/knife-environment.1 +11 -11
- data/distro/common/man/man1/knife-exec.1 +11 -11
- data/distro/common/man/man1/knife-index-rebuild.1 +1 -1
- data/distro/common/man/man1/knife-list.1 +5 -5
- data/distro/common/man/man1/knife-node.1 +16 -16
- data/distro/common/man/man1/knife-raw.1 +6 -6
- data/distro/common/man/man1/knife-recipe-list.1 +1 -1
- data/distro/common/man/man1/knife-role.1 +7 -7
- data/distro/common/man/man1/knife-search.1 +6 -6
- data/distro/common/man/man1/knife-serve.1 +6 -6
- data/distro/common/man/man1/knife-show.1 +5 -5
- data/distro/common/man/man1/knife-ssh.1 +9 -9
- data/distro/common/man/man1/knife-ssl-check.1 +7 -7
- data/distro/common/man/man1/knife-ssl-fetch.1 +9 -9
- data/distro/common/man/man1/knife-status.1 +5 -5
- data/distro/common/man/man1/knife-tag.1 +8 -8
- data/distro/common/man/man1/knife-upload.1 +5 -5
- data/distro/common/man/man1/knife-user.1 +8 -8
- data/distro/common/man/man1/knife-xargs.1 +36 -10
- data/distro/common/man/man1/knife.1 +14 -14
- data/distro/common/man/man8/chef-client.8 +3 -10
- data/distro/common/man/man8/chef-solo.8 +1 -1
- data/ext/win32-eventlog/Rakefile +50 -0
- data/ext/win32-eventlog/chef-log.man +26 -0
- data/lib/chef/application.rb +313 -241
- data/lib/chef/application/apply.rb +10 -8
- data/lib/chef/application/client.rb +58 -33
- data/lib/chef/application/solo.rb +33 -12
- data/lib/chef/chef_fs/chef_fs_data_store.rb +1 -1
- data/lib/chef/chef_fs/command_line.rb +1 -1
- data/lib/chef/chef_fs/file_system/organization_invites_entry.rb +2 -1
- data/lib/chef/chef_fs/file_system/organization_members_entry.rb +2 -1
- data/lib/chef/chef_fs/file_system/rest_list_entry.rb +2 -1
- data/lib/chef/client.rb +18 -48
- data/lib/chef/config.rb +43 -11
- data/lib/chef/cookbook/cookbook_version_loader.rb +14 -7
- data/lib/chef/cookbook/metadata.rb +81 -38
- data/lib/chef/cookbook/syntax_check.rb +18 -52
- data/lib/chef/cookbook_loader.rb +1 -1
- data/lib/chef/cookbook_version.rb +58 -39
- data/lib/chef/data_bag.rb +2 -2
- data/lib/chef/deprecation/provider/file.rb +2 -1
- data/lib/chef/dsl/data_query.rb +2 -29
- data/lib/chef/dsl/recipe.rb +8 -22
- data/lib/chef/encrypted_data_bag_item/assertions.rb +1 -1
- data/lib/chef/encrypted_data_bag_item/check_encrypted.rb +56 -0
- data/lib/chef/encrypted_data_bag_item/encrypted_data_bag_item_assertions.rb +1 -1
- data/lib/chef/event_loggers/base.rb +62 -0
- data/lib/chef/event_loggers/windows_eventlog.rb +104 -0
- data/lib/chef/exceptions.rb +18 -1
- data/lib/chef/file_cache.rb +3 -2
- data/lib/chef/guard_interpreter/resource_guard_interpreter.rb +15 -6
- data/lib/chef/http.rb +20 -13
- data/lib/chef/http/ssl_policies.rb +2 -1
- data/lib/chef/json_compat.rb +9 -3
- data/lib/chef/knife.rb +2 -1
- data/lib/chef/knife/bootstrap.rb +12 -18
- data/lib/chef/knife/bootstrap/archlinux-gems.erb +2 -2
- data/lib/chef/knife/bootstrap/chef-aix.erb +2 -2
- data/lib/chef/knife/bootstrap/chef-full.erb +2 -2
- data/lib/chef/knife/cookbook_create.rb +1 -1
- data/lib/chef/knife/cookbook_site_share.rb +43 -8
- data/lib/chef/knife/core/bootstrap_context.rb +6 -11
- data/lib/chef/knife/core/object_loader.rb +5 -5
- data/lib/chef/knife/core/status_presenter.rb +156 -0
- data/lib/chef/knife/core/subcommand_loader.rb +6 -5
- data/lib/chef/knife/core/ui.rb +4 -4
- data/lib/chef/knife/data_bag_create.rb +7 -32
- data/lib/chef/knife/data_bag_edit.rb +24 -43
- data/lib/chef/knife/data_bag_from_file.rb +6 -31
- data/lib/chef/knife/data_bag_secret_options.rb +142 -0
- data/lib/chef/knife/data_bag_show.rb +19 -33
- data/lib/chef/knife/node_from_file.rb +9 -8
- data/lib/chef/knife/ssh.rb +0 -7
- data/lib/chef/knife/ssl_check.rb +70 -6
- data/lib/chef/knife/status.rb +11 -58
- data/lib/chef/mixin/command/unix.rb +2 -2
- data/lib/chef/mixin/convert_to_class_name.rb +54 -0
- data/lib/chef/mixin/descendants_tracker.rb +82 -0
- data/lib/chef/mixin/homebrew_user.rb +68 -0
- data/lib/chef/mixin/shell_out.rb +0 -4
- data/lib/chef/mixin/windows_architecture_helper.rb +16 -0
- data/lib/chef/mixin/windows_env_helper.rb +56 -0
- data/lib/chef/node.rb +2 -2
- data/lib/chef/node_map.rb +146 -0
- data/lib/chef/platform/provider_mapping.rb +11 -39
- data/lib/chef/platform/provider_priority_map.rb +80 -0
- data/lib/chef/platform/query_helpers.rb +5 -1
- data/lib/chef/platform/service_helpers.rb +113 -0
- data/lib/chef/provider.rb +24 -0
- data/lib/chef/provider/breakpoint.rb +2 -0
- data/lib/chef/provider/cookbook_file.rb +2 -0
- data/lib/chef/provider/cron.rb +1 -1
- data/lib/chef/provider/cron/unix.rb +13 -9
- data/lib/chef/provider/deploy.rb +3 -2
- data/lib/chef/provider/deploy/revision.rb +4 -2
- data/lib/chef/provider/deploy/timestamped.rb +2 -0
- data/lib/chef/provider/directory.rb +2 -0
- data/lib/chef/provider/dsc_script.rb +179 -0
- data/lib/chef/provider/env.rb +25 -10
- data/lib/chef/provider/env/windows.rb +9 -16
- data/lib/chef/provider/erl_call.rb +2 -0
- data/lib/chef/provider/execute.rb +5 -2
- data/lib/chef/provider/file.rb +2 -0
- data/lib/chef/provider/git.rb +51 -23
- data/lib/chef/provider/group/dscl.rb +2 -2
- data/lib/chef/provider/group/pw.rb +9 -13
- data/lib/chef/provider/http_request.rb +2 -0
- data/lib/chef/provider/link.rb +3 -0
- data/lib/chef/provider/log.rb +2 -0
- data/lib/chef/provider/lwrp_base.rb +11 -9
- data/lib/chef/provider/mount/mount.rb +1 -1
- data/lib/chef/provider/package/aix.rb +2 -0
- data/lib/chef/provider/package/apt.rb +2 -0
- data/lib/chef/provider/package/dpkg.rb +2 -0
- data/lib/chef/provider/package/easy_install.rb +2 -0
- data/lib/chef/provider/package/freebsd/pkg.rb +2 -1
- data/lib/chef/provider/package/freebsd/pkgng.rb +1 -1
- data/lib/chef/provider/package/freebsd/port.rb +1 -9
- data/lib/chef/provider/package/homebrew.rb +127 -0
- data/lib/chef/provider/package/ips.rb +2 -0
- data/lib/chef/provider/package/macports.rb +3 -0
- data/lib/chef/provider/package/pacman.rb +5 -4
- data/lib/chef/provider/package/paludis.rb +4 -2
- data/lib/chef/provider/package/portage.rb +4 -1
- data/lib/chef/provider/package/rpm.rb +2 -0
- data/lib/chef/provider/package/rubygems.rb +4 -0
- data/lib/chef/provider/package/smartos.rb +2 -0
- data/lib/chef/provider/package/solaris.rb +2 -0
- data/lib/chef/provider/package/windows.rb +5 -2
- data/lib/chef/provider/package/yum.rb +2 -0
- data/lib/chef/provider/powershell_script.rb +3 -1
- data/lib/chef/provider/remote_directory.rb +25 -10
- data/lib/chef/provider/route.rb +2 -0
- data/lib/chef/provider/ruby_block.rb +2 -0
- data/lib/chef/provider/script.rb +6 -0
- data/lib/chef/provider/service/aix.rb +128 -0
- data/lib/chef/provider/service/aixinit.rb +117 -0
- data/lib/chef/provider/service/arch.rb +6 -0
- data/lib/chef/provider/service/debian.rb +35 -29
- data/lib/chef/provider/service/freebsd.rb +7 -1
- data/lib/chef/provider/service/gentoo.rb +5 -1
- data/lib/chef/provider/service/init.rb +2 -0
- data/lib/chef/provider/service/insserv.rb +15 -8
- data/lib/chef/provider/service/invokercd.rb +6 -0
- data/lib/chef/provider/service/macosx.rb +4 -1
- data/lib/chef/provider/service/redhat.rb +9 -3
- data/lib/chef/provider/service/simple.rb +2 -0
- data/lib/chef/provider/service/solaris.rb +2 -0
- data/lib/chef/provider/service/systemd.rb +7 -0
- data/lib/chef/provider/service/upstart.rb +7 -0
- data/lib/chef/provider/service/windows.rb +5 -0
- data/lib/chef/provider/subversion.rb +2 -0
- data/lib/chef/provider/template.rb +1 -0
- data/lib/chef/provider/user/dscl.rb +3 -2
- data/lib/chef/provider/whyrun_safe_ruby_block.rb +2 -0
- data/lib/chef/provider_resolver.rb +103 -0
- data/lib/chef/providers.rb +6 -2
- data/lib/chef/recipe.rb +2 -0
- data/lib/chef/resource.rb +69 -78
- data/lib/chef/resource/apt_package.rb +3 -1
- data/lib/chef/resource/bash.rb +1 -0
- data/lib/chef/resource/bff_package.rb +0 -1
- data/lib/chef/resource/breakpoint.rb +1 -1
- data/lib/chef/resource/chef_gem.rb +1 -2
- data/lib/chef/resource/conditional.rb +26 -6
- data/lib/chef/resource/cookbook_file.rb +2 -3
- data/lib/chef/resource/csh.rb +1 -0
- data/lib/chef/resource/deploy.rb +0 -1
- data/lib/chef/resource/deploy_revision.rb +6 -1
- data/lib/chef/resource/directory.rb +1 -2
- data/lib/chef/resource/dpkg_package.rb +2 -1
- data/lib/chef/resource/dsc_script.rb +125 -0
- data/lib/chef/resource/easy_install_package.rb +2 -1
- data/lib/chef/resource/erl_call.rb +1 -0
- data/lib/chef/resource/execute.rb +26 -9
- data/lib/chef/resource/file.rb +1 -3
- data/lib/chef/resource/freebsd_package.rb +10 -23
- data/lib/chef/resource/gem_package.rb +2 -1
- data/lib/chef/resource/git.rb +2 -1
- data/lib/chef/resource/homebrew_package.rb +46 -0
- data/lib/chef/resource/http_request.rb +1 -0
- data/lib/chef/resource/ips_package.rb +3 -1
- data/lib/chef/resource/link.rb +1 -2
- data/lib/chef/resource/log.rb +4 -0
- data/lib/chef/resource/lwrp_base.rb +24 -15
- data/lib/chef/resource/macports_package.rb +3 -1
- data/lib/chef/resource/pacman_package.rb +2 -1
- data/lib/chef/resource/paludis_package.rb +3 -1
- data/lib/chef/resource/perl.rb +1 -0
- data/lib/chef/resource/powershell_script.rb +0 -2
- data/lib/chef/resource/python.rb +1 -1
- data/lib/chef/resource/remote_directory.rb +1 -2
- data/lib/chef/resource/remote_file.rb +1 -1
- data/lib/chef/resource/rpm_package.rb +2 -1
- data/lib/chef/resource/ruby.rb +1 -0
- data/lib/chef/resource/ruby_block.rb +3 -0
- data/lib/chef/resource/script.rb +2 -25
- data/lib/chef/resource/service.rb +0 -4
- data/lib/chef/resource/smartos_package.rb +3 -4
- data/lib/chef/resource/solaris_package.rb +7 -1
- data/lib/chef/resource/subversion.rb +0 -1
- data/lib/chef/resource/template.rb +2 -3
- data/lib/chef/resource/timestamped_deploy.rb +1 -2
- data/lib/chef/resource/whyrun_safe_ruby_block.rb +0 -1
- data/lib/chef/resource/windows_package.rb +3 -4
- data/lib/chef/resource/windows_script.rb +3 -0
- data/lib/chef/resource/windows_service.rb +2 -2
- data/lib/chef/resource/yum_package.rb +3 -1
- data/lib/chef/resource_collection.rb +50 -227
- data/lib/chef/resource_collection/resource_collection_serialization.rb +59 -0
- data/lib/chef/resource_collection/resource_list.rb +89 -0
- data/lib/chef/resource_collection/resource_set.rb +170 -0
- data/lib/chef/resources.rb +2 -0
- data/lib/chef/role.rb +1 -1
- data/lib/chef/run_context.rb +5 -1
- data/lib/chef/shell/ext.rb +1 -1
- data/lib/chef/util/backup.rb +3 -2
- data/lib/chef/util/dsc/configuration_generator.rb +115 -0
- data/lib/chef/util/dsc/lcm_output_parser.rb +133 -0
- data/lib/chef/util/dsc/local_configuration_manager.rb +141 -0
- data/lib/chef/util/dsc/resource_info.rb +26 -0
- data/lib/chef/util/path_helper.rb +12 -0
- data/lib/chef/util/powershell/cmdlet.rb +136 -0
- data/lib/chef/util/powershell/cmdlet_result.rb +46 -0
- data/lib/chef/version.rb +1 -1
- data/lib/chef/win32/api/system.rb +9 -0
- data/lib/chef/win32/version.rb +2 -0
- data/spec/.DS_Store +0 -0
- data/spec/data/.DS_Store +0 -0
- data/spec/data/bootstrap/test-hints.erb +1 -1
- data/spec/data/bootstrap/test.erb +1 -1
- data/spec/data/cb_version_cookbooks/cookbook2/files/test.txt +0 -0
- data/spec/data/cb_version_cookbooks/cookbook2/templates/test.erb +0 -0
- data/spec/data/cookbooks/ignorken/files/default/not_me.rb +2 -0
- data/spec/data/cookbooks/ignorken/templates/ubuntu-12.10/not_me.rb +2 -0
- data/spec/data/cookbooks/openldap/libraries/openldap.rb +4 -0
- data/spec/data/cookbooks/openldap/libraries/openldap/version.rb +3 -0
- data/spec/data/lwrp/.DS_Store +0 -0
- data/spec/data/lwrp/providers/.DS_Store +0 -0
- data/spec/data/lwrp/providers/buck_passer.rb +9 -2
- data/spec/data/lwrp/resources/.DS_Store +0 -0
- data/spec/data/lwrp/resources/foo.rb +3 -2
- data/spec/data/lwrp_override/.DS_Store +0 -0
- data/spec/data/lwrp_override/providers/.DS_Store +0 -0
- data/spec/data/lwrp_override/providers/buck_passer.rb +5 -10
- data/spec/data/lwrp_override/resources/.DS_Store +0 -0
- data/spec/data/lwrp_override/resources/foo.rb +4 -3
- data/spec/functional/assets/chefinittest +34 -0
- data/spec/functional/assets/testchefsubsys +11 -0
- data/spec/functional/dsl/reboot_pending_spec.rb +19 -16
- data/spec/functional/event_loggers/windows_eventlog_spec.rb +82 -0
- data/spec/functional/knife/cookbook_delete_spec.rb +3 -3
- data/spec/functional/knife/exec_spec.rb +1 -1
- data/spec/functional/resource/aix_service_spec.rb +136 -0
- data/spec/functional/resource/aixinit_service_spec.rb +211 -0
- data/spec/functional/resource/base.rb +1 -0
- data/spec/functional/resource/batch_spec.rb +4 -11
- data/spec/functional/resource/cron_spec.rb +7 -1
- data/spec/functional/resource/dsc_script_spec.rb +382 -0
- data/spec/functional/resource/env_spec.rb +54 -0
- data/spec/functional/resource/execute_spec.rb +113 -0
- data/spec/functional/resource/file_spec.rb +2 -0
- data/spec/functional/resource/group_spec.rb +7 -4
- data/spec/functional/resource/powershell_spec.rb +198 -185
- data/spec/functional/resource/rpm_spec.rb +5 -4
- data/spec/functional/resource/user/dscl_spec.rb +2 -1
- data/spec/functional/util/path_helper_spec.rb +37 -0
- data/spec/functional/util/powershell/cmdlet_spec.rb +114 -0
- data/spec/integration/client/client_spec.rb +1 -1
- data/spec/integration/client/ipv6_spec.rb +1 -1
- data/spec/integration/knife/chef_fs_data_store_spec.rb +1 -1
- data/spec/integration/knife/chef_repo_path_spec.rb +1 -1
- data/spec/integration/knife/chef_repository_file_system_spec.rb +1 -1
- data/spec/integration/knife/chefignore_spec.rb +1 -1
- data/spec/integration/knife/common_options_spec.rb +1 -1
- data/spec/integration/knife/cookbook_api_ipv6_spec.rb +2 -2
- data/spec/integration/knife/delete_spec.rb +1 -1
- data/spec/integration/knife/deps_spec.rb +1 -1
- data/spec/integration/knife/diff_spec.rb +1 -1
- data/spec/integration/knife/download_spec.rb +1 -1
- data/spec/integration/knife/list_spec.rb +1 -1
- data/spec/integration/knife/raw_spec.rb +1 -1
- data/spec/integration/knife/redirection_spec.rb +1 -1
- data/spec/integration/knife/serve_spec.rb +1 -1
- data/spec/integration/knife/show_spec.rb +1 -1
- data/spec/integration/knife/upload_spec.rb +4 -3
- data/spec/integration/recipes/lwrp_inline_resources_spec.rb +1 -1
- data/spec/spec_helper.rb +15 -0
- data/spec/support/chef_helpers.rb +1 -0
- data/spec/support/lib/chef/provider/snakeoil.rb +1 -0
- data/spec/support/lib/chef/resource/zen_follower.rb +1 -7
- data/spec/support/platform_helpers.rb +28 -0
- data/spec/support/shared/functional/file_resource.rb +6 -0
- data/spec/support/shared/functional/windows_script.rb +118 -0
- data/spec/support/shared/integration/integration_helper.rb +5 -2
- data/spec/support/shared/matchers/exit_with_code.rb +28 -0
- data/spec/support/shared/matchers/match_environment_variable.rb +17 -0
- data/spec/support/shared/shared_examples.rb +14 -0
- data/spec/support/shared/unit/execute_resource.rb +0 -7
- data/spec/support/shared/unit/resource/static_provider_resolution.rb +71 -0
- data/spec/support/shared/unit/script_resource.rb +1 -1
- data/spec/support/shared/unit/windows_script_resource.rb +35 -2
- data/spec/tiny_server.rb +1 -2
- data/spec/unit/api_client_spec.rb +5 -1
- data/spec/unit/application/{apply.rb → apply_spec.rb} +13 -5
- data/spec/unit/application/client_spec.rb +106 -13
- data/spec/unit/application/solo_spec.rb +25 -1
- data/spec/unit/client_spec.rb +1 -26
- data/spec/unit/config_fetcher_spec.rb +2 -1
- data/spec/unit/config_spec.rb +91 -2
- data/spec/unit/cookbook/cookbook_version_loader_spec.rb +8 -0
- data/spec/unit/cookbook/metadata_spec.rb +43 -6
- data/spec/unit/cookbook/syntax_check_spec.rb +8 -2
- data/spec/unit/cookbook_loader_spec.rb +4 -2
- data/spec/unit/cookbook_version_spec.rb +83 -2
- data/spec/unit/data_bag_item_spec.rb +5 -1
- data/spec/unit/data_bag_spec.rb +6 -1
- data/spec/unit/dsl/data_query_spec.rb +8 -110
- data/spec/unit/encrypted_data_bag_item/check_encrypted_spec.rb +95 -0
- data/spec/unit/encrypted_data_bag_item_spec.rb +16 -23
- data/spec/unit/environment_spec.rb +6 -2
- data/spec/unit/exceptions_spec.rb +6 -0
- data/spec/unit/guard_interpreter/resource_guard_interpreter_spec.rb +16 -15
- data/spec/unit/json_compat_spec.rb +12 -2
- data/spec/unit/knife/bootstrap_spec.rb +16 -63
- data/spec/unit/knife/cookbook_site_share_spec.rb +59 -6
- data/spec/unit/knife/core/bootstrap_context_spec.rb +8 -37
- data/spec/unit/knife/core/subcommand_loader_spec.rb +1 -1
- data/spec/unit/knife/core/ui_spec.rb +28 -0
- data/spec/unit/knife/data_bag_create_spec.rb +63 -71
- data/spec/unit/knife/data_bag_edit_spec.rb +83 -49
- data/spec/unit/knife/data_bag_from_file_spec.rb +104 -126
- data/spec/unit/knife/data_bag_secret_options_spec.rb +165 -0
- data/spec/unit/knife/data_bag_show_spec.rb +74 -72
- data/spec/unit/knife/environment_from_file_spec.rb +3 -2
- data/spec/unit/knife/ssl_check_spec.rb +46 -1
- data/spec/unit/knife/status_spec.rb +1 -2
- data/spec/unit/knife_spec.rb +18 -1
- data/spec/unit/lwrp_spec.rb +29 -8
- data/spec/unit/mixin/homebrew_user_spec.rb +100 -0
- data/spec/unit/node_map_spec.rb +155 -0
- data/spec/unit/node_spec.rb +11 -0
- data/spec/unit/platform/query_helpers_spec.rb +23 -0
- data/spec/unit/platform_spec.rb +23 -0
- data/spec/unit/provider/breakpoint_spec.rb +9 -9
- data/spec/unit/provider/cookbook_file/content_spec.rb +3 -3
- data/spec/unit/provider/cookbook_file_spec.rb +1 -1
- data/spec/unit/provider/cron/unix_spec.rb +78 -60
- data/spec/unit/provider/cron_spec.rb +175 -175
- data/spec/unit/provider/deploy/revision_spec.rb +22 -21
- data/spec/unit/provider/deploy/timestamped_spec.rb +3 -3
- data/spec/unit/provider/deploy_spec.rb +231 -230
- data/spec/unit/provider/directory_spec.rb +55 -55
- data/spec/unit/provider/dsc_script_spec.rb +174 -0
- data/spec/unit/provider/env/windows_spec.rb +70 -34
- data/spec/unit/provider/env_spec.rb +95 -49
- data/spec/unit/provider/erl_call_spec.rb +9 -9
- data/spec/unit/provider/execute_spec.rb +43 -27
- data/spec/unit/provider/file/content_spec.rb +9 -9
- data/spec/unit/provider/file_spec.rb +1 -1
- data/spec/unit/provider/git_spec.rb +221 -159
- data/spec/unit/provider/group/dscl_spec.rb +64 -63
- data/spec/unit/provider/group/gpasswd_spec.rb +14 -14
- data/spec/unit/provider/group/groupadd_spec.rb +33 -33
- data/spec/unit/provider/group/groupmod_spec.rb +23 -23
- data/spec/unit/provider/group/pw_spec.rb +21 -21
- data/spec/unit/provider/group/usermod_spec.rb +20 -20
- data/spec/unit/provider/group/windows_spec.rb +15 -15
- data/spec/unit/provider/group_spec.rb +76 -76
- data/spec/unit/provider/http_request_spec.rb +30 -30
- data/spec/unit/provider/ifconfig/aix_spec.rb +20 -20
- data/spec/unit/provider/ifconfig/debian_spec.rb +25 -9
- data/spec/unit/provider/ifconfig/redhat_spec.rb +13 -13
- data/spec/unit/provider/ifconfig_spec.rb +43 -43
- data/spec/unit/provider/link_spec.rb +60 -60
- data/spec/unit/provider/log_spec.rb +0 -4
- data/spec/unit/provider/mdadm_spec.rb +23 -23
- data/spec/unit/provider/mount/aix_spec.rb +17 -17
- data/spec/unit/provider/mount/mount_spec.rb +115 -119
- data/spec/unit/provider/mount/solaris_spec.rb +72 -72
- data/spec/unit/provider/mount/windows_spec.rb +24 -24
- data/spec/unit/provider/ohai_spec.rb +11 -11
- data/spec/unit/provider/package/aix_spec.rb +34 -34
- data/spec/unit/provider/package/apt_spec.rb +36 -36
- data/spec/unit/provider/package/dpkg_spec.rb +27 -27
- data/spec/unit/provider/package/easy_install_spec.rb +16 -16
- data/spec/unit/provider/package/freebsd/pkg_spec.rb +53 -53
- data/spec/unit/provider/package/freebsd/pkgng_spec.rb +24 -24
- data/spec/unit/provider/package/freebsd/port_spec.rb +45 -35
- data/spec/unit/provider/package/homebrew_spec.rb +266 -0
- data/spec/unit/provider/package/ips_spec.rb +34 -34
- data/spec/unit/provider/package/macports_spec.rb +49 -49
- data/spec/unit/provider/package/pacman_spec.rb +35 -39
- data/spec/unit/provider/package/paludis_spec.rb +20 -20
- data/spec/unit/provider/package/portage_spec.rb +38 -38
- data/spec/unit/provider/package/rpm_spec.rb +29 -29
- data/spec/unit/provider/package/rubygems_spec.rb +284 -270
- data/spec/unit/provider/package/smartos_spec.rb +15 -15
- data/spec/unit/provider/package/solaris_spec.rb +35 -35
- data/spec/unit/provider/package/windows/msi_spec.rb +3 -3
- data/spec/unit/provider/package/windows_spec.rb +6 -6
- data/spec/unit/provider/package/yum_spec.rb +416 -416
- data/spec/unit/provider/package/zypper_spec.rb +47 -47
- data/spec/unit/provider/package_spec.rb +107 -107
- data/spec/unit/provider/powershell_spec.rb +1 -1
- data/spec/unit/provider/registry_key_spec.rb +61 -61
- data/spec/unit/provider/remote_directory_spec.rb +36 -36
- data/spec/unit/provider/remote_file/cache_control_data_spec.rb +24 -24
- data/spec/unit/provider/remote_file/content_spec.rb +45 -45
- data/spec/unit/provider/remote_file/fetcher_spec.rb +9 -9
- data/spec/unit/provider/remote_file/ftp_spec.rb +32 -32
- data/spec/unit/provider/remote_file/http_spec.rb +44 -44
- data/spec/unit/provider/remote_file/local_file_spec.rb +9 -9
- data/spec/unit/provider/remote_file_spec.rb +3 -3
- data/spec/unit/provider/route_spec.rb +63 -63
- data/spec/unit/provider/ruby_block_spec.rb +4 -4
- data/spec/unit/provider/script_spec.rb +12 -12
- data/spec/unit/provider/service/aix_service_spec.rb +181 -0
- data/spec/unit/provider/service/aixinit_service_spec.rb +269 -0
- data/spec/unit/provider/service/arch_service_spec.rb +48 -48
- data/spec/unit/provider/service/debian_service_spec.rb +40 -40
- data/spec/unit/provider/service/gentoo_service_spec.rb +28 -28
- data/spec/unit/provider/service/init_service_spec.rb +39 -39
- data/spec/unit/provider/service/insserv_service_spec.rb +8 -8
- data/spec/unit/provider/service/invokercd_service_spec.rb +35 -35
- data/spec/unit/provider/service/macosx_spec.rb +49 -49
- data/spec/unit/provider/service/redhat_spec.rb +27 -27
- data/spec/unit/provider/service/simple_service_spec.rb +28 -28
- data/spec/unit/provider/service/solaris_smf_service_spec.rb +43 -46
- data/spec/unit/provider/service/systemd_service_spec.rb +63 -63
- data/spec/unit/provider/service/upstart_service_spec.rb +78 -78
- data/spec/unit/provider/service/windows_spec.rb +92 -92
- data/spec/unit/provider/service_spec.rb +40 -40
- data/spec/unit/provider/subversion_spec.rb +80 -80
- data/spec/unit/provider/template/content_spec.rb +9 -9
- data/spec/unit/provider/template_spec.rb +6 -6
- data/spec/unit/provider/user/dscl_spec.rb +170 -167
- data/spec/unit/provider/user/pw_spec.rb +48 -48
- data/spec/unit/provider/user/solaris_spec.rb +8 -8
- data/spec/unit/provider/user/useradd_spec.rb +1 -1
- data/spec/unit/provider/user/windows_spec.rb +26 -26
- data/spec/unit/provider/user_spec.rb +72 -72
- data/spec/unit/provider/whyrun_safe_ruby_block_spec.rb +4 -4
- data/spec/unit/provider_resolver_spec.rb +387 -0
- data/spec/unit/recipe_spec.rb +33 -12
- data/spec/unit/resource/apt_package_spec.rb +10 -13
- data/spec/unit/resource/bash_spec.rb +4 -4
- data/spec/unit/resource/batch_spec.rb +1 -1
- data/spec/unit/resource/breakpoint_spec.rb +11 -7
- data/spec/unit/resource/chef_gem_spec.rb +8 -15
- data/spec/unit/resource/conditional_action_not_nothing_spec.rb +2 -2
- data/spec/unit/resource/conditional_spec.rb +35 -16
- data/spec/unit/resource/cookbook_file_spec.rb +13 -13
- data/spec/unit/resource/cron_spec.rb +37 -37
- data/spec/unit/resource/csh_spec.rb +4 -4
- data/spec/unit/resource/deploy_revision_spec.rb +13 -18
- data/spec/unit/resource/deploy_spec.rb +60 -55
- data/spec/unit/resource/directory_spec.rb +18 -18
- data/spec/unit/resource/dpkg_package_spec.rb +8 -14
- data/spec/unit/resource/dsc_script_spec.rb +98 -0
- data/spec/unit/resource/easy_install_package_spec.rb +9 -18
- data/spec/unit/resource/env_spec.rb +12 -12
- data/spec/unit/resource/erl_call_spec.rb +11 -11
- data/spec/unit/resource/execute_spec.rb +5 -0
- data/spec/unit/resource/file_spec.rb +29 -29
- data/spec/unit/resource/freebsd_package_spec.rb +11 -12
- data/spec/unit/resource/gem_package_spec.rb +8 -15
- data/spec/unit/resource/git_spec.rb +12 -8
- data/spec/unit/resource/group_spec.rb +27 -27
- data/spec/unit/resource/homebrew_package_spec.rb +50 -0
- data/spec/unit/resource/http_request_spec.rb +6 -6
- data/spec/unit/resource/ifconfig_spec.rb +8 -8
- data/spec/unit/resource/ips_package_spec.rb +10 -13
- data/spec/unit/resource/link_spec.rb +25 -25
- data/spec/unit/resource/log_spec.rb +9 -9
- data/spec/unit/resource/macports_package_spec.rb +8 -13
- data/spec/unit/resource/mdadm_spec.rb +18 -18
- data/spec/unit/resource/mount_spec.rb +45 -45
- data/spec/unit/resource/ohai_spec.rb +7 -7
- data/spec/unit/resource/package_spec.rb +12 -12
- data/spec/unit/resource/pacman_package_spec.rb +8 -14
- data/spec/unit/resource/perl_spec.rb +4 -4
- data/spec/unit/resource/portage_package_spec.rb +3 -3
- data/spec/unit/resource/powershell_spec.rb +7 -7
- data/spec/unit/resource/python_spec.rb +4 -4
- data/spec/unit/resource/registry_key_spec.rb +32 -32
- data/spec/unit/resource/remote_directory_spec.rb +17 -17
- data/spec/unit/resource/remote_file_spec.rb +41 -41
- data/spec/unit/resource/route_spec.rb +19 -19
- data/spec/unit/resource/rpm_package_spec.rb +9 -13
- data/spec/unit/resource/ruby_block_spec.rb +8 -8
- data/spec/unit/resource/ruby_spec.rb +4 -4
- data/spec/unit/resource/scm_spec.rb +40 -40
- data/spec/unit/resource/script_spec.rb +2 -2
- data/spec/unit/resource/service_spec.rb +37 -47
- data/spec/unit/resource/smartos_package_spec.rb +10 -15
- data/spec/unit/resource/solaris_package_spec.rb +13 -28
- data/spec/unit/resource/subversion_spec.rb +16 -12
- data/spec/unit/resource/template_spec.rb +35 -35
- data/spec/unit/resource/timestamped_deploy_spec.rb +30 -4
- data/spec/unit/resource/user_spec.rb +23 -23
- data/spec/unit/resource/windows_package_spec.rb +17 -10
- data/spec/unit/resource/windows_service_spec.rb +9 -6
- data/spec/unit/resource/yum_package_spec.rb +16 -21
- data/spec/unit/resource_collection/resource_list_spec.rb +137 -0
- data/spec/unit/resource_collection/resource_set_spec.rb +199 -0
- data/spec/unit/resource_collection_spec.rb +73 -92
- data/spec/unit/resource_definition_spec.rb +38 -40
- data/spec/unit/resource_reporter_spec.rb +3 -3
- data/spec/unit/resource_spec.rb +68 -33
- data/spec/unit/rest_spec.rb +83 -76
- data/spec/unit/role_spec.rb +5 -0
- data/spec/unit/run_list_spec.rb +5 -1
- data/spec/unit/runner_spec.rb +245 -238
- data/spec/unit/shell/shell_ext_spec.rb +1 -1
- data/spec/unit/user_spec.rb +5 -1
- data/spec/unit/util/dsc/configuration_generator_spec.rb +171 -0
- data/spec/unit/util/dsc/lcm_output_parser_spec.rb +169 -0
- data/spec/unit/util/dsc/local_configuration_manager_spec.rb +139 -0
- data/spec/unit/util/path_helper_spec.rb +23 -1
- data/spec/unit/util/powershell/cmdlet_spec.rb +106 -0
- data/spec/unit/workstation_config_loader_spec.rb +1 -1
- metadata +303 -196
- checksums.yaml +0 -7
- data/distro/README +0 -2
- data/distro/arch/etc/conf.d/chef-client.conf +0 -5
- data/distro/arch/etc/conf.d/chef-expander.conf +0 -8
- data/distro/arch/etc/conf.d/chef-server-webui.conf +0 -10
- data/distro/arch/etc/conf.d/chef-server.conf +0 -10
- data/distro/arch/etc/conf.d/chef-solr.conf +0 -8
- data/distro/arch/etc/rc.d/chef-client +0 -90
- data/distro/arch/etc/rc.d/chef-expander +0 -78
- data/distro/arch/etc/rc.d/chef-server +0 -78
- data/distro/arch/etc/rc.d/chef-server-webui +0 -78
- data/distro/arch/etc/rc.d/chef-solr +0 -78
- data/distro/debian/etc/default/chef-client +0 -4
- data/distro/debian/etc/default/chef-expander +0 -8
- data/distro/debian/etc/default/chef-server +0 -9
- data/distro/debian/etc/default/chef-server-webui +0 -9
- data/distro/debian/etc/default/chef-solr +0 -8
- data/distro/debian/etc/init.d/chef-client +0 -212
- data/distro/debian/etc/init.d/chef-expander +0 -176
- data/distro/debian/etc/init.d/chef-server +0 -122
- data/distro/debian/etc/init.d/chef-server-webui +0 -123
- data/distro/debian/etc/init.d/chef-solr +0 -176
- data/distro/debian/etc/init/chef-client.conf +0 -17
- data/distro/debian/etc/init/chef-expander.conf +0 -17
- data/distro/debian/etc/init/chef-server-webui.conf +0 -17
- data/distro/debian/etc/init/chef-server.conf +0 -17
- data/distro/debian/etc/init/chef-solr.conf +0 -17
- data/distro/redhat/etc/init.d/chef-client +0 -121
- data/distro/redhat/etc/init.d/chef-expander +0 -104
- data/distro/redhat/etc/init.d/chef-server +0 -112
- data/distro/redhat/etc/init.d/chef-server-webui +0 -112
- data/distro/redhat/etc/init.d/chef-solr +0 -104
- data/distro/redhat/etc/logrotate.d/chef-client +0 -8
- data/distro/redhat/etc/logrotate.d/chef-expander +0 -8
- data/distro/redhat/etc/logrotate.d/chef-server +0 -8
- data/distro/redhat/etc/logrotate.d/chef-server-webui +0 -8
- data/distro/redhat/etc/logrotate.d/chef-solr +0 -8
- data/distro/redhat/etc/sysconfig/chef-client +0 -15
- data/distro/redhat/etc/sysconfig/chef-expander +0 -7
- data/distro/redhat/etc/sysconfig/chef-server +0 -14
- data/distro/redhat/etc/sysconfig/chef-server-webui +0 -14
- data/distro/redhat/etc/sysconfig/chef-solr +0 -8
- data/distro/windows/service_manager.rb +0 -20
- data/lib/chef/resource_platform_map.rb +0 -151
- data/spec/support/shared/matchers.rb +0 -17
- data/spec/unit/resource_platform_map_spec.rb +0 -164
@@ -30,7 +30,7 @@ describe Chef::Provider::Service::Init, "load_current_resource" do
|
|
30
30
|
@current_resource = Chef::Resource::Service.new("chef")
|
31
31
|
|
32
32
|
@provider = Chef::Provider::Service::Init.new(@new_resource, @run_context)
|
33
|
-
Chef::Resource::Service.
|
33
|
+
allow(Chef::Resource::Service).to receive(:new).and_return(@current_resource)
|
34
34
|
|
35
35
|
@stdout = StringIO.new(<<-PS)
|
36
36
|
aj 7842 5057 0 21:26 pts/2 00:00:06 vi init.rb
|
@@ -38,17 +38,17 @@ aj 7903 5016 0 21:26 pts/5 00:00:00 /bin/bash
|
|
38
38
|
aj 8119 6041 0 21:34 pts/3 00:00:03 vi init_service_spec.rb
|
39
39
|
PS
|
40
40
|
@status = double("Status", :exitstatus => 0, :stdout => @stdout)
|
41
|
-
@provider.
|
41
|
+
allow(@provider).to receive(:shell_out!).and_return(@status)
|
42
42
|
end
|
43
43
|
|
44
44
|
it "should create a current resource with the name of the new resource" do
|
45
45
|
@provider.load_current_resource
|
46
|
-
@provider.current_resource.
|
46
|
+
expect(@provider.current_resource).to equal(@current_resource)
|
47
47
|
end
|
48
48
|
|
49
49
|
it "should set the current resources service name to the new resources service name" do
|
50
50
|
@provider.load_current_resource
|
51
|
-
@current_resource.service_name.
|
51
|
+
expect(@current_resource.service_name).to eq('chef')
|
52
52
|
end
|
53
53
|
|
54
54
|
describe "when the service supports status" do
|
@@ -57,37 +57,37 @@ PS
|
|
57
57
|
end
|
58
58
|
|
59
59
|
it "should run '/etc/init.d/service_name status'" do
|
60
|
-
@provider.
|
60
|
+
expect(@provider).to receive(:shell_out).with("/etc/init.d/#{@current_resource.service_name} status").and_return(@status)
|
61
61
|
@provider.load_current_resource
|
62
62
|
end
|
63
63
|
|
64
64
|
it "should set running to true if the status command returns 0" do
|
65
|
-
@provider.
|
65
|
+
allow(@provider).to receive(:shell_out).with("/etc/init.d/#{@current_resource.service_name} status").and_return(@status)
|
66
66
|
@provider.load_current_resource
|
67
|
-
@current_resource.running.
|
67
|
+
expect(@current_resource.running).to be_true
|
68
68
|
end
|
69
69
|
|
70
70
|
it "should set running to false if the status command returns anything except 0" do
|
71
|
-
@status.
|
72
|
-
@provider.
|
71
|
+
allow(@status).to receive(:exitstatus).and_return(1)
|
72
|
+
allow(@provider).to receive(:shell_out).with("/etc/init.d/#{@current_resource.service_name} status").and_return(@status)
|
73
73
|
@provider.load_current_resource
|
74
|
-
@current_resource.running.
|
74
|
+
expect(@current_resource.running).to be_false
|
75
75
|
end
|
76
76
|
|
77
77
|
it "should set running to false if the status command raises" do
|
78
|
-
@provider.
|
78
|
+
allow(@provider).to receive(:shell_out).and_raise(Mixlib::ShellOut::ShellCommandFailed)
|
79
79
|
@provider.load_current_resource
|
80
|
-
@current_resource.running.
|
80
|
+
expect(@current_resource.running).to be_false
|
81
81
|
end
|
82
82
|
end
|
83
83
|
|
84
84
|
describe "when a status command has been specified" do
|
85
85
|
before do
|
86
|
-
@new_resource.
|
86
|
+
allow(@new_resource).to receive(:status_command).and_return("/etc/init.d/chefhasmonkeypants status")
|
87
87
|
end
|
88
88
|
|
89
89
|
it "should run the services status command if one has been specified" do
|
90
|
-
@provider.
|
90
|
+
expect(@provider).to receive(:shell_out).with("/etc/init.d/chefhasmonkeypants status").and_return(@status)
|
91
91
|
@provider.load_current_resource
|
92
92
|
end
|
93
93
|
|
@@ -95,12 +95,12 @@ PS
|
|
95
95
|
|
96
96
|
describe "when an init command has been specified" do
|
97
97
|
before do
|
98
|
-
@new_resource.
|
98
|
+
allow(@new_resource).to receive(:init_command).and_return("/opt/chef-server/service/erchef")
|
99
99
|
@provider = Chef::Provider::Service::Init.new(@new_resource, @run_context)
|
100
100
|
end
|
101
101
|
|
102
102
|
it "should use the init_command if one has been specified" do
|
103
|
-
@provider.
|
103
|
+
expect(@provider).to receive(:shell_out_with_systems_locale!).with("/opt/chef-server/service/erchef start")
|
104
104
|
@provider.start_service
|
105
105
|
end
|
106
106
|
|
@@ -113,7 +113,7 @@ PS
|
|
113
113
|
@provider.load_current_resource
|
114
114
|
@provider.action = :start
|
115
115
|
@provider.define_resource_requirements
|
116
|
-
|
116
|
+
expect { @provider.process_resource_requirements }.to raise_error(Chef::Exceptions::Service)
|
117
117
|
end
|
118
118
|
|
119
119
|
it "should raise an error if the node has an empty ps attribute" do
|
@@ -121,14 +121,14 @@ PS
|
|
121
121
|
@provider.load_current_resource
|
122
122
|
@provider.action = :start
|
123
123
|
@provider.define_resource_requirements
|
124
|
-
|
124
|
+
expect { @provider.process_resource_requirements }.to raise_error(Chef::Exceptions::Service)
|
125
125
|
end
|
126
126
|
|
127
127
|
end
|
128
128
|
|
129
129
|
describe "when we have a 'ps' attribute" do
|
130
130
|
it "should shell_out! the node's ps command" do
|
131
|
-
@provider.
|
131
|
+
expect(@provider).to receive(:shell_out!).and_return(@status)
|
132
132
|
@provider.load_current_resource
|
133
133
|
end
|
134
134
|
|
@@ -137,39 +137,39 @@ PS
|
|
137
137
|
aj 7842 5057 0 21:26 pts/2 00:00:06 chef
|
138
138
|
aj 7842 5057 0 21:26 pts/2 00:00:06 poos
|
139
139
|
RUNNING_PS
|
140
|
-
@status.
|
140
|
+
allow(@status).to receive(:stdout).and_return(@stdout)
|
141
141
|
@provider.load_current_resource
|
142
|
-
@current_resource.running.
|
142
|
+
expect(@current_resource.running).to be_true
|
143
143
|
end
|
144
144
|
|
145
145
|
it "should set running to false if the regex doesn't match" do
|
146
|
-
@provider.
|
146
|
+
allow(@provider).to receive(:shell_out!).and_return(@status)
|
147
147
|
@provider.load_current_resource
|
148
|
-
@current_resource.running.
|
148
|
+
expect(@current_resource.running).to be_false
|
149
149
|
end
|
150
150
|
|
151
151
|
it "should raise an exception if ps fails" do
|
152
|
-
@provider.
|
152
|
+
allow(@provider).to receive(:shell_out!).and_raise(Mixlib::ShellOut::ShellCommandFailed)
|
153
153
|
@provider.load_current_resource
|
154
154
|
@provider.action = :start
|
155
155
|
@provider.define_resource_requirements
|
156
|
-
|
156
|
+
expect { @provider.process_resource_requirements }.to raise_error(Chef::Exceptions::Service)
|
157
157
|
end
|
158
158
|
end
|
159
159
|
|
160
160
|
it "should return the current resource" do
|
161
|
-
@provider.load_current_resource.
|
161
|
+
expect(@provider.load_current_resource).to eql(@current_resource)
|
162
162
|
end
|
163
163
|
|
164
164
|
describe "when starting the service" do
|
165
165
|
it "should call the start command if one is specified" do
|
166
166
|
@new_resource.start_command("/etc/init.d/chef startyousillysally")
|
167
|
-
@provider.
|
167
|
+
expect(@provider).to receive(:shell_out_with_systems_locale!).with("/etc/init.d/chef startyousillysally")
|
168
168
|
@provider.start_service()
|
169
169
|
end
|
170
170
|
|
171
171
|
it "should call '/etc/init.d/service_name start' if no start command is specified" do
|
172
|
-
@provider.
|
172
|
+
expect(@provider).to receive(:shell_out_with_systems_locale!).with("/etc/init.d/#{@new_resource.service_name} start")
|
173
173
|
@provider.start_service()
|
174
174
|
end
|
175
175
|
end
|
@@ -177,12 +177,12 @@ RUNNING_PS
|
|
177
177
|
describe Chef::Provider::Service::Init, "stop_service" do
|
178
178
|
it "should call the stop command if one is specified" do
|
179
179
|
@new_resource.stop_command("/etc/init.d/chef itoldyoutostop")
|
180
|
-
@provider.
|
180
|
+
expect(@provider).to receive(:shell_out_with_systems_locale!).with("/etc/init.d/chef itoldyoutostop")
|
181
181
|
@provider.stop_service()
|
182
182
|
end
|
183
183
|
|
184
184
|
it "should call '/etc/init.d/service_name stop' if no stop command is specified" do
|
185
|
-
@provider.
|
185
|
+
expect(@provider).to receive(:shell_out_with_systems_locale!).with("/etc/init.d/#{@new_resource.service_name} stop")
|
186
186
|
@provider.stop_service()
|
187
187
|
end
|
188
188
|
end
|
@@ -190,20 +190,20 @@ RUNNING_PS
|
|
190
190
|
describe "when restarting a service" do
|
191
191
|
it "should call 'restart' on the service_name if the resource supports it" do
|
192
192
|
@new_resource.supports({:restart => true})
|
193
|
-
@provider.
|
193
|
+
expect(@provider).to receive(:shell_out_with_systems_locale!).with("/etc/init.d/#{@new_resource.service_name} restart")
|
194
194
|
@provider.restart_service()
|
195
195
|
end
|
196
196
|
|
197
197
|
it "should call the restart_command if one has been specified" do
|
198
198
|
@new_resource.restart_command("/etc/init.d/chef restartinafire")
|
199
|
-
@provider.
|
199
|
+
expect(@provider).to receive(:shell_out_with_systems_locale!).with("/etc/init.d/#{@new_resource.service_name} restartinafire")
|
200
200
|
@provider.restart_service()
|
201
201
|
end
|
202
202
|
|
203
203
|
it "should just call stop, then start when the resource doesn't support restart and no restart_command is specified" do
|
204
|
-
@provider.
|
205
|
-
@provider.
|
206
|
-
@provider.
|
204
|
+
expect(@provider).to receive(:stop_service)
|
205
|
+
expect(@provider).to receive(:sleep).with(1)
|
206
|
+
expect(@provider).to receive(:start_service)
|
207
207
|
@provider.restart_service()
|
208
208
|
end
|
209
209
|
end
|
@@ -211,13 +211,13 @@ RUNNING_PS
|
|
211
211
|
describe "when reloading a service" do
|
212
212
|
it "should call 'reload' on the service if it supports it" do
|
213
213
|
@new_resource.supports({:reload => true})
|
214
|
-
@provider.
|
214
|
+
expect(@provider).to receive(:shell_out_with_systems_locale!).with("/etc/init.d/chef reload")
|
215
215
|
@provider.reload_service()
|
216
216
|
end
|
217
217
|
|
218
218
|
it "should should run the user specified reload command if one is specified and the service doesn't support reload" do
|
219
219
|
@new_resource.reload_command("/etc/init.d/chef lollerpants")
|
220
|
-
@provider.
|
220
|
+
expect(@provider).to receive(:shell_out_with_systems_locale!).with("/etc/init.d/chef lollerpants")
|
221
221
|
@provider.reload_service()
|
222
222
|
end
|
223
223
|
end
|
@@ -225,11 +225,11 @@ RUNNING_PS
|
|
225
225
|
describe "when a custom command has been specified" do
|
226
226
|
before do
|
227
227
|
@new_resource.start_command("/etc/init.d/chef startyousillysally")
|
228
|
-
@provider.
|
228
|
+
expect(@provider).to receive(:shell_out_with_systems_locale!).with("/etc/init.d/chef startyousillysally")
|
229
229
|
end
|
230
230
|
|
231
231
|
it "should still pass all why run assertions" do
|
232
|
-
|
232
|
+
expect { @provider.run_action(:start) }.not_to raise_error
|
233
233
|
end
|
234
234
|
end
|
235
235
|
end
|
@@ -30,29 +30,29 @@ describe Chef::Provider::Service::Insserv do
|
|
30
30
|
|
31
31
|
@provider = Chef::Provider::Service::Insserv.new(@new_resource, @run_context)
|
32
32
|
@status = double("Process::Status mock", :exitstatus => 0, :stdout => "")
|
33
|
-
@provider.
|
33
|
+
allow(@provider).to receive(:shell_out!).and_return(@status)
|
34
34
|
end
|
35
35
|
|
36
36
|
describe "load_current_resource" do
|
37
37
|
describe "when startup links exist" do
|
38
38
|
before do
|
39
|
-
Dir.
|
39
|
+
allow(Dir).to receive(:glob).with("/etc/rc**/S*initgrediant").and_return(["/etc/rc5.d/S18initgrediant", "/etc/rc2.d/S18initgrediant", "/etc/rc4.d/S18initgrediant", "/etc/rc3.d/S18initgrediant"])
|
40
40
|
end
|
41
41
|
|
42
42
|
it "sets the current enabled status to true" do
|
43
43
|
@provider.load_current_resource
|
44
|
-
@provider.current_resource.enabled.
|
44
|
+
expect(@provider.current_resource.enabled).to be_true
|
45
45
|
end
|
46
46
|
end
|
47
47
|
|
48
48
|
describe "when startup links do not exist" do
|
49
49
|
before do
|
50
|
-
Dir.
|
50
|
+
allow(Dir).to receive(:glob).with("/etc/rc**/S*initgrediant").and_return([])
|
51
51
|
end
|
52
52
|
|
53
53
|
it "sets the current enabled status to false" do
|
54
54
|
@provider.load_current_resource
|
55
|
-
@provider.current_resource.enabled.
|
55
|
+
expect(@provider.current_resource.enabled).to be_false
|
56
56
|
end
|
57
57
|
end
|
58
58
|
|
@@ -60,15 +60,15 @@ describe Chef::Provider::Service::Insserv do
|
|
60
60
|
|
61
61
|
describe "enable_service" do
|
62
62
|
it "should call insserv and create the default links" do
|
63
|
-
@provider.
|
64
|
-
@provider.
|
63
|
+
expect(@provider).to receive(:shell_out!).with("/sbin/insserv -r -f #{@new_resource.service_name}")
|
64
|
+
expect(@provider).to receive(:shell_out!).with("/sbin/insserv -d -f #{@new_resource.service_name}")
|
65
65
|
@provider.enable_service
|
66
66
|
end
|
67
67
|
end
|
68
68
|
|
69
69
|
describe "disable_service" do
|
70
70
|
it "should call insserv and remove the links" do
|
71
|
-
@provider.
|
71
|
+
expect(@provider).to receive(:shell_out!).with("/sbin/insserv -r -f #{@new_resource.service_name}")
|
72
72
|
@provider.disable_service
|
73
73
|
end
|
74
74
|
end
|
@@ -30,7 +30,7 @@ describe Chef::Provider::Service::Invokercd, "load_current_resource" do
|
|
30
30
|
@current_resource = Chef::Resource::Service.new("chef")
|
31
31
|
|
32
32
|
@provider = Chef::Provider::Service::Invokercd.new(@new_resource, @run_context)
|
33
|
-
Chef::Resource::Service.
|
33
|
+
allow(Chef::Resource::Service).to receive(:new).and_return(@current_resource)
|
34
34
|
|
35
35
|
@stdout = StringIO.new(<<-PS)
|
36
36
|
aj 7842 5057 0 21:26 pts/2 00:00:06 vi init.rb
|
@@ -38,17 +38,17 @@ aj 7903 5016 0 21:26 pts/5 00:00:00 /bin/bash
|
|
38
38
|
aj 8119 6041 0 21:34 pts/3 00:00:03 vi init_service_spec.rb
|
39
39
|
PS
|
40
40
|
@status = double("Status", :exitstatus => 0, :stdout => @stdout)
|
41
|
-
@provider.
|
41
|
+
allow(@provider).to receive(:shell_out!).and_return(@status)
|
42
42
|
end
|
43
43
|
|
44
44
|
it "should create a current resource with the name of the new resource" do
|
45
45
|
@provider.load_current_resource
|
46
|
-
@provider.current_resource.
|
46
|
+
expect(@provider.current_resource).to equal(@current_resource)
|
47
47
|
end
|
48
48
|
|
49
49
|
it "should set the current resources service name to the new resources service name" do
|
50
50
|
@provider.load_current_resource
|
51
|
-
@current_resource.service_name.
|
51
|
+
expect(@current_resource.service_name).to eq('chef')
|
52
52
|
end
|
53
53
|
|
54
54
|
describe "when the service supports status" do
|
@@ -57,37 +57,37 @@ PS
|
|
57
57
|
end
|
58
58
|
|
59
59
|
it "should run '/usr/sbin/invoke-rc.d service_name status'" do
|
60
|
-
@provider.
|
60
|
+
expect(@provider).to receive(:shell_out).with("/usr/sbin/invoke-rc.d #{@current_resource.service_name} status").and_return(@status)
|
61
61
|
@provider.load_current_resource
|
62
62
|
end
|
63
63
|
|
64
64
|
it "should set running to true if the status command returns 0" do
|
65
|
-
@provider.
|
65
|
+
allow(@provider).to receive(:shell_out).with("/usr/sbin/invoke-rc.d #{@current_resource.service_name} status").and_return(@status)
|
66
66
|
@provider.load_current_resource
|
67
|
-
@current_resource.running.
|
67
|
+
expect(@current_resource.running).to be_true
|
68
68
|
end
|
69
69
|
|
70
70
|
it "should set running to false if the status command returns anything except 0" do
|
71
|
-
@status.
|
72
|
-
@provider.
|
71
|
+
allow(@status).to receive(:exitstatus).and_return(1)
|
72
|
+
allow(@provider).to receive(:shell_out).with("/usr/sbin/invoke-rc.d #{@current_resource.service_name} status").and_return(@status)
|
73
73
|
@provider.load_current_resource
|
74
|
-
@current_resource.running.
|
74
|
+
expect(@current_resource.running).to be_false
|
75
75
|
end
|
76
76
|
|
77
77
|
it "should set running to false if the status command raises" do
|
78
|
-
@provider.
|
78
|
+
allow(@provider).to receive(:shell_out).with("/usr/sbin/invoke-rc.d #{@current_resource.service_name} status").and_raise(Mixlib::ShellOut::ShellCommandFailed)
|
79
79
|
@provider.load_current_resource
|
80
|
-
@current_resource.running.
|
80
|
+
expect(@current_resource.running).to be_false
|
81
81
|
end
|
82
82
|
end
|
83
83
|
|
84
84
|
describe "when a status command has been specified" do
|
85
85
|
before do
|
86
|
-
@new_resource.
|
86
|
+
allow(@new_resource).to receive(:status_command).and_return("/usr/sbin/invoke-rc.d chefhasmonkeypants status")
|
87
87
|
end
|
88
88
|
|
89
89
|
it "should run the services status command if one has been specified" do
|
90
|
-
@provider.
|
90
|
+
expect(@provider).to receive(:shell_out).with("/usr/sbin/invoke-rc.d chefhasmonkeypants status").and_return(@status)
|
91
91
|
@provider.load_current_resource
|
92
92
|
end
|
93
93
|
|
@@ -98,14 +98,14 @@ PS
|
|
98
98
|
@node.automatic_attrs[:command] = {:ps => nil}
|
99
99
|
@provider.action = :start
|
100
100
|
@provider.define_resource_requirements
|
101
|
-
|
101
|
+
expect { @provider.process_resource_requirements }.to raise_error(Chef::Exceptions::Service)
|
102
102
|
end
|
103
103
|
|
104
104
|
it "should raise error if the node has an empty ps attribute and no other means to get status" do
|
105
105
|
@node.automatic_attrs[:command] = {:ps => ""}
|
106
106
|
@provider.action = :start
|
107
107
|
@provider.define_resource_requirements
|
108
|
-
|
108
|
+
expect { @provider.process_resource_requirements }.to raise_error(Chef::Exceptions::Service)
|
109
109
|
end
|
110
110
|
|
111
111
|
end
|
@@ -113,7 +113,7 @@ PS
|
|
113
113
|
describe "when we have a 'ps' attribute" do
|
114
114
|
it "should shell_out! the node's ps command" do
|
115
115
|
@status = double("Status", :exitstatus => 0, :stdout => @stdout)
|
116
|
-
@provider.
|
116
|
+
expect(@provider).to receive(:shell_out!).with(@node[:command][:ps]).and_return(@status)
|
117
117
|
@provider.load_current_resource
|
118
118
|
end
|
119
119
|
|
@@ -123,40 +123,40 @@ aj 7842 5057 0 21:26 pts/2 00:00:06 chef
|
|
123
123
|
aj 7842 5057 0 21:26 pts/2 00:00:06 poos
|
124
124
|
RUNNING_PS
|
125
125
|
@status = double("Status", :exitstatus => 0, :stdout => @stdout)
|
126
|
-
@provider.
|
126
|
+
expect(@provider).to receive(:shell_out!).and_return(@status)
|
127
127
|
@provider.load_current_resource
|
128
|
-
@current_resource.running.
|
128
|
+
expect(@current_resource.running).to be_true
|
129
129
|
end
|
130
130
|
|
131
131
|
it "should set running to false if the regex doesn't match" do
|
132
132
|
@status = double("Status", :exitstatus => 0, :stdout => @stdout)
|
133
|
-
@provider.
|
133
|
+
expect(@provider).to receive(:shell_out!).and_return(@status)
|
134
134
|
@provider.load_current_resource
|
135
|
-
@current_resource.running.
|
135
|
+
expect(@current_resource.running).to be_false
|
136
136
|
end
|
137
137
|
|
138
138
|
it "should raise an exception if ps fails" do
|
139
|
-
@provider.
|
139
|
+
allow(@provider).to receive(:shell_out!).and_raise(Mixlib::ShellOut::ShellCommandFailed)
|
140
140
|
@provider.action = :start
|
141
141
|
@provider.load_current_resource
|
142
142
|
@provider.define_resource_requirements
|
143
|
-
|
143
|
+
expect { @provider.process_resource_requirements }.to raise_error(Chef::Exceptions::Service)
|
144
144
|
end
|
145
145
|
end
|
146
146
|
|
147
147
|
it "should return the current resource" do
|
148
|
-
@provider.load_current_resource.
|
148
|
+
expect(@provider.load_current_resource).to eql(@current_resource)
|
149
149
|
end
|
150
150
|
|
151
151
|
describe "when starting the service" do
|
152
152
|
it "should call the start command if one is specified" do
|
153
153
|
@new_resource.start_command("/usr/sbin/invoke-rc.d chef startyousillysally")
|
154
|
-
@provider.
|
154
|
+
expect(@provider).to receive(:shell_out_with_systems_locale!).with("/usr/sbin/invoke-rc.d chef startyousillysally")
|
155
155
|
@provider.start_service()
|
156
156
|
end
|
157
157
|
|
158
158
|
it "should call '/usr/sbin/invoke-rc.d service_name start' if no start command is specified" do
|
159
|
-
@provider.
|
159
|
+
expect(@provider).to receive(:shell_out_with_systems_locale!).with("/usr/sbin/invoke-rc.d #{@new_resource.service_name} start")
|
160
160
|
@provider.start_service()
|
161
161
|
end
|
162
162
|
end
|
@@ -164,12 +164,12 @@ RUNNING_PS
|
|
164
164
|
describe Chef::Provider::Service::Invokercd, "stop_service" do
|
165
165
|
it "should call the stop command if one is specified" do
|
166
166
|
@new_resource.stop_command("/usr/sbin/invoke-rc.d chef itoldyoutostop")
|
167
|
-
@provider.
|
167
|
+
expect(@provider).to receive(:shell_out_with_systems_locale!).with("/usr/sbin/invoke-rc.d chef itoldyoutostop")
|
168
168
|
@provider.stop_service()
|
169
169
|
end
|
170
170
|
|
171
171
|
it "should call '/usr/sbin/invoke-rc.d service_name stop' if no stop command is specified" do
|
172
|
-
@provider.
|
172
|
+
expect(@provider).to receive(:shell_out_with_systems_locale!).with("/usr/sbin/invoke-rc.d #{@new_resource.service_name} stop")
|
173
173
|
@provider.stop_service()
|
174
174
|
end
|
175
175
|
end
|
@@ -177,20 +177,20 @@ RUNNING_PS
|
|
177
177
|
describe "when restarting a service" do
|
178
178
|
it "should call 'restart' on the service_name if the resource supports it" do
|
179
179
|
@new_resource.supports({:restart => true})
|
180
|
-
@provider.
|
180
|
+
expect(@provider).to receive(:shell_out_with_systems_locale!).with("/usr/sbin/invoke-rc.d #{@new_resource.service_name} restart")
|
181
181
|
@provider.restart_service()
|
182
182
|
end
|
183
183
|
|
184
184
|
it "should call the restart_command if one has been specified" do
|
185
185
|
@new_resource.restart_command("/usr/sbin/invoke-rc.d chef restartinafire")
|
186
|
-
@provider.
|
186
|
+
expect(@provider).to receive(:shell_out_with_systems_locale!).with("/usr/sbin/invoke-rc.d #{@new_resource.service_name} restartinafire")
|
187
187
|
@provider.restart_service()
|
188
188
|
end
|
189
189
|
|
190
190
|
it "should just call stop, then start when the resource doesn't support restart and no restart_command is specified" do
|
191
|
-
@provider.
|
192
|
-
@provider.
|
193
|
-
@provider.
|
191
|
+
expect(@provider).to receive(:stop_service)
|
192
|
+
expect(@provider).to receive(:sleep).with(1)
|
193
|
+
expect(@provider).to receive(:start_service)
|
194
194
|
@provider.restart_service()
|
195
195
|
end
|
196
196
|
end
|
@@ -198,13 +198,13 @@ RUNNING_PS
|
|
198
198
|
describe "when reloading a service" do
|
199
199
|
it "should call 'reload' on the service if it supports it" do
|
200
200
|
@new_resource.supports({:reload => true})
|
201
|
-
@provider.
|
201
|
+
expect(@provider).to receive(:shell_out_with_systems_locale!).with("/usr/sbin/invoke-rc.d chef reload")
|
202
202
|
@provider.reload_service()
|
203
203
|
end
|
204
204
|
|
205
205
|
it "should should run the user specified reload command if one is specified and the service doesn't support reload" do
|
206
206
|
@new_resource.reload_command("/usr/sbin/invoke-rc.d chef lollerpants")
|
207
|
-
@provider.
|
207
|
+
expect(@provider).to receive(:shell_out_with_systems_locale!).with("/usr/sbin/invoke-rc.d chef lollerpants")
|
208
208
|
@provider.reload_service()
|
209
209
|
end
|
210
210
|
end
|