chef 10.12.0 → 10.14.0.beta.1
Sign up to get free protection for your applications and to get access to all the features.
- data/Rakefile +120 -0
- data/distro/common/html/chef-client.8.html +4 -4
- data/distro/common/html/chef-expander.8.html +4 -4
- data/distro/common/html/chef-expanderctl.8.html +4 -4
- data/distro/common/html/chef-server-webui.8.html +4 -4
- data/distro/common/html/chef-server.8.html +4 -4
- data/distro/common/html/chef-solo.8.html +4 -4
- data/distro/common/html/chef-solr.8.html +4 -4
- data/distro/common/html/knife-bootstrap.1.html +7 -5
- data/distro/common/html/knife-client.1.html +4 -4
- data/distro/common/html/knife-configure.1.html +5 -5
- data/distro/common/html/knife-cookbook-site.1.html +7 -7
- data/distro/common/html/knife-cookbook.1.html +8 -8
- data/distro/common/html/knife-data-bag.1.html +4 -4
- data/distro/common/html/knife-environment.1.html +7 -7
- data/distro/common/html/knife-exec.1.html +4 -4
- data/distro/common/html/knife-index.1.html +4 -4
- data/distro/common/html/knife-node.1.html +5 -5
- data/distro/common/html/knife-role.1.html +4 -4
- data/distro/common/html/knife-search.1.html +6 -6
- data/distro/common/html/knife-ssh.1.html +4 -4
- data/distro/common/html/knife-status.1.html +4 -4
- data/distro/common/html/knife-tag.1.html +5 -5
- data/distro/common/html/knife.1.html +12 -12
- data/distro/common/html/shef.1.html +4 -4
- data/distro/common/man/man1/knife-bootstrap.1 +5 -1
- data/distro/common/man/man1/knife-client.1 +1 -1
- data/distro/common/man/man1/knife-configure.1 +1 -1
- data/distro/common/man/man1/knife-cookbook-site.1 +1 -1
- data/distro/common/man/man1/knife-cookbook.1 +1 -1
- data/distro/common/man/man1/knife-data-bag.1 +1 -1
- data/distro/common/man/man1/knife-environment.1 +1 -1
- data/distro/common/man/man1/knife-exec.1 +1 -1
- data/distro/common/man/man1/knife-index.1 +1 -1
- data/distro/common/man/man1/knife-node.1 +1 -1
- data/distro/common/man/man1/knife-role.1 +1 -1
- data/distro/common/man/man1/knife-search.1 +1 -1
- data/distro/common/man/man1/knife-ssh.1 +1 -1
- data/distro/common/man/man1/knife-status.1 +1 -1
- data/distro/common/man/man1/knife-tag.1 +1 -1
- data/distro/common/man/man1/knife.1 +1 -1
- data/distro/common/man/man1/shef.1 +1 -1
- data/distro/common/man/man8/chef-client.8 +1 -1
- data/distro/common/man/man8/chef-expander.8 +1 -1
- data/distro/common/man/man8/chef-expanderctl.8 +1 -1
- data/distro/common/man/man8/chef-server-webui.8 +1 -1
- data/distro/common/man/man8/chef-server.8 +1 -1
- data/distro/common/man/man8/chef-solo.8 +1 -1
- data/distro/common/man/man8/chef-solr.8 +1 -1
- data/distro/common/markdown/man1/knife-bootstrap.mkd +3 -0
- data/lib/chef/application.rb +5 -1
- data/lib/chef/application/client.rb +17 -0
- data/lib/chef/application/solo.rb +17 -0
- data/lib/chef/client.rb +105 -27
- data/lib/chef/config.rb +11 -0
- data/lib/chef/cookbook/remote_file_vendor.rb +1 -5
- data/lib/chef/cookbook/synchronizer.rb +216 -0
- data/lib/chef/cookbook_version.rb +6 -26
- data/lib/chef/data_bag.rb +6 -2
- data/lib/chef/data_bag_item.rb +5 -1
- data/lib/chef/event_dispatch/base.rb +303 -0
- data/lib/chef/event_dispatch/dispatcher.rb +42 -0
- data/lib/chef/exceptions.rb +29 -1
- data/lib/chef/file_access_control.rb +7 -2
- data/lib/chef/file_access_control/unix.rb +117 -35
- data/lib/chef/file_access_control/windows.rb +57 -4
- data/lib/chef/file_cache.rb +4 -2
- data/lib/chef/formatters/base.rb +260 -0
- data/lib/chef/formatters/doc.rb +236 -0
- data/lib/chef/formatters/error_inspectors.rb +19 -0
- data/lib/chef/formatters/error_inspectors/api_error_formatting.rb +111 -0
- data/lib/chef/formatters/error_inspectors/compile_error_inspector.rb +90 -0
- data/lib/chef/formatters/error_inspectors/cookbook_resolve_error_inspector.rb +147 -0
- data/lib/chef/formatters/error_inspectors/cookbook_sync_error_inspector.rb +80 -0
- data/lib/chef/formatters/error_inspectors/node_load_error_inspector.rb +125 -0
- data/lib/chef/formatters/error_inspectors/registration_error_inspector.rb +137 -0
- data/lib/chef/formatters/error_inspectors/resource_failure_inspector.rb +101 -0
- data/lib/chef/formatters/error_inspectors/run_list_expansion_error_inspector.rb +117 -0
- data/lib/chef/formatters/minimal.rb +235 -0
- data/lib/chef/handler.rb +8 -0
- data/lib/chef/handler/error_report.rb +1 -1
- data/lib/chef/knife/bootstrap.rb +10 -1
- data/lib/chef/knife/bootstrap/archlinux-gems.erb +14 -1
- data/lib/chef/knife/bootstrap/centos5-gems.erb +13 -0
- data/lib/chef/knife/bootstrap/chef-full.erb +13 -0
- data/lib/chef/knife/bootstrap/fedora13-gems.erb +13 -0
- data/lib/chef/knife/bootstrap/ubuntu10.04-apt.erb +13 -0
- data/lib/chef/knife/bootstrap/ubuntu10.04-gems.erb +13 -0
- data/lib/chef/knife/bootstrap/ubuntu12.04-gems.erb +13 -0
- data/lib/chef/knife/cookbook_site_install.rb +17 -5
- data/lib/chef/knife/cookbook_site_show.rb +6 -3
- data/lib/chef/knife/core/cookbook_scm_repo.rb +12 -0
- data/lib/chef/knife/exec.rb +37 -2
- data/lib/chef/knife/ssh.rb +29 -5
- data/lib/chef/knife/status.rb +19 -2
- data/lib/chef/mixin/enforce_ownership_and_permissions.rb +5 -5
- data/lib/chef/mixin/language_include_recipe.rb +7 -6
- data/lib/chef/mixin/securable.rb +38 -10
- data/lib/chef/mixin/why_run.rb +339 -0
- data/lib/chef/monkey_patches/net_http.rb +22 -0
- data/lib/chef/node.rb +6 -2
- data/lib/chef/platform.rb +6 -3
- data/lib/chef/provider.rb +105 -9
- data/lib/chef/provider/cookbook_file.rb +18 -34
- data/lib/chef/provider/cron.rb +21 -12
- data/lib/chef/provider/deploy.rb +131 -75
- data/lib/chef/provider/directory.rb +80 -25
- data/lib/chef/provider/erl_call.rb +33 -28
- data/lib/chef/provider/execute.rb +8 -5
- data/lib/chef/provider/file.rb +128 -26
- data/lib/chef/provider/git.rb +87 -72
- data/lib/chef/provider/group.rb +49 -23
- data/lib/chef/provider/group/dscl.rb +9 -1
- data/lib/chef/provider/group/gpasswd.rb +8 -1
- data/lib/chef/provider/group/groupadd.rb +9 -1
- data/lib/chef/provider/group/groupmod.rb +120 -0
- data/lib/chef/provider/group/pw.rb +10 -1
- data/lib/chef/provider/group/suse.rb +8 -1
- data/lib/chef/provider/group/usermod.rb +10 -2
- data/lib/chef/provider/http_request.rb +72 -61
- data/lib/chef/provider/ifconfig.rb +51 -32
- data/lib/chef/provider/link.rb +43 -34
- data/lib/chef/provider/mdadm.rb +27 -29
- data/lib/chef/provider/mount.rb +40 -26
- data/lib/chef/provider/ohai.rb +13 -8
- data/lib/chef/provider/package.rb +57 -41
- data/lib/chef/provider/package/apt.rb +8 -11
- data/lib/chef/provider/package/dpkg.rb +30 -17
- data/lib/chef/provider/package/rpm.rb +23 -6
- data/lib/chef/provider/remote_directory.rb +8 -4
- data/lib/chef/provider/remote_file.rb +16 -18
- data/lib/chef/provider/resource_update.rb +55 -0
- data/lib/chef/provider/route.rb +19 -12
- data/lib/chef/provider/ruby_block.rb +8 -3
- data/lib/chef/provider/script.rb +4 -2
- data/lib/chef/provider/service.rb +35 -21
- data/lib/chef/provider/service/arch.rb +2 -5
- data/lib/chef/provider/service/debian.rb +32 -10
- data/lib/chef/provider/service/freebsd.rb +50 -14
- data/lib/chef/provider/service/gentoo.rb +18 -4
- data/lib/chef/provider/service/init.rb +13 -0
- data/lib/chef/provider/service/macosx.rb +32 -13
- data/lib/chef/provider/service/redhat.rb +30 -13
- data/lib/chef/provider/service/simple.rb +68 -25
- data/lib/chef/provider/service/solaris.rb +4 -0
- data/lib/chef/provider/service/systemd.rb +13 -0
- data/lib/chef/provider/service/upstart.rb +27 -1
- data/lib/chef/provider/service/windows.rb +4 -0
- data/lib/chef/provider/subversion.rb +36 -22
- data/lib/chef/provider/template.rb +27 -22
- data/lib/chef/provider/user.rb +66 -45
- data/lib/chef/providers.rb +1 -0
- data/lib/chef/resource.rb +138 -24
- data/lib/chef/resource/conditional.rb +8 -0
- data/lib/chef/resource/deploy.rb +9 -0
- data/lib/chef/resource/execute.rb +1 -1
- data/lib/chef/resource/file.rb +11 -0
- data/lib/chef/resource/link.rb +20 -0
- data/lib/chef/resource/package.rb +4 -0
- data/lib/chef/resource/template.rb +0 -1
- data/lib/chef/resource_reporter.rb +195 -0
- data/lib/chef/rest.rb +55 -38
- data/lib/chef/run_context.rb +90 -19
- data/lib/chef/run_list/run_list_expansion.rb +33 -20
- data/lib/chef/run_status.rb +4 -1
- data/lib/chef/runner.rb +9 -23
- data/lib/chef/scan_access_control.rb +133 -0
- data/lib/chef/shef/shef_session.rb +17 -5
- data/lib/chef/version.rb +1 -1
- data/spec/data/bad-config.rb +1 -0
- data/spec/data/big_json.json +1 -0
- data/spec/data/big_json_plus_one.json +1 -0
- data/spec/data/bootstrap/test-hints.erb +12 -0
- data/spec/data/bootstrap/test.erb +1 -0
- data/spec/data/cb_version_cookbooks/tatft/README.rdoc +3 -0
- data/spec/data/cb_version_cookbooks/tatft/attributes/default.rb +1 -0
- data/spec/data/cb_version_cookbooks/tatft/definitions/runit_service.rb +1 -0
- data/spec/data/cb_version_cookbooks/tatft/files/default/giant_blob.tgz +1 -0
- data/spec/data/cb_version_cookbooks/tatft/libraries/ownage.rb +1 -0
- data/spec/data/cb_version_cookbooks/tatft/providers/lwp.rb +1 -0
- data/spec/data/cb_version_cookbooks/tatft/recipes/default.rb +1 -0
- data/spec/data/cb_version_cookbooks/tatft/resources/lwr.rb +1 -0
- data/spec/data/cb_version_cookbooks/tatft/templates/default/configuration.erb +0 -0
- data/spec/data/checksum/random.txt +1 -0
- data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-600hhz-0 +1 -0
- data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-6m8zdk-0 +0 -0
- data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-ahd2gq-0 +1 -0
- data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-api8ux-0 +1 -0
- data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-b0r1m1-0 +1 -0
- data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-bfygsi-0 +1 -0
- data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-el14l6-0 +1 -0
- data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-ivrl3y-0 +1 -0
- data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-kkbs85-0 +1 -0
- data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-ory1ux-0 +1 -0
- data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-pgsq76-0 +1 -0
- data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-ra8uim-0 +1 -0
- data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-t7k1g-0 +1 -0
- data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-t8g0sv-0 +1 -0
- data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-ufy6g3-0 +1 -0
- data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-x2d6j9-0 +1 -0
- data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-xi0l6h-0 +1 -0
- data/spec/data/config.rb +6 -0
- data/spec/data/cookbooks/apache2/files/default/apache2_module_conf_generate.pl +2 -0
- data/spec/data/cookbooks/apache2/recipes/default.rb +3 -0
- data/spec/data/cookbooks/borken/recipes/default.rb +2 -0
- data/spec/data/cookbooks/borken/templates/default/borken.erb +2 -0
- data/spec/data/cookbooks/chefignore +6 -0
- data/spec/data/cookbooks/java/files/default/java.response +2 -0
- data/spec/data/cookbooks/openldap/attributes/default.rb +15 -0
- data/spec/data/cookbooks/openldap/attributes/smokey.rb +1 -0
- data/spec/data/cookbooks/openldap/definitions/client.rb +5 -0
- data/spec/data/cookbooks/openldap/definitions/server.rb +5 -0
- data/spec/data/cookbooks/openldap/files/default/remotedir/remote_dir_file1.txt +3 -0
- data/spec/data/cookbooks/openldap/files/default/remotedir/remote_dir_file2.txt +3 -0
- data/spec/data/cookbooks/openldap/files/default/remotedir/remotesubdir/remote_subdir_file1.txt +3 -0
- data/spec/data/cookbooks/openldap/files/default/remotedir/remotesubdir/remote_subdir_file2.txt +3 -0
- data/spec/data/cookbooks/openldap/files/default/remotedir/subdir_with_no_file_just_a_subsubdir/the_subsubdir/some_file.txt +3 -0
- data/spec/data/cookbooks/openldap/recipes/default.rb +3 -0
- data/spec/data/cookbooks/openldap/recipes/gigantor.rb +3 -0
- data/spec/data/cookbooks/openldap/recipes/one.rb +15 -0
- data/spec/data/cookbooks/openldap/templates/default/openldap_stuff.conf.erb +1 -0
- data/spec/data/cookbooks/openldap/templates/default/openldap_variable_stuff.conf.erb +1 -0
- data/spec/data/cookbooks/openldap/templates/default/test.erb +1 -0
- data/spec/data/definitions/test.rb +5 -0
- data/spec/data/environment-config.rb +5 -0
- data/spec/data/fileedit/blank +0 -0
- data/spec/data/fileedit/hosts +4 -0
- data/spec/data/gems/chef-integration-test-0.1.0.gem +0 -0
- data/spec/data/kitchen/chefignore +6 -0
- data/spec/data/kitchen/openldap/attributes/default.rb +3 -0
- data/spec/data/kitchen/openldap/attributes/robinson.rb +3 -0
- data/spec/data/kitchen/openldap/definitions/client.rb +3 -0
- data/spec/data/kitchen/openldap/definitions/drewbarrymore.rb +3 -0
- data/spec/data/kitchen/openldap/recipes/gigantor.rb +3 -0
- data/spec/data/kitchen/openldap/recipes/ignoreme.rb +3 -0
- data/spec/data/kitchen/openldap/recipes/woot.rb +3 -0
- data/spec/data/knife-site-subcommands/plugins/knife/example_subcommand.rb +0 -0
- data/spec/data/knife_subcommand/test_explicit_category.rb +7 -0
- data/spec/data/knife_subcommand/test_name_mapping.rb +4 -0
- data/spec/data/knife_subcommand/test_yourself.rb +13 -0
- data/spec/data/lwrp/providers/buck_passer.rb +3 -0
- data/spec/data/lwrp/providers/buck_passer_2.rb +10 -0
- data/spec/data/lwrp/providers/embedded_resource_accesses_providers_scope.rb +16 -0
- data/spec/data/lwrp/providers/monkey_name_printer.rb +5 -0
- data/spec/data/lwrp/providers/paint_drying_watcher.rb +7 -0
- data/spec/data/lwrp/providers/thumb_twiddler.rb +7 -0
- data/spec/data/lwrp/resources/bar.rb +1 -0
- data/spec/data/lwrp/resources/foo.rb +3 -0
- data/spec/data/lwrp/resources_with_default_attributes/nodeattr.rb +1 -0
- data/spec/data/lwrp_override/providers/buck_passer.rb +10 -0
- data/spec/data/lwrp_override/resources/foo.rb +4 -0
- data/spec/data/metadata/quick_start/metadata.rb +19 -0
- data/spec/data/nodes/default.rb +15 -0
- data/spec/data/nodes/test.example.com.rb +17 -0
- data/spec/data/nodes/test.rb +15 -0
- data/spec/data/object_loader/environments/test.json +5 -0
- data/spec/data/object_loader/environments/test.rb +2 -0
- data/spec/data/object_loader/environments/test_json_class.json +6 -0
- data/spec/data/object_loader/nodes/test.json +5 -0
- data/spec/data/object_loader/nodes/test.rb +2 -0
- data/spec/data/object_loader/nodes/test_json_class.json +6 -0
- data/spec/data/object_loader/roles/test.json +5 -0
- data/spec/data/object_loader/roles/test.rb +2 -0
- data/spec/data/object_loader/roles/test_json_class.json +6 -0
- data/spec/data/old_home_dir/my-dot-emacs +0 -0
- data/spec/data/old_home_dir/my-dot-vim +0 -0
- data/spec/data/recipes/test.rb +7 -0
- data/spec/data/remote_directory_data/remote_dir_file.txt +1 -0
- data/spec/data/remote_directory_data/remote_subdirectory/remote_subdir_file.txt +1 -0
- data/spec/data/remote_file/nyan_cat.png +0 -0
- data/spec/data/run_context/cookbooks/test/attributes/george.rb +1 -0
- data/spec/data/run_context/cookbooks/test/definitions/new_animals.rb +9 -0
- data/spec/data/run_context/cookbooks/test/definitions/new_cat.rb +5 -0
- data/spec/data/run_context/cookbooks/test/recipes/default.rb +5 -0
- data/spec/data/run_context/cookbooks/test/recipes/one.rb +7 -0
- data/spec/data/run_context/cookbooks/test/recipes/two.rb +7 -0
- data/spec/data/run_context/nodes/run_context.rb +5 -0
- data/spec/data/search_queries_to_transform.txt +98 -0
- data/spec/data/ssl/5e707473.0 +18 -0
- data/spec/data/ssl/chef-rspec.cert +27 -0
- data/spec/data/ssl/chef-rspec.key +27 -0
- data/spec/data/ssl/key.pem +15 -0
- data/spec/data/ssl/private_key.pem +27 -0
- data/spec/data/ssl/private_key_with_whitespace.pem +32 -0
- data/spec/data/templates/seattle.txt +1 -0
- data/spec/functional/knife/cookbook_delete_spec.rb +159 -0
- data/spec/functional/knife/exec_spec.rb +59 -0
- data/spec/functional/knife/ssh_spec.rb +209 -0
- data/spec/functional/resource/directory_spec.rb +39 -0
- data/spec/functional/resource/file_spec.rb +69 -0
- data/spec/functional/resource/link_spec.rb +572 -0
- data/spec/functional/resource/remote_directory_spec.rb +114 -0
- data/spec/functional/resource/remote_file_spec.rb +42 -0
- data/spec/functional/resource/template_spec.rb +68 -0
- data/spec/functional/tiny_server_spec.rb +77 -0
- data/spec/rcov.opts +2 -0
- data/spec/spec_helper.rb +77 -0
- data/spec/stress/win32/file_spec.rb +37 -0
- data/spec/stress/win32/memory_spec.rb +22 -0
- data/spec/stress/win32/security_spec.rb +69 -0
- data/spec/support/chef_helpers.rb +52 -0
- data/spec/support/lib/chef/provider/easy.rb +35 -0
- data/spec/support/lib/chef/provider/snakeoil.rb +40 -0
- data/spec/support/lib/chef/resource/cat.rb +41 -0
- data/spec/support/lib/chef/resource/one_two_three_four.rb +43 -0
- data/spec/support/lib/chef/resource/zen_master.rb +46 -0
- data/spec/support/matchers/leak.rb +96 -0
- data/spec/support/mock/constant.rb +52 -0
- data/spec/support/mock/platform.rb +18 -0
- data/spec/support/platform_helpers.rb +23 -0
- data/spec/support/platforms/prof/gc.rb +54 -0
- data/spec/support/platforms/prof/win32.rb +46 -0
- data/spec/support/shared/functional/directory_resource.rb +85 -0
- data/spec/support/shared/functional/file_resource.rb +172 -0
- data/spec/support/shared/functional/knife.rb +37 -0
- data/spec/support/shared/functional/securable_resource.rb +378 -0
- data/spec/support/shared/unit/api_error_inspector.rb +180 -0
- data/spec/tiny_server.rb +179 -0
- data/spec/unit/api_client_spec.rb +184 -0
- data/spec/unit/application/agent_spec.rb +0 -0
- data/spec/unit/application/client_spec.rb +136 -0
- data/spec/unit/application/knife_spec.rb +152 -0
- data/spec/unit/application/server_spec.rb +0 -0
- data/spec/unit/application/solo_spec.rb +167 -0
- data/spec/unit/application_spec.rb +239 -0
- data/spec/unit/certificate_spec.rb +76 -0
- data/spec/unit/checksum/storage/filesystem_spec.rb +69 -0
- data/spec/unit/checksum_cache_spec.rb +209 -0
- data/spec/unit/checksum_spec.rb +94 -0
- data/spec/unit/chef_spec.rb +25 -0
- data/spec/unit/client_spec.rb +226 -0
- data/spec/unit/config_spec.rb +203 -0
- data/spec/unit/cookbook/chefignore_spec.rb +38 -0
- data/spec/unit/cookbook/metadata_spec.rb +627 -0
- data/spec/unit/cookbook/synchronizer_spec.rb +258 -0
- data/spec/unit/cookbook/syntax_check_spec.rb +211 -0
- data/spec/unit/cookbook_loader_spec.rb +144 -0
- data/spec/unit/cookbook_manifest_spec.rb +554 -0
- data/spec/unit/cookbook_spec.rb +101 -0
- data/spec/unit/cookbook_version_spec.rb +406 -0
- data/spec/unit/couchdb_spec.rb +274 -0
- data/spec/unit/daemon_spec.rb +281 -0
- data/spec/unit/data_bag_item_spec.rb +280 -0
- data/spec/unit/data_bag_spec.rb +169 -0
- data/spec/unit/encrypted_data_bag_item_spec.rb +122 -0
- data/spec/unit/environment_spec.rb +466 -0
- data/spec/unit/exceptions_spec.rb +74 -0
- data/spec/unit/file_access_control_spec.rb +282 -0
- data/spec/unit/file_cache_spec.rb +114 -0
- data/spec/unit/formatters/error_inspectors/compile_error_inspector_spec.rb +69 -0
- data/spec/unit/formatters/error_inspectors/cookbook_resolve_error_inspector_spec.rb +75 -0
- data/spec/unit/formatters/error_inspectors/cookbook_sync_error_inspector_spec.rb +43 -0
- data/spec/unit/formatters/error_inspectors/node_load_error_inspector_spec.rb +27 -0
- data/spec/unit/formatters/error_inspectors/registration_error_inspector_spec.rb +27 -0
- data/spec/unit/formatters/error_inspectors/resource_failure_inspector_spec.rb +71 -0
- data/spec/unit/formatters/error_inspectors/run_list_expansion_error_inspector_spec.rb +93 -0
- data/spec/unit/handler/json_file_spec.rb +64 -0
- data/spec/unit/handler_spec.rb +216 -0
- data/spec/unit/index_queue_spec.rb +391 -0
- data/spec/unit/json_compat_spect.rb +53 -0
- data/spec/unit/knife/bootstrap_spec.rb +191 -0
- data/spec/unit/knife/client_bulk_delete_spec.rb +78 -0
- data/spec/unit/knife/client_create_spec.rb +74 -0
- data/spec/unit/knife/client_delete_spec.rb +40 -0
- data/spec/unit/knife/client_edit_spec.rb +40 -0
- data/spec/unit/knife/client_list_spec.rb +34 -0
- data/spec/unit/knife/client_reregister_spec.rb +61 -0
- data/spec/unit/knife/client_show_spec.rb +42 -0
- data/spec/unit/knife/config_file_selection_spec.rb +117 -0
- data/spec/unit/knife/configure_client_spec.rb +83 -0
- data/spec/unit/knife/configure_spec.rb +127 -0
- data/spec/unit/knife/cookbook_bulk_delete_spec.rb +87 -0
- data/spec/unit/knife/cookbook_create_spec.rb +251 -0
- data/spec/unit/knife/cookbook_delete_spec.rb +239 -0
- data/spec/unit/knife/cookbook_download_spec.rb +217 -0
- data/spec/unit/knife/cookbook_list_spec.rb +88 -0
- data/spec/unit/knife/cookbook_metadata_from_file_spec.rb +65 -0
- data/spec/unit/knife/cookbook_metadata_spec.rb +172 -0
- data/spec/unit/knife/cookbook_show_spec.rb +223 -0
- data/spec/unit/knife/cookbook_site_download_spec.rb +151 -0
- data/spec/unit/knife/cookbook_site_install_spec.rb +138 -0
- data/spec/unit/knife/cookbook_site_share_spec.rb +146 -0
- data/spec/unit/knife/cookbook_site_unshare_spec.rb +77 -0
- data/spec/unit/knife/cookbook_test_spec.rb +83 -0
- data/spec/unit/knife/cookbook_upload_spec.rb +143 -0
- data/spec/unit/knife/core/bootstrap_context_spec.rb +128 -0
- data/spec/unit/knife/core/cookbook_scm_repo_spec.rb +187 -0
- data/spec/unit/knife/core/object_loader_spec.rb +81 -0
- data/spec/unit/knife/core/subcommand_loader_spec.rb +54 -0
- data/spec/unit/knife/core/ui_spec.rb +160 -0
- data/spec/unit/knife/data_bag_create_spec.rb +96 -0
- data/spec/unit/knife/data_bag_edit_spec.rb +83 -0
- data/spec/unit/knife/data_bag_from_file_spec.rb +182 -0
- data/spec/unit/knife/data_bag_show_spec.rb +105 -0
- data/spec/unit/knife/environment_create_spec.rb +91 -0
- data/spec/unit/knife/environment_delete_spec.rb +71 -0
- data/spec/unit/knife/environment_edit_spec.rb +79 -0
- data/spec/unit/knife/environment_from_file_spec.rb +66 -0
- data/spec/unit/knife/environment_list_spec.rb +54 -0
- data/spec/unit/knife/environment_show_spec.rb +52 -0
- data/spec/unit/knife/index_rebuild_spec.rb +65 -0
- data/spec/unit/knife/knife_help.rb +92 -0
- data/spec/unit/knife/node_bulk_delete_spec.rb +97 -0
- data/spec/unit/knife/node_delete_spec.rb +68 -0
- data/spec/unit/knife/node_edit_spec.rb +88 -0
- data/spec/unit/knife/node_from_file_spec.rb +59 -0
- data/spec/unit/knife/node_list_spec.rb +63 -0
- data/spec/unit/knife/node_run_list_add_spec.rb +125 -0
- data/spec/unit/knife/node_run_list_remove_spec.rb +73 -0
- data/spec/unit/knife/node_show_spec.rb +48 -0
- data/spec/unit/knife/role_bulk_delete_spec.rb +80 -0
- data/spec/unit/knife/role_create_spec.rb +80 -0
- data/spec/unit/knife/role_delete_spec.rb +67 -0
- data/spec/unit/knife/role_edit_spec.rb +79 -0
- data/spec/unit/knife/role_from_file_spec.rb +69 -0
- data/spec/unit/knife/role_list_spec.rb +56 -0
- data/spec/unit/knife/tag_create_spec.rb +23 -0
- data/spec/unit/knife/tag_delete_spec.rb +25 -0
- data/spec/unit/knife/tag_list_spec.rb +23 -0
- data/spec/unit/knife_spec.rb +295 -0
- data/spec/unit/log_spec.rb +24 -0
- data/spec/unit/lwrp_spec.rb +231 -0
- data/spec/unit/mash_spec.rb +51 -0
- data/spec/unit/mixin/checksum_spec.rb +41 -0
- data/spec/unit/mixin/command_spec.rb +101 -0
- data/spec/unit/mixin/convert_to_class_name_spec.rb +50 -0
- data/spec/unit/mixin/deep_merge_spec.rb +786 -0
- data/spec/unit/mixin/deprecation_spec.rb +34 -0
- data/spec/unit/mixin/enforce_ownership_and_permissions_spec.rb +66 -0
- data/spec/unit/mixin/language_spec.rb +305 -0
- data/spec/unit/mixin/params_validate_spec.rb +370 -0
- data/spec/unit/mixin/path_sanity_spec.rb +80 -0
- data/spec/unit/mixin/securable_spec.rb +254 -0
- data/spec/unit/mixin/shell_out_spec.rb +109 -0
- data/spec/unit/mixin/template_spec.rb +104 -0
- data/spec/unit/mixin/xml_escape_spec.rb +54 -0
- data/spec/unit/monkey_patches/string_spec.rb +37 -0
- data/spec/unit/node/attribute_spec.rb +1033 -0
- data/spec/unit/node_spec.rb +744 -0
- data/spec/unit/openid_registration_spec.rb +153 -0
- data/spec/unit/platform_spec.rb +228 -0
- data/spec/unit/provider/breakpoint_spec.rb +54 -0
- data/spec/unit/provider/cookbook_file_spec.rb +209 -0
- data/spec/unit/provider/cron/solaris_spec.rb +121 -0
- data/spec/unit/provider/cron_spec.rb +766 -0
- data/spec/unit/provider/deploy/revision_spec.rb +108 -0
- data/spec/unit/provider/deploy/timestamped_spec.rb +40 -0
- data/spec/unit/provider/deploy_spec.rb +610 -0
- data/spec/unit/provider/directory_spec.rb +148 -0
- data/spec/unit/provider/env_spec.rb +232 -0
- data/spec/unit/provider/erl_call_spec.rb +88 -0
- data/spec/unit/provider/execute_spec.rb +60 -0
- data/spec/unit/provider/file_spec.rb +292 -0
- data/spec/unit/provider/git_spec.rb +352 -0
- data/spec/unit/provider/group/dscl_spec.rb +294 -0
- data/spec/unit/provider/group/gpasswd_spec.rb +108 -0
- data/spec/unit/provider/group/groupadd_spec.rb +161 -0
- data/spec/unit/provider/group/groupmod_spec.rb +134 -0
- data/spec/unit/provider/group/pw_spec.rb +140 -0
- data/spec/unit/provider/group/usermod_spec.rb +90 -0
- data/spec/unit/provider/group/windows_spec.rb +94 -0
- data/spec/unit/provider/group_spec.rb +259 -0
- data/spec/unit/provider/http_request_spec.rb +172 -0
- data/spec/unit/provider/ifconfig_spec.rb +213 -0
- data/spec/unit/provider/link_spec.rb +249 -0
- data/spec/unit/provider/log_spec.rb +81 -0
- data/spec/unit/provider/mdadm_spec.rb +131 -0
- data/spec/unit/provider/mount/mount_spec.rb +398 -0
- data/spec/unit/provider/mount/windows_spec.rb +134 -0
- data/spec/unit/provider/mount_spec.rb +160 -0
- data/spec/unit/provider/ohai_spec.rb +85 -0
- data/spec/unit/provider/package/apt_spec.rb +339 -0
- data/spec/unit/provider/package/dpkg_spec.rb +216 -0
- data/spec/unit/provider/package/easy_install_spec.rb +112 -0
- data/spec/unit/provider/package/freebsd_spec.rb +259 -0
- data/spec/unit/provider/package/macports_spec.rb +203 -0
- data/spec/unit/provider/package/pacman_spec.rb +177 -0
- data/spec/unit/provider/package/portage_spec.rb +276 -0
- data/spec/unit/provider/package/rpm_spec.rb +152 -0
- data/spec/unit/provider/package/rubygems_spec.rb +614 -0
- data/spec/unit/provider/package/smartos_spec.rb +83 -0
- data/spec/unit/provider/package/solaris_spec.rb +179 -0
- data/spec/unit/provider/package/yum_spec.rb +1795 -0
- data/spec/unit/provider/package/zypper_spec.rb +159 -0
- data/spec/unit/provider/package_spec.rb +423 -0
- data/spec/unit/provider/remote_directory_spec.rb +186 -0
- data/spec/unit/provider/remote_file_spec.rb +274 -0
- data/spec/unit/provider/route_spec.rb +230 -0
- data/spec/unit/provider/ruby_block_spec.rb +38 -0
- data/spec/unit/provider/script_spec.rb +96 -0
- data/spec/unit/provider/service/arch_service_spec.rb +330 -0
- data/spec/unit/provider/service/debian_service_spec.rb +254 -0
- data/spec/unit/provider/service/freebsd_service_spec.rb +351 -0
- data/spec/unit/provider/service/gentoo_service_spec.rb +144 -0
- data/spec/unit/provider/service/init_service_spec.rb +212 -0
- data/spec/unit/provider/service/insserv_service_spec.rb +76 -0
- data/spec/unit/provider/service/invokercd_service_spec.rb +212 -0
- data/spec/unit/provider/service/macosx_spec.rb +229 -0
- data/spec/unit/provider/service/redhat_spec.rb +155 -0
- data/spec/unit/provider/service/simple_service_spec.rb +171 -0
- data/spec/unit/provider/service/solaris_smf_service_spec.rb +140 -0
- data/spec/unit/provider/service/systemd_service_spec.rb +239 -0
- data/spec/unit/provider/service/upstart_service_spec.rb +314 -0
- data/spec/unit/provider/service/windows_spec.rb +235 -0
- data/spec/unit/provider/service_spec.rb +169 -0
- data/spec/unit/provider/subversion_spec.rb +281 -0
- data/spec/unit/provider/template_spec.rb +186 -0
- data/spec/unit/provider/user/dscl_spec.rb +439 -0
- data/spec/unit/provider/user/pw_spec.rb +235 -0
- data/spec/unit/provider/user/useradd_spec.rb +380 -0
- data/spec/unit/provider/user/windows_spec.rb +178 -0
- data/spec/unit/provider/user_spec.rb +466 -0
- data/spec/unit/provider_spec.rb +168 -0
- data/spec/unit/recipe_spec.rb +268 -0
- data/spec/unit/resource/apt_package_spec.rb +43 -0
- data/spec/unit/resource/bash_spec.rb +40 -0
- data/spec/unit/resource/breakpoint_spec.rb +43 -0
- data/spec/unit/resource/chef_gem_spec.rb +49 -0
- data/spec/unit/resource/conditional_spec.rb +147 -0
- data/spec/unit/resource/cookbook_file_spec.rb +48 -0
- data/spec/unit/resource/cron_spec.rb +154 -0
- data/spec/unit/resource/csh_spec.rb +40 -0
- data/spec/unit/resource/deploy_revision_spec.rb +47 -0
- data/spec/unit/resource/deploy_spec.rb +232 -0
- data/spec/unit/resource/directory_spec.rb +62 -0
- data/spec/unit/resource/dpkg_package_spec.rb +38 -0
- data/spec/unit/resource/easy_install_package_spec.rb +48 -0
- data/spec/unit/resource/env_spec.rb +66 -0
- data/spec/unit/resource/erl_call_spec.rb +69 -0
- data/spec/unit/resource/execute_spec.rb +108 -0
- data/spec/unit/resource/file_spec.rb +114 -0
- data/spec/unit/resource/freebsd_package_spec.rb +39 -0
- data/spec/unit/resource/gem_package_spec.rb +49 -0
- data/spec/unit/resource/git_spec.rb +46 -0
- data/spec/unit/resource/group_spec.rb +132 -0
- data/spec/unit/resource/http_request_spec.rb +46 -0
- data/spec/unit/resource/link_spec.rb +97 -0
- data/spec/unit/resource/log_spec.rb +51 -0
- data/spec/unit/resource/macports_package_spec.rb +37 -0
- data/spec/unit/resource/mdadm_spec.rb +80 -0
- data/spec/unit/resource/mount_spec.rb +138 -0
- data/spec/unit/resource/ohai_spec.rb +44 -0
- data/spec/unit/resource/package_spec.rb +77 -0
- data/spec/unit/resource/pacman_package_spec.rb +38 -0
- data/spec/unit/resource/perl_spec.rb +40 -0
- data/spec/unit/resource/portage_package_spec.rb +38 -0
- data/spec/unit/resource/python_spec.rb +40 -0
- data/spec/unit/resource/remote_directory_spec.rb +75 -0
- data/spec/unit/resource/remote_file_spec.rb +85 -0
- data/spec/unit/resource/route_spec.rb +88 -0
- data/spec/unit/resource/rpm_package_spec.rb +38 -0
- data/spec/unit/resource/ruby_block_spec.rb +46 -0
- data/spec/unit/resource/ruby_spec.rb +40 -0
- data/spec/unit/resource/scm_spec.rb +139 -0
- data/spec/unit/resource/script_spec.rb +55 -0
- data/spec/unit/resource/service_spec.rb +144 -0
- data/spec/unit/resource/smartos_package_spec.rb +38 -0
- data/spec/unit/resource/subversion_spec.rb +58 -0
- data/spec/unit/resource/template_spec.rb +101 -0
- data/spec/unit/resource/timestamped_deploy_spec.rb +28 -0
- data/spec/unit/resource/user_spec.rb +101 -0
- data/spec/unit/resource/yum_package_spec.rb +85 -0
- data/spec/unit/resource_collection/stepable_iterator_spec.rb +144 -0
- data/spec/unit/resource_collection_spec.rb +257 -0
- data/spec/unit/resource_definition_spec.rb +119 -0
- data/spec/unit/resource_platform_map_spec.rb +164 -0
- data/spec/unit/resource_reporter_spec.rb +425 -0
- data/spec/unit/resource_spec.rb +611 -0
- data/spec/unit/rest/auth_credentials_spec.rb +409 -0
- data/spec/unit/rest_spec.rb +644 -0
- data/spec/unit/role_spec.rb +275 -0
- data/spec/unit/run_context_spec.rb +64 -0
- data/spec/unit/run_list/run_list_expansion_spec.rb +129 -0
- data/spec/unit/run_list/run_list_item_spec.rb +117 -0
- data/spec/unit/run_list/versioned_recipe_list_spec.rb +123 -0
- data/spec/unit/run_list_spec.rb +507 -0
- data/spec/unit/run_status_spec.rb +145 -0
- data/spec/unit/runner_spec.rb +303 -0
- data/spec/unit/scan_access_control_spec.rb +151 -0
- data/spec/unit/search/query_spec.rb +99 -0
- data/spec/unit/shef/model_wrapper_spec.rb +97 -0
- data/spec/unit/shef/shef_ext_spec.rb +153 -0
- data/spec/unit/shef/shef_session_spec.rb +141 -0
- data/spec/unit/shef_spec.rb +161 -0
- data/spec/unit/solr_query/query_transform_spec.rb +450 -0
- data/spec/unit/solr_query/solr_http_request_spec.rb +244 -0
- data/spec/unit/solr_query_spec.rb +203 -0
- data/spec/unit/util/file_edit_spec.rb +135 -0
- data/spec/unit/version_class_spec.rb +172 -0
- data/spec/unit/version_constraint_spec.rb +134 -0
- data/spec/unit/webui_user_spec.rb +238 -0
- data/tasks/rspec.rb +75 -0
- metadata +884 -435
@@ -0,0 +1,744 @@
|
|
1
|
+
#
|
2
|
+
# Author:: Adam Jacob (<adam@opscode.com>)
|
3
|
+
# Copyright:: Copyright (c) 2008 Opscode, Inc.
|
4
|
+
# License:: Apache License, Version 2.0
|
5
|
+
#
|
6
|
+
# Licensed under the Apache License, Version 2.0 (the "License");
|
7
|
+
# you may not use this file except in compliance with the License.
|
8
|
+
# You may obtain a copy of the License at
|
9
|
+
#
|
10
|
+
# http://www.apache.org/licenses/LICENSE-2.0
|
11
|
+
#
|
12
|
+
# Unless required by applicable law or agreed to in writing, software
|
13
|
+
# distributed under the License is distributed on an "AS IS" BASIS,
|
14
|
+
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
15
|
+
# See the License for the specific language governing permissions and
|
16
|
+
# limitations under the License.
|
17
|
+
#
|
18
|
+
|
19
|
+
require 'spec_helper'
|
20
|
+
require 'ostruct'
|
21
|
+
|
22
|
+
describe Chef::Node do
|
23
|
+
before(:each) do
|
24
|
+
Chef::Config.node_path(File.expand_path(File.join(CHEF_SPEC_DATA, "nodes")))
|
25
|
+
@node = Chef::Node.new()
|
26
|
+
end
|
27
|
+
|
28
|
+
it "creates a node and assigns it a name" do
|
29
|
+
node = Chef::Node.build('solo-node')
|
30
|
+
node.name.should == 'solo-node'
|
31
|
+
end
|
32
|
+
|
33
|
+
it "should validate the name of the node" do
|
34
|
+
lambda{Chef::Node.build('solo node')}.should raise_error(Chef::Exceptions::ValidationFailed)
|
35
|
+
end
|
36
|
+
|
37
|
+
describe "when the node does not exist on the server" do
|
38
|
+
before do
|
39
|
+
response = OpenStruct.new(:code => '404')
|
40
|
+
exception = Net::HTTPServerException.new("404 not found", response)
|
41
|
+
Chef::Node.stub!(:load).and_raise(exception)
|
42
|
+
@node.name("created-node")
|
43
|
+
end
|
44
|
+
|
45
|
+
it "creates a new node for find_or_create" do
|
46
|
+
Chef::Node.stub!(:new).and_return(@node)
|
47
|
+
@node.should_receive(:create).and_return(@node)
|
48
|
+
node = Chef::Node.find_or_create("created-node")
|
49
|
+
node.name.should == 'created-node'
|
50
|
+
node.should equal(@node)
|
51
|
+
end
|
52
|
+
end
|
53
|
+
|
54
|
+
describe "when the node exists on the server" do
|
55
|
+
before do
|
56
|
+
@node.name('existing-node')
|
57
|
+
Chef::Node.stub!(:load).and_return(@node)
|
58
|
+
end
|
59
|
+
|
60
|
+
it "loads the node via the REST API for find_or_create" do
|
61
|
+
Chef::Node.find_or_create('existing-node').should equal(@node)
|
62
|
+
end
|
63
|
+
end
|
64
|
+
|
65
|
+
describe "run_state" do
|
66
|
+
it "should have a template_cache hash" do
|
67
|
+
@node.run_state[:template_cache].should be_a_kind_of(Hash)
|
68
|
+
end
|
69
|
+
|
70
|
+
it "should have a seen_recipes hash" do
|
71
|
+
@node.run_state[:seen_recipes].should be_a_kind_of(Hash)
|
72
|
+
end
|
73
|
+
end
|
74
|
+
|
75
|
+
describe "initialize" do
|
76
|
+
it "should default to the '_default' chef_environment" do
|
77
|
+
n = Chef::Node.new
|
78
|
+
n.chef_environment.should == '_default'
|
79
|
+
end
|
80
|
+
end
|
81
|
+
|
82
|
+
describe "name" do
|
83
|
+
it "should allow you to set a name with name(something)" do
|
84
|
+
lambda { @node.name("latte") }.should_not raise_error
|
85
|
+
end
|
86
|
+
|
87
|
+
it "should return the name with name()" do
|
88
|
+
@node.name("latte")
|
89
|
+
@node.name.should eql("latte")
|
90
|
+
end
|
91
|
+
|
92
|
+
it "should always have a string for name" do
|
93
|
+
lambda { @node.name(Hash.new) }.should raise_error(ArgumentError)
|
94
|
+
end
|
95
|
+
|
96
|
+
it "cannot be blank" do
|
97
|
+
lambda { @node.name("")}.should raise_error(Chef::Exceptions::ValidationFailed)
|
98
|
+
end
|
99
|
+
|
100
|
+
it "should not accept name doesn't match /^[\-[:alnum:]_:.]+$/" do
|
101
|
+
lambda { @node.name("space in it")}.should raise_error(Chef::Exceptions::ValidationFailed)
|
102
|
+
end
|
103
|
+
end
|
104
|
+
|
105
|
+
describe "chef_environment" do
|
106
|
+
it "should set an environment with chef_environment(something)" do
|
107
|
+
lambda { @node.chef_environment("latte") }.should_not raise_error
|
108
|
+
end
|
109
|
+
|
110
|
+
it "should return the chef_environment with chef_environment()" do
|
111
|
+
@node.chef_environment("latte")
|
112
|
+
@node.chef_environment.should == "latte"
|
113
|
+
end
|
114
|
+
|
115
|
+
it "should disallow non-strings" do
|
116
|
+
lambda { @node.chef_environment(Hash.new) }.should raise_error(ArgumentError)
|
117
|
+
lambda { @node.chef_environment(42) }.should raise_error(ArgumentError)
|
118
|
+
end
|
119
|
+
|
120
|
+
it "cannot be blank" do
|
121
|
+
lambda { @node.chef_environment("")}.should raise_error(Chef::Exceptions::ValidationFailed)
|
122
|
+
end
|
123
|
+
end
|
124
|
+
|
125
|
+
describe "attributes" do
|
126
|
+
it "should be loaded from the node's cookbooks" do
|
127
|
+
@cookbook_repo = File.expand_path(File.join(File.dirname(__FILE__), "..", "data", "cookbooks"))
|
128
|
+
@node.cookbook_collection = Chef::CookbookCollection.new(Chef::CookbookLoader.new(@cookbook_repo))
|
129
|
+
@node.load_attributes
|
130
|
+
@node.ldap_server.should eql("ops1prod")
|
131
|
+
@node.ldap_basedn.should eql("dc=hjksolutions,dc=com")
|
132
|
+
@node.ldap_replication_password.should eql("forsure")
|
133
|
+
@node.smokey.should eql("robinson")
|
134
|
+
end
|
135
|
+
|
136
|
+
it "should have attributes" do
|
137
|
+
@node.attribute.should be_a_kind_of(Hash)
|
138
|
+
end
|
139
|
+
|
140
|
+
it "should allow attributes to be accessed by name or symbol directly on node[]" do
|
141
|
+
@node.attribute["locust"] = "something"
|
142
|
+
@node[:locust].should eql("something")
|
143
|
+
@node["locust"].should eql("something")
|
144
|
+
end
|
145
|
+
|
146
|
+
it "should return nil if it cannot find an attribute with node[]" do
|
147
|
+
@node["secret"].should eql(nil)
|
148
|
+
end
|
149
|
+
|
150
|
+
it "should allow you to set an attribute via node[]=" do
|
151
|
+
@node["secret"] = "shush"
|
152
|
+
@node["secret"].should eql("shush")
|
153
|
+
end
|
154
|
+
|
155
|
+
it "should allow you to query whether an attribute exists with attribute?" do
|
156
|
+
@node.attribute["locust"] = "something"
|
157
|
+
@node.attribute?("locust").should eql(true)
|
158
|
+
@node.attribute?("no dice").should eql(false)
|
159
|
+
end
|
160
|
+
|
161
|
+
it "should let you go deep with attribute?" do
|
162
|
+
@node.set["battles"]["people"]["wonkey"] = true
|
163
|
+
@node["battles"]["people"].attribute?("wonkey").should == true
|
164
|
+
@node["battles"]["people"].attribute?("snozzberry").should == false
|
165
|
+
end
|
166
|
+
|
167
|
+
it "should allow you to set an attribute via method_missing" do
|
168
|
+
@node.sunshine "is bright"
|
169
|
+
@node.attribute[:sunshine].should eql("is bright")
|
170
|
+
end
|
171
|
+
|
172
|
+
it "should allow you get get an attribute via method_missing" do
|
173
|
+
@node.sunshine "is bright"
|
174
|
+
@node.sunshine.should eql("is bright")
|
175
|
+
end
|
176
|
+
|
177
|
+
describe "normal attributes" do
|
178
|
+
it "should allow you to set an attribute with set, without pre-declaring a hash" do
|
179
|
+
@node.set[:snoopy][:is_a_puppy] = true
|
180
|
+
@node[:snoopy][:is_a_puppy].should == true
|
181
|
+
end
|
182
|
+
|
183
|
+
it "should allow you to set an attribute with set_unless" do
|
184
|
+
@node.set_unless[:snoopy][:is_a_puppy] = false
|
185
|
+
@node[:snoopy][:is_a_puppy].should == false
|
186
|
+
end
|
187
|
+
|
188
|
+
it "should not allow you to set an attribute with set_unless if it already exists" do
|
189
|
+
@node.set[:snoopy][:is_a_puppy] = true
|
190
|
+
@node.set_unless[:snoopy][:is_a_puppy] = false
|
191
|
+
@node[:snoopy][:is_a_puppy].should == true
|
192
|
+
end
|
193
|
+
|
194
|
+
it "auto-vivifies attributes created via method syntax" do
|
195
|
+
@node.set.fuu.bahrr.baz = "qux"
|
196
|
+
@node.fuu.bahrr.baz.should == "qux"
|
197
|
+
end
|
198
|
+
|
199
|
+
end
|
200
|
+
|
201
|
+
describe "default attributes" do
|
202
|
+
it "should be set with default, without pre-declaring a hash" do
|
203
|
+
@node.default[:snoopy][:is_a_puppy] = true
|
204
|
+
@node[:snoopy][:is_a_puppy].should == true
|
205
|
+
end
|
206
|
+
|
207
|
+
it "should allow you to set with default_unless without pre-declaring a hash" do
|
208
|
+
@node.default_unless[:snoopy][:is_a_puppy] = false
|
209
|
+
@node[:snoopy][:is_a_puppy].should == false
|
210
|
+
end
|
211
|
+
|
212
|
+
it "should not allow you to set an attribute with default_unless if it already exists" do
|
213
|
+
@node.default[:snoopy][:is_a_puppy] = true
|
214
|
+
@node.default_unless[:snoopy][:is_a_puppy] = false
|
215
|
+
@node[:snoopy][:is_a_puppy].should == true
|
216
|
+
end
|
217
|
+
|
218
|
+
it "auto-vivifies attributes created via method syntax" do
|
219
|
+
@node.default.fuu.bahrr.baz = "qux"
|
220
|
+
@node.fuu.bahrr.baz.should == "qux"
|
221
|
+
end
|
222
|
+
|
223
|
+
end
|
224
|
+
|
225
|
+
describe "override attributes" do
|
226
|
+
it "should be set with override, without pre-declaring a hash" do
|
227
|
+
@node.override[:snoopy][:is_a_puppy] = true
|
228
|
+
@node[:snoopy][:is_a_puppy].should == true
|
229
|
+
end
|
230
|
+
|
231
|
+
it "should allow you to set with override_unless without pre-declaring a hash" do
|
232
|
+
@node.override_unless[:snoopy][:is_a_puppy] = false
|
233
|
+
@node[:snoopy][:is_a_puppy].should == false
|
234
|
+
end
|
235
|
+
|
236
|
+
it "should not allow you to set an attribute with override_unless if it already exists" do
|
237
|
+
@node.override[:snoopy][:is_a_puppy] = true
|
238
|
+
@node.override_unless[:snoopy][:is_a_puppy] = false
|
239
|
+
@node[:snoopy][:is_a_puppy].should == true
|
240
|
+
end
|
241
|
+
|
242
|
+
it "auto-vivifies attributes created via method syntax" do
|
243
|
+
@node.override.fuu.bahrr.baz = "qux"
|
244
|
+
@node.fuu.bahrr.baz.should == "qux"
|
245
|
+
end
|
246
|
+
|
247
|
+
end
|
248
|
+
|
249
|
+
it "should raise an ArgumentError if you ask for an attribute that doesn't exist via method_missing" do
|
250
|
+
lambda { @node.sunshine }.should raise_error(ArgumentError)
|
251
|
+
end
|
252
|
+
|
253
|
+
it "should allow you to iterate over attributes with each_attribute" do
|
254
|
+
@node.sunshine "is bright"
|
255
|
+
@node.canada "is a nice place"
|
256
|
+
seen_attributes = Hash.new
|
257
|
+
@node.each_attribute do |a,v|
|
258
|
+
seen_attributes[a] = v
|
259
|
+
end
|
260
|
+
seen_attributes.should have_key("sunshine")
|
261
|
+
seen_attributes.should have_key("canada")
|
262
|
+
seen_attributes["sunshine"].should == "is bright"
|
263
|
+
seen_attributes["canada"].should == "is a nice place"
|
264
|
+
end
|
265
|
+
end
|
266
|
+
|
267
|
+
describe "consuming json" do
|
268
|
+
|
269
|
+
before do
|
270
|
+
@ohai_data = {:platform => 'foo', :platform_version => 'bar'}
|
271
|
+
end
|
272
|
+
|
273
|
+
it "consumes the run list portion of a collection of attributes and returns the remainder" do
|
274
|
+
attrs = {"run_list" => [ "role[base]", "recipe[chef::server]" ], "foo" => "bar"}
|
275
|
+
@node.consume_run_list(attrs).should == {"foo" => "bar"}
|
276
|
+
@node.run_list.should == [ "role[base]", "recipe[chef::server]" ]
|
277
|
+
end
|
278
|
+
|
279
|
+
it "should overwrites the run list with the run list it consumes" do
|
280
|
+
@node.consume_run_list "recipes" => [ "one", "two" ]
|
281
|
+
@node.consume_run_list "recipes" => [ "three" ]
|
282
|
+
@node.run_list.should == [ "three" ]
|
283
|
+
end
|
284
|
+
|
285
|
+
it "should not add duplicate recipes from the json attributes" do
|
286
|
+
@node.run_list << "one"
|
287
|
+
@node.consume_run_list "recipes" => [ "one", "two", "three" ]
|
288
|
+
@node.run_list.should == [ "one", "two", "three" ]
|
289
|
+
end
|
290
|
+
|
291
|
+
it "doesn't change the run list if no run_list is specified in the json" do
|
292
|
+
@node.run_list << "role[database]"
|
293
|
+
@node.consume_run_list "foo" => "bar"
|
294
|
+
@node.run_list.should == ["role[database]"]
|
295
|
+
end
|
296
|
+
|
297
|
+
it "raises an exception if you provide both recipe and run_list attributes, since this is ambiguous" do
|
298
|
+
lambda { @node.consume_run_list "recipes" => "stuff", "run_list" => "other_stuff" }.should raise_error(Chef::Exceptions::AmbiguousRunlistSpecification)
|
299
|
+
end
|
300
|
+
|
301
|
+
it "should add json attributes to the node" do
|
302
|
+
@node.consume_external_attrs(@ohai_data, {"one" => "two", "three" => "four"})
|
303
|
+
@node.one.should eql("two")
|
304
|
+
@node.three.should eql("four")
|
305
|
+
end
|
306
|
+
|
307
|
+
it "should set the tags attribute to an empty array if it is not already defined" do
|
308
|
+
@node.consume_external_attrs(@ohai_data, {})
|
309
|
+
@node.tags.should eql([])
|
310
|
+
end
|
311
|
+
|
312
|
+
it "should not set the tags attribute to an empty array if it is already defined" do
|
313
|
+
@node[:tags] = [ "radiohead" ]
|
314
|
+
@node.consume_external_attrs(@ohai_data, {})
|
315
|
+
@node.tags.should eql([ "radiohead" ])
|
316
|
+
end
|
317
|
+
|
318
|
+
it "deep merges attributes instead of overwriting them" do
|
319
|
+
@node.consume_external_attrs(@ohai_data, "one" => {"two" => {"three" => "four"}})
|
320
|
+
@node.one.to_hash.should == {"two" => {"three" => "four"}}
|
321
|
+
@node.consume_external_attrs(@ohai_data, "one" => {"abc" => "123"})
|
322
|
+
@node.consume_external_attrs(@ohai_data, "one" => {"two" => {"foo" => "bar"}})
|
323
|
+
@node.one.to_hash.should == {"two" => {"three" => "four", "foo" => "bar"}, "abc" => "123"}
|
324
|
+
end
|
325
|
+
|
326
|
+
it "gives attributes from JSON priority when deep merging" do
|
327
|
+
@node.consume_external_attrs(@ohai_data, "one" => {"two" => {"three" => "four"}})
|
328
|
+
@node.one.to_hash.should == {"two" => {"three" => "four"}}
|
329
|
+
@node.consume_external_attrs(@ohai_data, "one" => {"two" => {"three" => "forty-two"}})
|
330
|
+
@node.one.to_hash.should == {"two" => {"three" => "forty-two"}}
|
331
|
+
end
|
332
|
+
|
333
|
+
end
|
334
|
+
|
335
|
+
describe "preparing for a chef client run" do
|
336
|
+
before do
|
337
|
+
@ohai_data = {:platform => 'foobuntu', :platform_version => '23.42'}
|
338
|
+
end
|
339
|
+
|
340
|
+
it "sets its platform according to platform detection" do
|
341
|
+
@node.consume_external_attrs(@ohai_data, {})
|
342
|
+
@node.automatic_attrs[:platform].should == 'foobuntu'
|
343
|
+
@node.automatic_attrs[:platform_version].should == '23.42'
|
344
|
+
end
|
345
|
+
|
346
|
+
it "consumes the run list from provided json attributes" do
|
347
|
+
@node.consume_external_attrs(@ohai_data, {"run_list" => ['recipe[unicorn]']})
|
348
|
+
@node.run_list.should == ['recipe[unicorn]']
|
349
|
+
end
|
350
|
+
|
351
|
+
it "saves non-runlist json attrs for later" do
|
352
|
+
expansion = Chef::RunList::RunListExpansion.new('_default', [])
|
353
|
+
@node.run_list.stub!(:expand).and_return(expansion)
|
354
|
+
@node.consume_external_attrs(@ohai_data, {"foo" => "bar"})
|
355
|
+
@node.expand!
|
356
|
+
@node.normal_attrs.should == {"foo" => "bar", "tags" => []}
|
357
|
+
end
|
358
|
+
|
359
|
+
end
|
360
|
+
|
361
|
+
describe "when expanding its run list and merging attributes" do
|
362
|
+
before do
|
363
|
+
@expansion = Chef::RunList::RunListExpansion.new("_default", [])
|
364
|
+
@node.run_list.stub!(:expand).and_return(@expansion)
|
365
|
+
end
|
366
|
+
|
367
|
+
it "sets the 'recipes' automatic attribute to the recipes in the expanded run_list" do
|
368
|
+
@expansion.recipes << 'recipe[chef::client]' << 'recipe[nginx::default]'
|
369
|
+
@node.expand!
|
370
|
+
@node.automatic_attrs[:recipes].should == ['recipe[chef::client]', 'recipe[nginx::default]']
|
371
|
+
end
|
372
|
+
|
373
|
+
it "sets the 'roles' automatic attribute to the expanded role list" do
|
374
|
+
@expansion.instance_variable_set(:@applied_roles, {'arf' => nil, 'countersnark' => nil})
|
375
|
+
@node.expand!
|
376
|
+
@node.automatic_attrs[:roles].sort.should == ['arf', 'countersnark']
|
377
|
+
end
|
378
|
+
|
379
|
+
end
|
380
|
+
|
381
|
+
# TODO: timh, cw: 2010-5-19: Node.recipe? deprecated. See node.rb
|
382
|
+
# describe "recipes" do
|
383
|
+
# it "should have a RunList of recipes that should be applied" do
|
384
|
+
# @node.recipes.should be_a_kind_of(Chef::RunList)
|
385
|
+
# end
|
386
|
+
#
|
387
|
+
# it "should allow you to query whether or not it has a recipe applied with recipe?" do
|
388
|
+
# @node.recipes << "sunrise"
|
389
|
+
# @node.recipe?("sunrise").should eql(true)
|
390
|
+
# @node.recipe?("not at home").should eql(false)
|
391
|
+
# end
|
392
|
+
#
|
393
|
+
# it "should allow you to query whether or not a recipe has been applied, even if it was included" do
|
394
|
+
# @node.run_state[:seen_recipes]["snakes"] = true
|
395
|
+
# @node.recipe?("snakes").should eql(true)
|
396
|
+
# end
|
397
|
+
#
|
398
|
+
# it "should return false if a recipe has not been seen" do
|
399
|
+
# @node.recipe?("snakes").should eql(false)
|
400
|
+
# end
|
401
|
+
#
|
402
|
+
# it "should allow you to set recipes with arguments" do
|
403
|
+
# @node.recipes "one", "two"
|
404
|
+
# @node.recipe?("one").should eql(true)
|
405
|
+
# @node.recipe?("two").should eql(true)
|
406
|
+
# end
|
407
|
+
# end
|
408
|
+
|
409
|
+
describe "roles" do
|
410
|
+
it "should allow you to query whether or not it has a recipe applied with role?" do
|
411
|
+
@node.run_list << "role[sunrise]"
|
412
|
+
@node.role?("sunrise").should eql(true)
|
413
|
+
@node.role?("not at home").should eql(false)
|
414
|
+
end
|
415
|
+
|
416
|
+
it "should allow you to set roles with arguments" do
|
417
|
+
@node.run_list << "role[one]"
|
418
|
+
@node.run_list << "role[two]"
|
419
|
+
@node.role?("one").should eql(true)
|
420
|
+
@node.role?("two").should eql(true)
|
421
|
+
end
|
422
|
+
end
|
423
|
+
|
424
|
+
describe "run_list" do
|
425
|
+
it "should have a Chef::RunList of recipes and roles that should be applied" do
|
426
|
+
@node.run_list.should be_a_kind_of(Chef::RunList)
|
427
|
+
end
|
428
|
+
|
429
|
+
it "should allow you to query the run list with arguments" do
|
430
|
+
@node.run_list "recipe[baz]"
|
431
|
+
@node.run_list?("recipe[baz]").should eql(true)
|
432
|
+
end
|
433
|
+
|
434
|
+
it "should allow you to set the run list with arguments" do
|
435
|
+
@node.run_list "recipe[baz]", "role[foo]"
|
436
|
+
@node.run_list?("recipe[baz]").should eql(true)
|
437
|
+
@node.run_list?("role[foo]").should eql(true)
|
438
|
+
end
|
439
|
+
end
|
440
|
+
|
441
|
+
describe "from file" do
|
442
|
+
it "should load a node from a ruby file" do
|
443
|
+
@node.from_file(File.expand_path(File.join(CHEF_SPEC_DATA, "nodes", "test.rb")))
|
444
|
+
@node.name.should eql("test.example.com-short")
|
445
|
+
@node.sunshine.should eql("in")
|
446
|
+
@node.something.should eql("else")
|
447
|
+
@node.recipes.should == ["operations-master", "operations-monitoring"]
|
448
|
+
end
|
449
|
+
|
450
|
+
it "should raise an exception if the file cannot be found or read" do
|
451
|
+
lambda { @node.from_file("/tmp/monkeydiving") }.should raise_error(IOError)
|
452
|
+
end
|
453
|
+
end
|
454
|
+
|
455
|
+
describe "find_file" do
|
456
|
+
it "should load a node from a file by fqdn" do
|
457
|
+
@node.find_file("test.example.com")
|
458
|
+
@node.name.should == "test.example.com"
|
459
|
+
@node.chef_environment.should == "dev"
|
460
|
+
end
|
461
|
+
|
462
|
+
it "should load a node from a file by hostname" do
|
463
|
+
File.stub!(:exists?).and_return(true)
|
464
|
+
File.should_receive(:exists?).with(File.join(Chef::Config[:node_path], "test.example.com.rb")).and_return(false)
|
465
|
+
@node.find_file("test.example.com")
|
466
|
+
@node.name.should == "test.example.com-short"
|
467
|
+
end
|
468
|
+
|
469
|
+
it "should load a node from the default file" do
|
470
|
+
File.stub!(:exists?).and_return(true)
|
471
|
+
File.should_receive(:exists?).with(File.join(Chef::Config[:node_path], "test.example.com.rb")).and_return(false)
|
472
|
+
File.should_receive(:exists?).with(File.join(Chef::Config[:node_path], "test.rb")).and_return(false)
|
473
|
+
@node.find_file("test.example.com")
|
474
|
+
@node.name.should == "test.example.com-default"
|
475
|
+
end
|
476
|
+
|
477
|
+
it "should raise an ArgumentError if it cannot find any node file at all" do
|
478
|
+
File.stub!(:exists?).and_return(true)
|
479
|
+
File.should_receive(:exists?).with(File.join(Chef::Config[:node_path], "test.example.com.rb")).and_return(false)
|
480
|
+
File.should_receive(:exists?).with(File.join(Chef::Config[:node_path], "test.rb")).and_return(false)
|
481
|
+
File.should_receive(:exists?).with(File.join(Chef::Config[:node_path], "default.rb")).and_return(false)
|
482
|
+
lambda { @node.find_file("test.example.com") }.should raise_error(ArgumentError)
|
483
|
+
end
|
484
|
+
end
|
485
|
+
|
486
|
+
describe "update_from!" do
|
487
|
+
before(:each) do
|
488
|
+
@node.name("orig")
|
489
|
+
@node.chef_environment("dev")
|
490
|
+
@node.default_attrs = { "one" => { "two" => "three", "four" => "five", "eight" => "nine" } }
|
491
|
+
@node.override_attrs = { "one" => { "two" => "three", "four" => "six" } }
|
492
|
+
@node.normal_attrs = { "one" => { "two" => "seven" } }
|
493
|
+
@node.run_list << "role[marxist]"
|
494
|
+
@node.run_list << "role[leninist]"
|
495
|
+
@node.run_list << "recipe[stalinist]"
|
496
|
+
|
497
|
+
@example = Chef::Node.new()
|
498
|
+
@example.name("newname")
|
499
|
+
@example.chef_environment("prod")
|
500
|
+
@example.default_attrs = { "alpha" => { "bravo" => "charlie", "delta" => "echo" } }
|
501
|
+
@example.override_attrs = { "alpha" => { "bravo" => "foxtrot", "delta" => "golf" } }
|
502
|
+
@example.normal_attrs = { "alpha" => { "bravo" => "hotel" } }
|
503
|
+
@example.run_list << "role[comedy]"
|
504
|
+
@example.run_list << "role[drama]"
|
505
|
+
@example.run_list << "recipe[mystery]"
|
506
|
+
end
|
507
|
+
|
508
|
+
it "allows update of everything except name" do
|
509
|
+
@node.update_from!(@example)
|
510
|
+
@node.name.should == "orig"
|
511
|
+
@node.chef_environment.should == @example.chef_environment
|
512
|
+
@node.default_attrs.should == @example.default_attrs
|
513
|
+
@node.override_attrs.should == @example.override_attrs
|
514
|
+
@node.normal_attrs.should == @example.normal_attrs
|
515
|
+
@node.run_list.should == @example.run_list
|
516
|
+
end
|
517
|
+
|
518
|
+
it "should not update the name of the node" do
|
519
|
+
@node.should_not_receive(:name).with(@example.name)
|
520
|
+
@node.update_from!(@example)
|
521
|
+
end
|
522
|
+
end
|
523
|
+
|
524
|
+
describe "to_hash" do
|
525
|
+
it "should serialize itself as a hash" do
|
526
|
+
@node.chef_environment("dev")
|
527
|
+
@node.default_attrs = { "one" => { "two" => "three", "four" => "five", "eight" => "nine" } }
|
528
|
+
@node.override_attrs = { "one" => { "two" => "three", "four" => "six" } }
|
529
|
+
@node.normal_attrs = { "one" => { "two" => "seven" } }
|
530
|
+
@node.run_list << "role[marxist]"
|
531
|
+
@node.run_list << "role[leninist]"
|
532
|
+
@node.run_list << "recipe[stalinist]"
|
533
|
+
h = @node.to_hash
|
534
|
+
h["one"]["two"].should == "three"
|
535
|
+
h["one"]["four"].should == "six"
|
536
|
+
h["one"]["eight"].should == "nine"
|
537
|
+
h["role"].should be_include("marxist")
|
538
|
+
h["role"].should be_include("leninist")
|
539
|
+
h["run_list"].should be_include("role[marxist]")
|
540
|
+
h["run_list"].should be_include("role[leninist]")
|
541
|
+
h["run_list"].should be_include("recipe[stalinist]")
|
542
|
+
h["chef_environment"].should == "dev"
|
543
|
+
end
|
544
|
+
end
|
545
|
+
|
546
|
+
describe "json" do
|
547
|
+
it "should serialize itself as json", :json => true do
|
548
|
+
@node.find_file("test.example.com")
|
549
|
+
json = Chef::JSONCompat.to_json(@node)
|
550
|
+
json.should =~ /json_class/
|
551
|
+
json.should =~ /name/
|
552
|
+
json.should =~ /chef_environment/
|
553
|
+
json.should =~ /normal/
|
554
|
+
json.should =~ /default/
|
555
|
+
json.should =~ /override/
|
556
|
+
json.should =~ /run_list/
|
557
|
+
end
|
558
|
+
|
559
|
+
it 'should serialze valid json with a run list', :json => true do
|
560
|
+
#This test came about because activesupport mucks with Chef json serialization
|
561
|
+
#Test should pass with and without Activesupport
|
562
|
+
@node.run_list << {"type" => "role", "name" => 'Cthulu'}
|
563
|
+
@node.run_list << {"type" => "role", "name" => 'Hastur'}
|
564
|
+
json = Chef::JSONCompat.to_json(@node)
|
565
|
+
json.should =~ /\"run_list\":\[\"role\[Cthulu\]\",\"role\[Hastur\]\"\]/
|
566
|
+
end
|
567
|
+
|
568
|
+
it "should deserialize itself from json", :json => true do
|
569
|
+
@node.find_file("test.example.com")
|
570
|
+
json = Chef::JSONCompat.to_json(@node)
|
571
|
+
serialized_node = Chef::JSONCompat.from_json(json)
|
572
|
+
serialized_node.should be_a_kind_of(Chef::Node)
|
573
|
+
serialized_node.name.should eql(@node.name)
|
574
|
+
serialized_node.chef_environment.should eql(@node.chef_environment)
|
575
|
+
@node.each_attribute do |k,v|
|
576
|
+
serialized_node[k].should eql(v)
|
577
|
+
end
|
578
|
+
serialized_node.run_list.should == @node.run_list
|
579
|
+
end
|
580
|
+
end
|
581
|
+
|
582
|
+
describe "to_s" do
|
583
|
+
it "should turn into a string like node[name]" do
|
584
|
+
@node.name("airplane")
|
585
|
+
@node.to_s.should eql("node[airplane]")
|
586
|
+
end
|
587
|
+
end
|
588
|
+
|
589
|
+
describe "api model" do
|
590
|
+
before(:each) do
|
591
|
+
@rest = mock("Chef::REST")
|
592
|
+
Chef::REST.stub!(:new).and_return(@rest)
|
593
|
+
@query = mock("Chef::Search::Query")
|
594
|
+
Chef::Search::Query.stub!(:new).and_return(@query)
|
595
|
+
end
|
596
|
+
|
597
|
+
describe "list" do
|
598
|
+
describe "inflated" do
|
599
|
+
it "should return a hash of node names and objects" do
|
600
|
+
n1 = mock("Chef::Node", :name => "one")
|
601
|
+
@query.should_receive(:search).with(:node).and_yield(n1)
|
602
|
+
r = Chef::Node.list(true)
|
603
|
+
r["one"].should == n1
|
604
|
+
end
|
605
|
+
end
|
606
|
+
|
607
|
+
it "should return a hash of node names and urls" do
|
608
|
+
@rest.should_receive(:get_rest).and_return({ "one" => "http://foo" })
|
609
|
+
r = Chef::Node.list
|
610
|
+
r["one"].should == "http://foo"
|
611
|
+
end
|
612
|
+
end
|
613
|
+
|
614
|
+
describe "load" do
|
615
|
+
it "should load a node by name" do
|
616
|
+
@rest.should_receive(:get_rest).with("nodes/monkey").and_return("foo")
|
617
|
+
Chef::Node.load("monkey").should == "foo"
|
618
|
+
end
|
619
|
+
end
|
620
|
+
|
621
|
+
describe "destroy" do
|
622
|
+
it "should destroy a node" do
|
623
|
+
@rest.should_receive(:delete_rest).with("nodes/monkey").and_return("foo")
|
624
|
+
@node.name("monkey")
|
625
|
+
@node.destroy
|
626
|
+
end
|
627
|
+
end
|
628
|
+
|
629
|
+
describe "save" do
|
630
|
+
it "should update a node if it already exists" do
|
631
|
+
@node.name("monkey")
|
632
|
+
@rest.should_receive(:put_rest).with("nodes/monkey", @node).and_return("foo")
|
633
|
+
@node.save
|
634
|
+
end
|
635
|
+
|
636
|
+
it "should not try and create if it can update" do
|
637
|
+
@node.name("monkey")
|
638
|
+
@rest.should_receive(:put_rest).with("nodes/monkey", @node).and_return("foo")
|
639
|
+
@rest.should_not_receive(:post_rest)
|
640
|
+
@node.save
|
641
|
+
end
|
642
|
+
|
643
|
+
it "should create if it cannot update" do
|
644
|
+
@node.name("monkey")
|
645
|
+
exception = mock("404 error", :code => "404")
|
646
|
+
@rest.should_receive(:put_rest).and_raise(Net::HTTPServerException.new("foo", exception))
|
647
|
+
@rest.should_receive(:post_rest).with("nodes", @node)
|
648
|
+
@node.save
|
649
|
+
end
|
650
|
+
|
651
|
+
describe "when whyrun mode is enabled" do
|
652
|
+
before do
|
653
|
+
Chef::Config[:why_run] = true
|
654
|
+
end
|
655
|
+
after do
|
656
|
+
Chef::Config[:why_run] = false
|
657
|
+
end
|
658
|
+
it "should not save" do
|
659
|
+
@node.name("monkey")
|
660
|
+
@rest.should_not_receive(:put_rest)
|
661
|
+
@rest.should_not_receive(:post_rest)
|
662
|
+
@node.save
|
663
|
+
end
|
664
|
+
end
|
665
|
+
end
|
666
|
+
end
|
667
|
+
|
668
|
+
describe "acting as a CouchDB-backed model" do
|
669
|
+
before(:each) do
|
670
|
+
@couchdb = Chef::CouchDB.new
|
671
|
+
@mock_couch = mock('couch mock')
|
672
|
+
end
|
673
|
+
|
674
|
+
describe "list" do
|
675
|
+
before(:each) do
|
676
|
+
@mock_couch.stub!(:list).and_return(
|
677
|
+
{ "rows" => [ { "value" => "a", "key" => "avenue" } ] }
|
678
|
+
)
|
679
|
+
Chef::CouchDB.stub!(:new).and_return(@mock_couch)
|
680
|
+
end
|
681
|
+
|
682
|
+
it "should retrieve a list of nodes from CouchDB" do
|
683
|
+
Chef::Node.cdb_list.should eql(["avenue"])
|
684
|
+
end
|
685
|
+
|
686
|
+
it "should return just the ids if inflate is false" do
|
687
|
+
Chef::Node.cdb_list(false).should eql(["avenue"])
|
688
|
+
end
|
689
|
+
|
690
|
+
it "should return the full objects if inflate is true" do
|
691
|
+
Chef::Node.cdb_list(true).should eql(["a"])
|
692
|
+
end
|
693
|
+
end
|
694
|
+
|
695
|
+
describe "when loading a given node" do
|
696
|
+
it "should load a node from couchdb by name" do
|
697
|
+
@couchdb.should_receive(:load).with("node", "coffee").and_return(true)
|
698
|
+
Chef::CouchDB.stub!(:new).and_return(@couchdb)
|
699
|
+
Chef::Node.cdb_load("coffee")
|
700
|
+
end
|
701
|
+
end
|
702
|
+
|
703
|
+
describe "when destroying a Node" do
|
704
|
+
it "should delete this node from couchdb" do
|
705
|
+
@couchdb.should_receive(:delete).with("node", "bob", 1).and_return(true)
|
706
|
+
Chef::CouchDB.stub!(:new).and_return(@couchdb)
|
707
|
+
node = Chef::Node.new
|
708
|
+
node.name "bob"
|
709
|
+
node.couchdb_rev = 1
|
710
|
+
node.cdb_destroy
|
711
|
+
end
|
712
|
+
end
|
713
|
+
|
714
|
+
describe "when saving a Node" do
|
715
|
+
before(:each) do
|
716
|
+
@couchdb.stub!(:store).and_return({ "rev" => 33 })
|
717
|
+
Chef::CouchDB.stub!(:new).and_return(@couchdb)
|
718
|
+
@node = Chef::Node.new
|
719
|
+
@node.name "bob"
|
720
|
+
@node.couchdb_rev = 1
|
721
|
+
end
|
722
|
+
|
723
|
+
it "should save the node to couchdb" do
|
724
|
+
@couchdb.should_receive(:store).with("node", "bob", @node).and_return({ "rev" => 33 })
|
725
|
+
@node.cdb_save
|
726
|
+
end
|
727
|
+
|
728
|
+
it "should store the new couchdb_rev" do
|
729
|
+
@node.cdb_save
|
730
|
+
@node.couchdb_rev.should eql(33)
|
731
|
+
end
|
732
|
+
end
|
733
|
+
|
734
|
+
describe "create_design_document" do
|
735
|
+
it "should create our design document" do
|
736
|
+
@couchdb.should_receive(:create_design_document).with("nodes", Chef::Node::DESIGN_DOCUMENT)
|
737
|
+
Chef::CouchDB.stub!(:new).and_return(@couchdb)
|
738
|
+
Chef::Node.create_design_document
|
739
|
+
end
|
740
|
+
end
|
741
|
+
|
742
|
+
end
|
743
|
+
|
744
|
+
end
|