chef 12.10.24-universal-mingw32 → 12.11.18-universal-mingw32
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/CONTRIBUTING.md +3 -38
- data/Gemfile +6 -11
- data/LICENSE +201 -201
- data/README.md +11 -1
- data/VERSION +1 -1
- data/acceptance/.bundle/config +2 -0
- data/acceptance/Gemfile.lock +27 -26
- data/acceptance/basics/.kitchen/logs/chef-current-install-ubuntu-1404.log +2 -0
- data/acceptance/basics/.kitchen/logs/kitchen.log +3 -0
- data/acceptance/data-collector/.acceptance/acceptance-cookbook/.gitignore +2 -0
- data/acceptance/data-collector/.acceptance/acceptance-cookbook/metadata.rb +3 -0
- data/acceptance/data-collector/.acceptance/acceptance-cookbook/recipes/destroy.rb +2 -0
- data/acceptance/data-collector/.acceptance/acceptance-cookbook/recipes/provision.rb +2 -0
- data/acceptance/data-collector/.acceptance/acceptance-cookbook/recipes/verify.rb +2 -0
- data/acceptance/data-collector/.acceptance/data-collector-test/.gitignore +16 -0
- data/acceptance/data-collector/.acceptance/data-collector-test/Berksfile +3 -0
- data/acceptance/data-collector/.acceptance/data-collector-test/files/default/api.rb +85 -0
- data/acceptance/data-collector/.acceptance/data-collector-test/files/default/apigemfile +3 -0
- data/acceptance/data-collector/.acceptance/data-collector-test/files/default/client-rb-both-mode.rb +4 -0
- data/acceptance/data-collector/.acceptance/data-collector-test/files/default/client-rb-client-mode.rb +4 -0
- data/acceptance/data-collector/.acceptance/data-collector-test/files/default/client-rb-no-endpoint.rb +2 -0
- data/acceptance/data-collector/.acceptance/data-collector-test/files/default/client-rb-solo-mode.rb +4 -0
- data/acceptance/data-collector/.acceptance/data-collector-test/files/default/config.ru +2 -0
- data/acceptance/data-collector/.acceptance/data-collector-test/metadata.rb +7 -0
- data/acceptance/data-collector/.acceptance/data-collector-test/recipes/default.rb +38 -0
- data/acceptance/data-collector/.kitchen.yml +9 -0
- data/acceptance/data-collector/Berksfile +3 -0
- data/acceptance/data-collector/Berksfile.lock +6 -0
- data/acceptance/data-collector/test/integration/default/serverspec/default_spec.rb +251 -0
- data/acceptance/fips/.kitchen/logs/fips-integration-centos-6.log +3 -0
- data/acceptance/fips/.kitchen/logs/fips-integration-windows-2012r2.log +3 -0
- data/acceptance/fips/.kitchen/logs/fips-unit-functional-centos-6.log +3 -0
- data/acceptance/fips/.kitchen/logs/fips-unit-functional-windows-2012r2.log +3 -0
- data/acceptance/fips/.kitchen/logs/kitchen.log +6 -0
- data/acceptance/fips/test/integration/fips-integration/serverspec/fips-integration_spec.rb +2 -1
- data/acceptance/top-cookbooks/.kitchen.docker.yml +1 -4
- data/acceptance/trivial/.kitchen/logs/chef-current-install-windows-2012r2.log +2 -0
- data/acceptance/trivial/.kitchen/logs/kitchen.log +3 -0
- data/acceptance/windows-service/.kitchen/logs/chef-windows-service-windows-2012r2.log +2 -0
- data/acceptance/windows-service/.kitchen/logs/kitchen.log +3 -0
- data/bin/chef-apply +0 -0
- data/bin/chef-client +0 -0
- data/bin/chef-service-manager +0 -0
- data/bin/chef-shell +0 -0
- data/bin/chef-solo +0 -0
- data/bin/chef-windows-service +0 -0
- data/bin/knife +0 -0
- data/chef.gemspec +1 -0
- data/distro/common/html/_sources/ctl_chef_client.txt +35 -35
- data/distro/common/html/_sources/ctl_chef_server.txt +341 -341
- data/distro/common/html/_sources/ctl_chef_shell.txt +15 -15
- data/distro/common/html/_sources/ctl_chef_solo.txt +25 -25
- data/distro/common/html/_sources/index.txt +135 -135
- data/distro/common/html/_sources/knife.txt +74 -74
- data/distro/common/html/_sources/knife_bootstrap.txt +56 -56
- data/distro/common/html/_sources/knife_client.txt +150 -150
- data/distro/common/html/_sources/knife_common_options.txt +6 -6
- data/distro/common/html/_sources/knife_configure.txt +29 -29
- data/distro/common/html/_sources/knife_cookbook.txt +236 -236
- data/distro/common/html/_sources/knife_cookbook_site.txt +157 -157
- data/distro/common/html/_sources/knife_data_bag.txt +159 -159
- data/distro/common/html/_sources/knife_delete.txt +26 -26
- data/distro/common/html/_sources/knife_deps.txt +61 -61
- data/distro/common/html/_sources/knife_diff.txt +34 -34
- data/distro/common/html/_sources/knife_download.txt +44 -44
- data/distro/common/html/_sources/knife_edit.txt +26 -26
- data/distro/common/html/_sources/knife_environment.txt +158 -158
- data/distro/common/html/_sources/knife_exec.txt +47 -47
- data/distro/common/html/_sources/knife_index_rebuild.txt +20 -20
- data/distro/common/html/_sources/knife_list.txt +33 -33
- data/distro/common/html/_sources/knife_node.txt +250 -250
- data/distro/common/html/_sources/knife_raw.txt +35 -35
- data/distro/common/html/_sources/knife_recipe_list.txt +23 -23
- data/distro/common/html/_sources/knife_role.txt +157 -157
- data/distro/common/html/_sources/knife_search.txt +53 -53
- data/distro/common/html/_sources/knife_serve.txt +18 -18
- data/distro/common/html/_sources/knife_show.txt +26 -26
- data/distro/common/html/_sources/knife_ssh.txt +43 -43
- data/distro/common/html/_sources/knife_ssl_check.txt +41 -41
- data/distro/common/html/_sources/knife_ssl_fetch.txt +41 -41
- data/distro/common/html/_sources/knife_status.txt +37 -37
- data/distro/common/html/_sources/knife_tag.txt +69 -69
- data/distro/common/html/_sources/knife_upload.txt +49 -49
- data/distro/common/html/_sources/knife_user.txt +127 -127
- data/distro/common/html/_sources/knife_using.txt +43 -43
- data/distro/common/html/_sources/knife_xargs.txt +30 -30
- data/distro/common/html/_static/guide.css +504 -504
- data/distro/common/html/_static/pygments.css +61 -61
- data/distro/common/html/_static/underscore.js +31 -31
- data/distro/common/html/ctl_chef_client.html +269 -269
- data/distro/common/html/ctl_chef_server.html +727 -727
- data/distro/common/html/ctl_chef_shell.html +162 -162
- data/distro/common/html/ctl_chef_solo.html +193 -193
- data/distro/common/html/index.html +201 -201
- data/distro/common/html/knife.html +169 -169
- data/distro/common/html/knife_bootstrap.html +284 -284
- data/distro/common/html/knife_client.html +284 -284
- data/distro/common/html/knife_common_options.html +95 -95
- data/distro/common/html/knife_configure.html +104 -104
- data/distro/common/html/knife_cookbook.html +486 -486
- data/distro/common/html/knife_data_bag.html +373 -373
- data/distro/common/html/knife_delete.html +92 -92
- data/distro/common/html/knife_deps.html +142 -142
- data/distro/common/html/knife_diff.html +122 -122
- data/distro/common/html/knife_download.html +144 -144
- data/distro/common/html/knife_edit.html +88 -88
- data/distro/common/html/knife_environment.html +325 -325
- data/distro/common/html/knife_exec.html +219 -219
- data/distro/common/html/knife_index_rebuild.html +82 -82
- data/distro/common/html/knife_list.html +113 -113
- data/distro/common/html/knife_node.html +457 -457
- data/distro/common/html/knife_raw.html +109 -109
- data/distro/common/html/knife_recipe_list.html +90 -90
- data/distro/common/html/knife_role.html +294 -294
- data/distro/common/html/knife_search.html +202 -202
- data/distro/common/html/knife_serve.html +78 -78
- data/distro/common/html/knife_show.html +103 -103
- data/distro/common/html/knife_ssh.html +176 -176
- data/distro/common/html/knife_ssl_check.html +150 -150
- data/distro/common/html/knife_ssl_fetch.html +150 -150
- data/distro/common/html/knife_status.html +143 -143
- data/distro/common/html/knife_tag.html +137 -137
- data/distro/common/html/knife_upload.html +152 -152
- data/distro/common/html/knife_user.html +241 -241
- data/distro/common/html/knife_using.html +209 -209
- data/distro/common/html/knife_xargs.html +121 -121
- data/distro/common/html/search.html +81 -81
- data/distro/common/man/man1/README.md +58 -58
- data/distro/common/man/man1/chef-shell.1 +194 -194
- data/distro/common/man/man1/knife-bootstrap.1 +215 -215
- data/distro/common/man/man1/knife-client.1 +443 -443
- data/distro/common/man/man1/knife-configure.1 +161 -161
- data/distro/common/man/man1/knife-cookbook.1 +770 -770
- data/distro/common/man/man1/knife-data-bag.1 +617 -617
- data/distro/common/man/man1/knife-delete.1 +127 -127
- data/distro/common/man/man1/knife-deps.1 +246 -246
- data/distro/common/man/man1/knife-diff.1 +226 -226
- data/distro/common/man/man1/knife-download.1 +258 -258
- data/distro/common/man/man1/knife-edit.1 +121 -121
- data/distro/common/man/man1/knife-environment.1 +508 -508
- data/distro/common/man/man1/knife-exec.1 +362 -362
- data/distro/common/man/man1/knife-index-rebuild.1 +63 -63
- data/distro/common/man/man1/knife-list.1 +174 -174
- data/distro/common/man/man1/knife-node.1 +716 -716
- data/distro/common/man/man1/knife-raw.1 +172 -172
- data/distro/common/man/man1/knife-recipe-list.1 +85 -85
- data/distro/common/man/man1/knife-role.1 +426 -426
- data/distro/common/man/man1/knife-search.1 +359 -359
- data/distro/common/man/man1/knife-serve.1 +109 -109
- data/distro/common/man/man1/knife-show.1 +160 -160
- data/distro/common/man/man1/knife-ssh.1 +284 -284
- data/distro/common/man/man1/knife-ssl-check.1 +207 -207
- data/distro/common/man/man1/knife-ssl-fetch.1 +207 -207
- data/distro/common/man/man1/knife-status.1 +234 -234
- data/distro/common/man/man1/knife-tag.1 +189 -189
- data/distro/common/man/man1/knife-upload.1 +280 -280
- data/distro/common/man/man1/knife-user.1 +356 -356
- data/distro/common/man/man1/knife-xargs.1 +189 -189
- data/distro/common/man/man1/knife.1 +332 -332
- data/distro/common/man/man8/chef-apply.8 +86 -86
- data/distro/common/man/man8/chef-client.8 +398 -398
- data/distro/common/man/man8/chef-solo.8 +260 -260
- data/distro/common/markdown/README +3 -3
- data/lib/chef/application.rb +14 -9
- data/lib/chef/application/apply.rb +5 -5
- data/lib/chef/application/client.rb +3 -3
- data/lib/chef/application/exit_code.rb +226 -0
- data/lib/chef/application/solo.rb +37 -7
- data/lib/chef/application/windows_service.rb +3 -3
- data/lib/chef/chef_fs/command_line.rb +7 -0
- data/lib/chef/chef_fs/config.rb +1 -1
- data/lib/chef/chef_fs/data_handler/data_handler_base.rb +11 -10
- data/lib/chef/chef_fs/data_handler/environment_data_handler.rb +1 -1
- data/lib/chef/chef_fs/data_handler/role_data_handler.rb +1 -1
- data/lib/chef/chef_fs/file_system.rb +15 -13
- data/lib/chef/chef_fs/file_system/base_fs_object.rb +4 -0
- data/lib/chef/chef_fs/file_system/chef_server/acl_dir.rb +1 -1
- data/lib/chef/chef_fs/file_system/chef_server/acl_entry.rb +9 -0
- data/lib/chef/chef_fs/file_system/chef_server/data_bag_dir.rb +6 -0
- data/lib/chef/chef_fs/file_system/chef_server/data_bag_entry.rb +19 -0
- data/lib/chef/chef_fs/file_system/chef_server/environments_dir.rb +1 -1
- data/lib/chef/chef_fs/file_system/chef_server/nodes_dir.rb +1 -1
- data/lib/chef/chef_fs/file_system/chef_server/org_entry.rb +4 -0
- data/lib/chef/chef_fs/file_system/chef_server/organization_invites_entry.rb +4 -0
- data/lib/chef/chef_fs/file_system/chef_server/organization_members_entry.rb +4 -0
- data/lib/chef/chef_fs/file_system/chef_server/policy_revision_entry.rb +4 -0
- data/lib/chef/chef_fs/file_system/chef_server/rest_list_dir.rb +3 -3
- data/lib/chef/chef_fs/file_system/chef_server/rest_list_entry.rb +15 -4
- data/lib/chef/chef_fs/file_system/exceptions.rb +7 -0
- data/lib/chef/chef_fs/file_system/multiplexed_dir.rb +2 -2
- data/lib/chef/chef_fs/file_system/nonexistent_fs_object.rb +0 -4
- data/lib/chef/chef_fs/file_system/repository/acl.rb +7 -0
- data/lib/chef/chef_fs/file_system/repository/acls_sub_dir.rb +0 -4
- data/lib/chef/chef_fs/file_system/repository/base_file.rb +36 -4
- data/lib/chef/chef_fs/file_system/repository/chef_repository_file_system_cookbook_entry.rb +4 -0
- data/lib/chef/chef_fs/file_system/repository/client_keys_sub_dir.rb +0 -4
- data/lib/chef/chef_fs/file_system/repository/clients_dir.rb +0 -3
- data/lib/chef/chef_fs/file_system/repository/containers_dir.rb +0 -4
- data/lib/chef/chef_fs/file_system/repository/directory.rb +4 -0
- data/lib/chef/chef_fs/file_system/repository/environments_dir.rb +0 -4
- data/lib/chef/chef_fs/file_system/repository/groups_dir.rb +0 -4
- data/lib/chef/chef_fs/file_system/repository/nodes_dir.rb +0 -4
- data/lib/chef/chef_fs/file_system/repository/policy_groups_dir.rb +0 -4
- data/lib/chef/chef_fs/file_system/repository/roles_dir.rb +0 -4
- data/lib/chef/chef_fs/file_system/repository/users_dir.rb +0 -4
- data/lib/chef/client.rb +11 -3
- data/lib/chef/config_fetcher.rb +4 -4
- data/lib/chef/cookbook/gem_installer.rb +1 -0
- data/lib/chef/cookbook/synchronizer.rb +1 -1
- data/lib/chef/data_bag.rb +2 -2
- data/lib/chef/data_bag_item.rb +1 -1
- data/lib/chef/data_collector.rb +345 -0
- data/lib/chef/data_collector/messages.rb +125 -0
- data/lib/chef/data_collector/messages/helpers.rb +161 -0
- data/lib/chef/data_collector/resource_report.rb +84 -0
- data/lib/chef/decorator.rb +81 -0
- data/lib/chef/decorator/lazy.rb +60 -0
- data/lib/chef/decorator/lazy_array.rb +59 -0
- data/lib/chef/deprecation/provider/remote_file.rb +1 -1
- data/lib/chef/dsl/core.rb +19 -11
- data/lib/chef/dsl/platform_introspection.rb +16 -0
- data/lib/chef/dsl/recipe.rb +15 -9
- data/lib/chef/dsl/universal.rb +50 -0
- data/lib/chef/environment.rb +2 -2
- data/lib/chef/exceptions.rb +19 -4
- data/lib/chef/handler.rb +33 -0
- data/lib/chef/knife/cookbook_show.rb +6 -10
- data/lib/chef/knife/cookbook_site_install.rb +7 -2
- data/lib/chef/knife/help_topics.rb +4 -4
- data/lib/chef/knife/list.rb +1 -2
- data/lib/chef/knife/ssl_check.rb +2 -1
- data/lib/chef/monkey_patches/win32/registry.rb +11 -0
- data/lib/chef/nil_argument.rb +3 -3
- data/lib/chef/node.rb +2 -2
- data/lib/chef/platform/rebooter.rb +13 -2
- data/lib/chef/policy_builder/dynamic.rb +1 -1
- data/lib/chef/policy_builder/expand_node_object.rb +3 -3
- data/lib/chef/policy_builder/policyfile.rb +1 -1
- data/lib/chef/provider/git.rb +43 -41
- data/lib/chef/provider/lwrp_base.rb +0 -1
- data/lib/chef/provider/osx_profile.rb +2 -3
- data/lib/chef/provider/package.rb +51 -13
- data/lib/chef/provider/package/apt.rb +97 -103
- data/lib/chef/provider/package/chocolatey.rb +9 -10
- data/lib/chef/provider/package/dpkg.rb +2 -2
- data/lib/chef/provider/package/portage.rb +1 -1
- data/lib/chef/provider/package/rubygems.rb +8 -12
- data/lib/chef/provider/package/yum.rb +4 -959
- data/lib/chef/provider/package/yum/rpm_utils.rb +642 -0
- data/lib/chef/provider/package/{yum-dump.py → yum/yum-dump.py} +0 -0
- data/lib/chef/provider/package/yum/yum_cache.rb +376 -0
- data/lib/chef/provider/resource_update.rb +52 -52
- data/lib/chef/provider/systemd_unit.rb +238 -0
- data/lib/chef/providers.rb +1 -0
- data/lib/chef/reserved_names.rb +9 -9
- data/lib/chef/resource.rb +2 -7
- data/lib/chef/resource/file.rb +6 -1
- data/lib/chef/resource/systemd_unit.rb +63 -0
- data/lib/chef/resources.rb +1 -0
- data/lib/chef/sandbox.rb +20 -20
- data/lib/chef/shell/shell_session.rb +3 -3
- data/lib/chef/version.rb +1 -1
- data/lib/chef/win32/system.rb +0 -0
- data/spec/data/apt/chef-integration-test-1.0/debian/changelog +5 -5
- data/spec/data/apt/chef-integration-test-1.0/debian/compat +1 -1
- data/spec/data/apt/chef-integration-test-1.0/debian/control +13 -13
- data/spec/data/apt/chef-integration-test-1.0/debian/files +1 -1
- data/spec/data/apt/chef-integration-test-1.0/debian/rules +13 -13
- data/spec/data/apt/chef-integration-test-1.0/debian/source/format +1 -1
- data/spec/data/apt/chef-integration-test-1.1/debian/changelog +11 -11
- data/spec/data/apt/chef-integration-test-1.1/debian/compat +1 -1
- data/spec/data/apt/chef-integration-test-1.1/debian/control +13 -13
- data/spec/data/apt/chef-integration-test-1.1/debian/files +1 -1
- data/spec/data/apt/chef-integration-test-1.1/debian/rules +13 -13
- data/spec/data/apt/chef-integration-test-1.1/debian/source/format +1 -1
- data/spec/data/apt/chef-integration-test2-1.0/debian/rules +0 -0
- data/spec/data/apt/chef-integration-test_1.0-1_amd64.changes +22 -22
- data/spec/data/apt/chef-integration-test_1.1-1_amd64.changes +22 -22
- data/spec/data/apt/var/www/apt/conf/distributions +7 -7
- data/spec/data/apt/var/www/apt/conf/incoming +4 -4
- data/spec/data/apt/var/www/apt/conf/pulls +3 -3
- data/spec/data/apt/var/www/apt/db/version +4 -4
- data/spec/data/apt/var/www/apt/dists/sid/Release +19 -19
- data/spec/data/apt/var/www/apt/dists/sid/main/binary-amd64/Packages +16 -16
- data/spec/data/apt/var/www/apt/dists/sid/main/binary-amd64/Release +5 -5
- data/spec/data/bootstrap/encrypted_data_bag_secret +1 -1
- data/spec/data/bootstrap/no_proxy.erb +2 -2
- data/spec/data/bootstrap/secret.erb +9 -9
- data/spec/data/bootstrap/test-hints.erb +12 -12
- data/spec/data/bootstrap/test.erb +1 -1
- data/spec/data/cb_version_cookbooks/tatft/README.rdoc +2 -2
- data/spec/data/cb_version_cookbooks/tatft/attributes/default.rb +1 -1
- data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-600hhz-0 +1 -1
- data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-ahd2gq-0 +1 -1
- data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-api8ux-0 +1 -1
- data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-b0r1m1-0 +1 -1
- data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-bfygsi-0 +1 -1
- data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-el14l6-0 +1 -1
- data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-ivrl3y-0 +1 -1
- data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-kkbs85-0 +1 -1
- data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-ory1ux-0 +1 -1
- data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-pgsq76-0 +1 -1
- data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-ra8uim-0 +1 -1
- data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-t7k1g-0 +1 -1
- data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-t8g0sv-0 +1 -1
- data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-ufy6g3-0 +1 -1
- data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-x2d6j9-0 +1 -1
- data/spec/data/checksum_cache/chef-file--tmp-chef-rendered-template20100929-10863-xi0l6h-0 +1 -1
- data/spec/data/config.rb +6 -6
- data/spec/data/cookbooks/angrybash/metadata.rb +2 -2
- data/spec/data/cookbooks/angrybash/recipes/default.rb +8 -8
- data/spec/data/cookbooks/apache2/files/default/apache2_module_conf_generate.pl +2 -2
- data/spec/data/cookbooks/apache2/metadata.rb +2 -2
- data/spec/data/cookbooks/apache2/recipes/default.rb +2 -2
- data/spec/data/cookbooks/borken/metadata.rb +2 -2
- data/spec/data/cookbooks/borken/recipes/default.rb +1 -1
- data/spec/data/cookbooks/borken/templates/default/borken.erb +1 -1
- data/spec/data/cookbooks/chefignore +8 -8
- data/spec/data/cookbooks/ignorken/files/default/not_me.rb +2 -2
- data/spec/data/cookbooks/ignorken/metadata.rb +2 -2
- data/spec/data/cookbooks/ignorken/recipes/ignoreme.rb +1 -1
- data/spec/data/cookbooks/ignorken/templates/ubuntu-12.10/not_me.rb +2 -2
- data/spec/data/cookbooks/java/files/default/java.response +1 -1
- data/spec/data/cookbooks/java/metadata.rb +2 -2
- data/spec/data/cookbooks/name-mismatch-versionnumber/README.md +4 -4
- data/spec/data/cookbooks/name-mismatch-versionnumber/metadata.rb +8 -8
- data/spec/data/cookbooks/openldap/attributes/default.rb +16 -16
- data/spec/data/cookbooks/openldap/attributes/smokey.rb +1 -1
- data/spec/data/cookbooks/openldap/definitions/client.rb +5 -5
- data/spec/data/cookbooks/openldap/definitions/server.rb +5 -5
- data/spec/data/cookbooks/openldap/files/default/.dotfile +1 -1
- data/spec/data/cookbooks/openldap/files/default/remotedir/.a_dotdir/.a_dotfile_in_a_dotdir +1 -1
- data/spec/data/cookbooks/openldap/files/default/remotedir/not_a_template.erb +2 -2
- data/spec/data/cookbooks/openldap/files/default/remotedir/remote_dir_file1.txt +2 -2
- data/spec/data/cookbooks/openldap/files/default/remotedir/remote_dir_file2.txt +2 -2
- data/spec/data/cookbooks/openldap/files/default/remotedir/remotesubdir/.a_dotfile +1 -1
- data/spec/data/cookbooks/openldap/files/default/remotedir/remotesubdir/remote_subdir_file1.txt +2 -2
- data/spec/data/cookbooks/openldap/files/default/remotedir/remotesubdir/remote_subdir_file2.txt +2 -2
- data/spec/data/cookbooks/openldap/files/default/remotedir/subdir_with_no_file_just_a_subsubdir/the_subsubdir/some_file.txt +3 -3
- data/spec/data/cookbooks/openldap/libraries/openldap.rb +4 -4
- data/spec/data/cookbooks/openldap/libraries/openldap/version.rb +3 -3
- data/spec/data/cookbooks/openldap/metadata.rb +8 -8
- data/spec/data/cookbooks/openldap/recipes/default.rb +4 -4
- data/spec/data/cookbooks/openldap/recipes/gigantor.rb +3 -3
- data/spec/data/cookbooks/openldap/recipes/one.rb +15 -15
- data/spec/data/cookbooks/openldap/recipes/return.rb +2 -2
- data/spec/data/cookbooks/openldap/templates/default/helper_test.erb +1 -1
- data/spec/data/cookbooks/openldap/templates/default/helpers_via_partial_test.erb +1 -1
- data/spec/data/cookbooks/openldap/templates/default/no_windows_line_endings.erb +4 -4
- data/spec/data/cookbooks/openldap/templates/default/openldap_variable_stuff.conf.erb +1 -1
- data/spec/data/cookbooks/openldap/templates/default/test.erb +1 -1
- data/spec/data/cookbooks/preseed/files/default/preseed-file.seed +1 -1
- data/spec/data/cookbooks/preseed/files/default/preseed-template.seed +4 -4
- data/spec/data/cookbooks/preseed/metadata.rb +2 -2
- data/spec/data/cookbooks/preseed/templates/default/preseed-template-variables.seed +1 -1
- data/spec/data/cookbooks/preseed/templates/default/preseed-template.seed +1 -1
- data/spec/data/definitions/test.rb +4 -4
- data/spec/data/environment-config.rb +4 -4
- data/spec/data/file-providers-method-snapshot-chef-11-4.json +127 -127
- data/spec/data/fileedit/hosts +4 -4
- data/spec/data/incomplete-metadata-chef-repo/incomplete-metadata/README.md +4 -4
- data/spec/data/incomplete-metadata-chef-repo/incomplete-metadata/metadata.rb +13 -13
- data/spec/data/invalid-metadata-chef-repo/invalid-metadata/README.md +4 -4
- data/spec/data/kitchen/chefignore +6 -6
- data/spec/data/kitchen/openldap/attributes/default.rb +3 -3
- data/spec/data/kitchen/openldap/attributes/robinson.rb +2 -2
- data/spec/data/kitchen/openldap/definitions/client.rb +3 -3
- data/spec/data/kitchen/openldap/definitions/drewbarrymore.rb +2 -2
- data/spec/data/kitchen/openldap/recipes/gigantor.rb +2 -2
- data/spec/data/kitchen/openldap/recipes/ignoreme.rb +2 -2
- data/spec/data/kitchen/openldap/recipes/woot.rb +3 -3
- data/spec/data/knife_subcommand/test_explicit_category.rb +6 -6
- data/spec/data/knife_subcommand/test_name_mapping.rb +4 -4
- data/spec/data/knife_subcommand/test_yourself.rb +21 -21
- data/spec/data/lwrp/providers/inline_compiler.rb +26 -26
- data/spec/data/lwrp/providers/monkey_name_printer.rb +5 -5
- data/spec/data/lwrp/providers/paint_drying_watcher.rb +7 -7
- data/spec/data/lwrp/providers/thumb_twiddler.rb +7 -7
- data/spec/data/lwrp/resources/foo.rb +4 -4
- data/spec/data/lwrp/resources_with_default_attributes/nodeattr.rb +1 -1
- data/spec/data/lwrp_override/providers/buck_passer.rb +5 -5
- data/spec/data/mac_users/10.7-8.plist.xml +559 -559
- data/spec/data/mac_users/10.7-8.shadow.xml +11 -11
- data/spec/data/mac_users/10.7.plist.xml +559 -559
- data/spec/data/mac_users/10.7.shadow.xml +11 -11
- data/spec/data/mac_users/10.8.plist.xml +559 -559
- data/spec/data/mac_users/10.8.shadow.xml +21 -21
- data/spec/data/mac_users/10.9.plist.xml +560 -560
- data/spec/data/mac_users/10.9.shadow.xml +21 -21
- data/spec/data/metadata/quick_start/metadata.rb +19 -19
- data/spec/data/nodes/default.rb +15 -15
- data/spec/data/nodes/test.example.com.rb +17 -17
- data/spec/data/nodes/test.rb +15 -15
- data/spec/data/null_config.rb +1 -1
- data/spec/data/object_loader/environments/test.json +7 -7
- data/spec/data/object_loader/environments/test.rb +2 -2
- data/spec/data/object_loader/environments/test_json_class.json +8 -8
- data/spec/data/object_loader/nodes/test.json +7 -7
- data/spec/data/object_loader/nodes/test.rb +2 -2
- data/spec/data/object_loader/nodes/test_json_class.json +8 -8
- data/spec/data/object_loader/roles/test.json +7 -7
- data/spec/data/object_loader/roles/test.rb +2 -2
- data/spec/data/object_loader/roles/test_json_class.json +8 -8
- data/spec/data/partial_one.erb +1 -1
- data/spec/data/recipes/test.rb +7 -7
- data/spec/data/run_context/cookbooks/circular-dep1/attributes/default.rb +4 -4
- data/spec/data/run_context/cookbooks/circular-dep1/definitions/circular_dep1_res.rb +1 -1
- data/spec/data/run_context/cookbooks/circular-dep1/libraries/lib.rb +2 -2
- data/spec/data/run_context/cookbooks/circular-dep1/metadata.rb +2 -2
- data/spec/data/run_context/cookbooks/circular-dep1/providers/provider.rb +1 -1
- data/spec/data/run_context/cookbooks/circular-dep1/resources/resource.rb +1 -1
- data/spec/data/run_context/cookbooks/circular-dep2/attributes/default.rb +3 -3
- data/spec/data/run_context/cookbooks/circular-dep2/definitions/circular_dep2_res.rb +1 -1
- data/spec/data/run_context/cookbooks/circular-dep2/libraries/lib.rb +2 -2
- data/spec/data/run_context/cookbooks/circular-dep2/metadata.rb +2 -2
- data/spec/data/run_context/cookbooks/circular-dep2/providers/provider.rb +1 -1
- data/spec/data/run_context/cookbooks/circular-dep2/resources/resource.rb +1 -1
- data/spec/data/run_context/cookbooks/dependency1/attributes/aa_first.rb +2 -2
- data/spec/data/run_context/cookbooks/dependency1/attributes/default.rb +2 -2
- data/spec/data/run_context/cookbooks/dependency1/attributes/zz_last.rb +3 -3
- data/spec/data/run_context/cookbooks/dependency1/definitions/dependency1_res.rb +1 -1
- data/spec/data/run_context/cookbooks/dependency1/libraries/lib.rb +2 -2
- data/spec/data/run_context/cookbooks/dependency1/providers/provider.rb +1 -1
- data/spec/data/run_context/cookbooks/dependency1/resources/resource.rb +1 -1
- data/spec/data/run_context/cookbooks/dependency2/attributes/default.rb +3 -3
- data/spec/data/run_context/cookbooks/dependency2/definitions/dependency2_res.rb +1 -1
- data/spec/data/run_context/cookbooks/dependency2/libraries/lib.rb +2 -2
- data/spec/data/run_context/cookbooks/dependency2/providers/provider.rb +1 -1
- data/spec/data/run_context/cookbooks/dependency2/resources/resource.rb +1 -1
- data/spec/data/run_context/cookbooks/no-default-attr/attributes/server.rb +3 -3
- data/spec/data/run_context/cookbooks/no-default-attr/definitions/no_default-attr_res.rb +1 -1
- data/spec/data/run_context/cookbooks/no-default-attr/providers/provider.rb +1 -1
- data/spec/data/run_context/cookbooks/no-default-attr/resources/resource.rb +1 -1
- data/spec/data/run_context/cookbooks/test-with-circular-deps/attributes/default.rb +3 -3
- data/spec/data/run_context/cookbooks/test-with-circular-deps/definitions/test_with-circular-deps_res.rb +1 -1
- data/spec/data/run_context/cookbooks/test-with-circular-deps/libraries/lib.rb +2 -2
- data/spec/data/run_context/cookbooks/test-with-circular-deps/metadata.rb +2 -2
- data/spec/data/run_context/cookbooks/test-with-circular-deps/providers/provider.rb +1 -1
- data/spec/data/run_context/cookbooks/test-with-circular-deps/resources/resource.rb +1 -1
- data/spec/data/run_context/cookbooks/test-with-deps/attributes/default.rb +3 -3
- data/spec/data/run_context/cookbooks/test-with-deps/definitions/test_with-deps_res.rb +1 -1
- data/spec/data/run_context/cookbooks/test-with-deps/libraries/lib.rb +1 -1
- data/spec/data/run_context/cookbooks/test-with-deps/metadata.rb +3 -3
- data/spec/data/run_context/cookbooks/test-with-deps/providers/provider.rb +1 -1
- data/spec/data/run_context/cookbooks/test-with-deps/resources/resource.rb +1 -1
- data/spec/data/run_context/cookbooks/test/attributes/george.rb +1 -1
- data/spec/data/run_context/cookbooks/test/definitions/new_animals.rb +9 -9
- data/spec/data/run_context/cookbooks/test/definitions/new_cat.rb +5 -5
- data/spec/data/run_context/cookbooks/test/definitions/test_res.rb +1 -1
- data/spec/data/run_context/cookbooks/test/providers/provider.rb +1 -1
- data/spec/data/run_context/cookbooks/test/recipes/default.rb +5 -5
- data/spec/data/run_context/cookbooks/test/recipes/one.rb +7 -7
- data/spec/data/run_context/cookbooks/test/recipes/two.rb +7 -7
- data/spec/data/run_context/cookbooks/test/resources/resource.rb +1 -1
- data/spec/data/run_context/nodes/run_context.rb +5 -5
- data/spec/data/search_queries_to_transform.txt +98 -98
- data/spec/data/shef-config.rb +10 -10
- data/spec/data/ssl/5e707473.0 +18 -18
- data/spec/data/ssl/chef-rspec.cert +27 -27
- data/spec/data/ssl/chef-rspec.key +27 -27
- data/spec/data/ssl/key.pem +15 -15
- data/spec/data/ssl/private_key.pem +27 -27
- data/spec/data/ssl/private_key_with_whitespace.pem +32 -32
- data/spec/data/standalone_cookbook/chefignore +9 -9
- data/spec/data/standalone_cookbook/recipes/default.rb +2 -2
- data/spec/data/trusted_certs/example.crt +22 -22
- data/spec/data/trusted_certs/intermediate.pem +27 -27
- data/spec/data/trusted_certs/root.pem +22 -22
- data/spec/functional/assets/chefinittest +34 -34
- data/spec/functional/assets/testchefsubsys +10 -10
- data/spec/functional/provider/remote_file/cache_control_data_spec.rb +0 -0
- data/spec/functional/resource/aix_service_spec.rb +0 -0
- data/spec/functional/resource/aixinit_service_spec.rb +0 -0
- data/spec/functional/resource/chocolatey_package_spec.rb +0 -5
- data/spec/functional/resource/env_spec.rb +0 -0
- data/spec/functional/win32/registry_spec.rb +1 -0
- data/spec/integration/client/exit_code_spec.rb +245 -0
- data/spec/integration/knife/deps_spec.rb +7 -7
- data/spec/integration/knife/download_spec.rb +19 -0
- data/spec/integration/knife/list_spec.rb +0 -8
- data/spec/integration/knife/upload_spec.rb +21 -2
- data/spec/integration/solo/solo_spec.rb +1 -1
- data/spec/rcov.opts +2 -2
- data/spec/unit/application/apply_spec.rb +6 -4
- data/spec/unit/application/exit_code_spec.rb +231 -0
- data/spec/unit/application/solo_spec.rb +143 -88
- data/spec/unit/chef_fs/config_spec.rb +129 -0
- data/spec/unit/chef_fs/file_system/repository/base_file_spec.rb +8 -10
- data/spec/unit/client_spec.rb +1 -1
- data/spec/unit/config_fetcher_spec.rb +2 -2
- data/spec/unit/cookbook/synchronizer_spec.rb +1 -1
- data/spec/unit/data_bag_item_spec.rb +2 -2
- data/spec/unit/data_bag_spec.rb +2 -2
- data/spec/unit/data_collector/messages/helpers_spec.rb +190 -0
- data/spec/unit/data_collector/messages_spec.rb +207 -0
- data/spec/unit/data_collector_spec.rb +525 -0
- data/spec/unit/decorator/lazy_array_spec.rb +58 -0
- data/spec/unit/decorator/lazy_spec.rb +39 -0
- data/spec/unit/decorator_spec.rb +142 -0
- data/spec/unit/environment_spec.rb +4 -4
- data/spec/unit/handler_spec.rb +87 -0
- data/spec/unit/knife/cookbook_show_spec.rb +89 -90
- data/spec/unit/knife/ssl_check_spec.rb +16 -0
- data/spec/unit/policy_builder/dynamic_spec.rb +1 -1
- data/spec/unit/policy_builder/policyfile_spec.rb +1 -1
- data/spec/unit/provider/git_spec.rb +77 -18
- data/spec/unit/provider/package/apt_spec.rb +97 -34
- data/spec/unit/provider/package/chocolatey_spec.rb +3 -15
- data/spec/unit/provider/package/portage_spec.rb +6 -0
- data/spec/unit/provider/package/rubygems_spec.rb +38 -4
- data/spec/unit/provider/package/yum/yum_cache_spec.rb +27 -0
- data/spec/unit/provider/package_spec.rb +20 -7
- data/spec/unit/provider/systemd_unit_spec.rb +885 -0
- data/spec/unit/resource/systemd_unit_spec.rb +133 -0
- data/spec/unit/resource_builder_spec.rb +1 -1
- data/tasks/bin/bundle-platform +6 -2
- data/tasks/bin/bundle-platform.bat +0 -0
- data/tasks/bin/create-override-gemfile +0 -0
- data/tasks/bin/run_external_test +0 -0
- data/tasks/bundle_util.rb +18 -2
- data/tasks/changelog.rb +1 -0
- data/tasks/dependencies.rb +47 -57
- metadata +847 -7
- data/tasks/bin/run_chef_tests +0 -17
@@ -29,23 +29,48 @@ class Chef
|
|
29
29
|
attr_reader :file_path
|
30
30
|
attr_reader :data_handler
|
31
31
|
|
32
|
+
alias_method :display_path, :path
|
33
|
+
alias_method :display_name, :name
|
34
|
+
|
32
35
|
def initialize(name, parent)
|
33
36
|
@parent = parent
|
37
|
+
|
38
|
+
if %w{ .rb .json }.include? File.extname(name)
|
39
|
+
name = File.basename(name, ".*")
|
40
|
+
end
|
41
|
+
|
42
|
+
file_path = "#{parent.file_path}/#{name}"
|
43
|
+
|
44
|
+
Chef::Log.debug "BaseFile: Detecting file extension for #{name}"
|
45
|
+
ext = File.exist?(file_path + ".rb") ? ".rb" : ".json"
|
46
|
+
name += ext
|
47
|
+
file_path += ext
|
48
|
+
|
49
|
+
Chef::Log.debug "BaseFile: got a file path of #{file_path} for #{name}"
|
34
50
|
@name = name
|
35
51
|
@path = Chef::ChefFS::PathUtils.join(parent.path, name)
|
36
|
-
@file_path =
|
52
|
+
@file_path = file_path
|
37
53
|
end
|
38
54
|
|
39
55
|
def dir?
|
40
56
|
false
|
41
57
|
end
|
42
58
|
|
59
|
+
# Used to compare names on disk to the API, for diffing.
|
60
|
+
def bare_name
|
61
|
+
File.basename(name, ".*")
|
62
|
+
end
|
63
|
+
|
43
64
|
def is_json_file?
|
44
|
-
File.extname(
|
65
|
+
File.extname(file_path) == ".json"
|
66
|
+
end
|
67
|
+
|
68
|
+
def is_ruby_file?
|
69
|
+
File.extname(file_path) == ".rb"
|
45
70
|
end
|
46
71
|
|
47
72
|
def name_valid?
|
48
|
-
!name.start_with?(".") && is_json_file?
|
73
|
+
!name.start_with?(".") && (is_json_file? || is_ruby_file?)
|
49
74
|
end
|
50
75
|
|
51
76
|
def fs_entry_valid?
|
@@ -91,12 +116,19 @@ class Chef
|
|
91
116
|
end
|
92
117
|
|
93
118
|
def read
|
94
|
-
|
119
|
+
if is_ruby_file?
|
120
|
+
data_handler.from_ruby(file_path).to_json
|
121
|
+
else
|
122
|
+
File.open(file_path, "rb") { |f| f.read }
|
123
|
+
end
|
95
124
|
rescue Errno::ENOENT
|
96
125
|
raise Chef::ChefFS::FileSystem::NotFoundError.new(self, $!)
|
97
126
|
end
|
98
127
|
|
99
128
|
def write(content)
|
129
|
+
if is_ruby_file?
|
130
|
+
raise Chef::ChefFS::FileSystem::RubyFileError.new(:write, self)
|
131
|
+
end
|
100
132
|
if content && write_pretty_json && is_json_file?
|
101
133
|
content = minimize(content, self)
|
102
134
|
end
|
@@ -37,6 +37,10 @@ class Chef
|
|
37
37
|
attr_reader :recursive
|
38
38
|
attr_reader :file_path
|
39
39
|
|
40
|
+
alias_method :display_path, :path
|
41
|
+
alias_method :display_name, :name
|
42
|
+
alias_method :bare_name, :name
|
43
|
+
|
40
44
|
def initialize(name, parent, file_path = nil, ruby_only = false, recursive = false)
|
41
45
|
@parent = parent
|
42
46
|
@name = name
|
@@ -28,6 +28,10 @@ class Chef
|
|
28
28
|
attr_reader :path
|
29
29
|
attr_reader :file_path
|
30
30
|
|
31
|
+
alias_method :display_path, :path
|
32
|
+
alias_method :display_name, :name
|
33
|
+
alias_method :bare_name, :name
|
34
|
+
|
31
35
|
def initialize(name, parent, file_path = nil)
|
32
36
|
@parent = parent
|
33
37
|
@name = name
|
data/lib/chef/client.rb
CHANGED
@@ -45,6 +45,7 @@ require "chef/formatters/doc"
|
|
45
45
|
require "chef/formatters/minimal"
|
46
46
|
require "chef/version"
|
47
47
|
require "chef/resource_reporter"
|
48
|
+
require "chef/data_collector"
|
48
49
|
require "chef/audit/audit_reporter"
|
49
50
|
require "chef/run_lock"
|
50
51
|
require "chef/policy_builder"
|
@@ -262,7 +263,8 @@ class Chef
|
|
262
263
|
enforce_path_sanity
|
263
264
|
run_ohai
|
264
265
|
|
265
|
-
register unless Chef::Config[:
|
266
|
+
register unless Chef::Config[:solo_legacy_mode]
|
267
|
+
register_data_collector_reporter
|
266
268
|
|
267
269
|
load_node
|
268
270
|
|
@@ -533,7 +535,7 @@ class Chef
|
|
533
535
|
# @api private
|
534
536
|
#
|
535
537
|
def save_updated_node
|
536
|
-
if Chef::Config[:
|
538
|
+
if Chef::Config[:solo_legacy_mode]
|
537
539
|
# nothing to do
|
538
540
|
elsif policy_builder.temporary_policy?
|
539
541
|
Chef::Log.warn("Skipping final node save because override_runlist was given")
|
@@ -936,7 +938,7 @@ class Chef
|
|
936
938
|
end
|
937
939
|
|
938
940
|
def assert_cookbook_path_not_empty(run_context)
|
939
|
-
if Chef::Config[:
|
941
|
+
if Chef::Config[:solo_legacy_mode]
|
940
942
|
# Check for cookbooks in the path given
|
941
943
|
# Chef::Config[:cookbook_path] can be a string or an array
|
942
944
|
# if it's an array, go through it and check each one, raise error at the last one if no files are found
|
@@ -957,6 +959,12 @@ class Chef
|
|
957
959
|
|
958
960
|
Chef::ReservedNames::Win32::Security.has_admin_privileges?
|
959
961
|
end
|
962
|
+
|
963
|
+
# Register the data collector reporter to send event information to the
|
964
|
+
# data collector server
|
965
|
+
def register_data_collector_reporter
|
966
|
+
events.register(Chef::DataCollector::Reporter.new) if Chef::DataCollector.register_reporter?
|
967
|
+
end
|
960
968
|
end
|
961
969
|
end
|
962
970
|
|
data/lib/chef/config_fetcher.rb
CHANGED
@@ -25,7 +25,7 @@ class Chef
|
|
25
25
|
begin
|
26
26
|
Chef::JSONCompat.from_json(config_data)
|
27
27
|
rescue Chef::Exceptions::JSON::ParseError => error
|
28
|
-
Chef::Application.fatal!("Could not parse the provided JSON file (#{config_location}): " + error.message,
|
28
|
+
Chef::Application.fatal!("Could not parse the provided JSON file (#{config_location}): " + error.message, Chef::Exceptions::DeprecatedExitCode.new)
|
29
29
|
end
|
30
30
|
end
|
31
31
|
|
@@ -40,15 +40,15 @@ class Chef
|
|
40
40
|
def fetch_remote_config
|
41
41
|
http.get("")
|
42
42
|
rescue SocketError, SystemCallError, Net::HTTPServerException => error
|
43
|
-
Chef::Application.fatal!("Cannot fetch config '#{config_location}': '#{error.class}: #{error.message}",
|
43
|
+
Chef::Application.fatal!("Cannot fetch config '#{config_location}': '#{error.class}: #{error.message}", Chef::Exceptions::DeprecatedExitCode.new)
|
44
44
|
end
|
45
45
|
|
46
46
|
def read_local_config
|
47
47
|
::File.read(config_location)
|
48
48
|
rescue Errno::ENOENT
|
49
|
-
Chef::Application.fatal!("Cannot load configuration from #{config_location}",
|
49
|
+
Chef::Application.fatal!("Cannot load configuration from #{config_location}", Chef::Exceptions::DeprecatedExitCode.new)
|
50
50
|
rescue Errno::EACCES
|
51
|
-
Chef::Application.fatal!("Permissions are incorrect on #{config_location}. Please chmod a+r #{config_location}",
|
51
|
+
Chef::Application.fatal!("Permissions are incorrect on #{config_location}. Please chmod a+r #{config_location}", Chef::Exceptions::DeprecatedExitCode.new)
|
52
52
|
end
|
53
53
|
|
54
54
|
def config_missing?
|
@@ -43,7 +43,7 @@ class Chef
|
|
43
43
|
end
|
44
44
|
|
45
45
|
def cleanup_file_cache
|
46
|
-
unless Chef::Config[:
|
46
|
+
unless Chef::Config[:solo_legacy_mode] || skip_removal
|
47
47
|
# Delete each file in the cache that we didn't encounter in the
|
48
48
|
# manifest.
|
49
49
|
cache.find(File.join(%w{cookbooks ** {*,.*}})).each do |cache_filename|
|
data/lib/chef/data_bag.rb
CHANGED
@@ -91,7 +91,7 @@ class Chef
|
|
91
91
|
end
|
92
92
|
|
93
93
|
def self.list(inflate = false)
|
94
|
-
if Chef::Config[:
|
94
|
+
if Chef::Config[:solo_legacy_mode]
|
95
95
|
paths = Array(Chef::Config[:data_bag_path])
|
96
96
|
names = []
|
97
97
|
paths.each do |path|
|
@@ -118,7 +118,7 @@ class Chef
|
|
118
118
|
|
119
119
|
# Load a Data Bag by name via either the RESTful API or local data_bag_path if run in solo mode
|
120
120
|
def self.load(name)
|
121
|
-
if Chef::Config[:
|
121
|
+
if Chef::Config[:solo_legacy_mode]
|
122
122
|
paths = Array(Chef::Config[:data_bag_path])
|
123
123
|
data_bag = {}
|
124
124
|
paths.each do |path|
|
data/lib/chef/data_bag_item.rb
CHANGED
@@ -147,7 +147,7 @@ class Chef
|
|
147
147
|
|
148
148
|
# Load a Data Bag Item by name via either the RESTful API or local data_bag_path if run in solo mode
|
149
149
|
def self.load(data_bag, name)
|
150
|
-
if Chef::Config[:
|
150
|
+
if Chef::Config[:solo_legacy_mode]
|
151
151
|
bag = Chef::DataBag.load(data_bag)
|
152
152
|
raise Exceptions::InvalidDataBagItemID, "Item #{name} not found in data bag #{data_bag}. Other items found: #{bag.keys.join(", ")}" unless bag.include?(name)
|
153
153
|
item = bag[name]
|
@@ -0,0 +1,345 @@
|
|
1
|
+
#
|
2
|
+
# Author:: Adam Leff (<adamleff@chef.io>)
|
3
|
+
# Author:: Ryan Cragun (<ryan@chef.io>)
|
4
|
+
#
|
5
|
+
# Copyright:: Copyright 2012-2016, Chef Software Inc.
|
6
|
+
# License:: Apache License, Version 2.0
|
7
|
+
#
|
8
|
+
# Licensed under the Apache License, Version 2.0 (the "License");
|
9
|
+
# you may not use this file except in compliance with the License.
|
10
|
+
# You may obtain a copy of the License at
|
11
|
+
#
|
12
|
+
# http://www.apache.org/licenses/LICENSE-2.0
|
13
|
+
#
|
14
|
+
# Unless required by applicable law or agreed to in writing, software
|
15
|
+
# distributed under the License is distributed on an "AS IS" BASIS,
|
16
|
+
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
17
|
+
# See the License for the specific language governing permissions and
|
18
|
+
# limitations under the License.
|
19
|
+
#
|
20
|
+
|
21
|
+
require "uri"
|
22
|
+
require "chef/event_dispatch/base"
|
23
|
+
require "chef/data_collector/messages"
|
24
|
+
require "chef/data_collector/resource_report"
|
25
|
+
|
26
|
+
class Chef
|
27
|
+
|
28
|
+
# == Chef::DataCollector
|
29
|
+
# Provides methods for determinine whether a reporter should be registered.
|
30
|
+
class DataCollector
|
31
|
+
def self.register_reporter?
|
32
|
+
Chef::Config[:data_collector][:server_url] &&
|
33
|
+
!Chef::Config[:why_run] &&
|
34
|
+
self.reporter_enabled_for_current_mode?
|
35
|
+
end
|
36
|
+
|
37
|
+
def self.reporter_enabled_for_current_mode?
|
38
|
+
if Chef::Config[:solo] || Chef::Config[:local_mode]
|
39
|
+
acceptable_modes = [:solo, :both]
|
40
|
+
else
|
41
|
+
acceptable_modes = [:client, :both]
|
42
|
+
end
|
43
|
+
|
44
|
+
acceptable_modes.include?(Chef::Config[:data_collector][:mode])
|
45
|
+
end
|
46
|
+
|
47
|
+
# == Chef::DataCollector::Reporter
|
48
|
+
# Provides an event handler that can be registered to report on Chef
|
49
|
+
# run data. Unlike the existing Chef::ResourceReporter event handler,
|
50
|
+
# the DataCollector handler is not tied to a Chef Server / Chef Reporting
|
51
|
+
# and exports its data through a webhook-like mechanism to a configured
|
52
|
+
# endpoint.
|
53
|
+
class Reporter < EventDispatch::Base
|
54
|
+
attr_reader :updated_resources, :status, :exception, :error_descriptions,
|
55
|
+
:expanded_run_list, :run_status, :http, :resource_count,
|
56
|
+
:current_resource_report, :enabled
|
57
|
+
|
58
|
+
def initialize
|
59
|
+
@updated_resources = []
|
60
|
+
@resource_count = 0
|
61
|
+
@current_resource_loaded = nil
|
62
|
+
@error_descriptions = {}
|
63
|
+
@expanded_run_list = {}
|
64
|
+
@http = Chef::HTTP.new(data_collector_server_url)
|
65
|
+
@enabled = true
|
66
|
+
end
|
67
|
+
|
68
|
+
# see EventDispatch::Base#run_started
|
69
|
+
# Upon receipt, we will send our run start message to the
|
70
|
+
# configured DataCollector endpoint. Depending on whether
|
71
|
+
# the user has configured raise_on_failure, if we cannot
|
72
|
+
# send the message, we will either disable the DataCollector
|
73
|
+
# Reporter for the duration of this run, or we'll raise an
|
74
|
+
# exception.
|
75
|
+
def run_started(current_run_status)
|
76
|
+
update_run_status(current_run_status)
|
77
|
+
|
78
|
+
disable_reporter_on_error do
|
79
|
+
send_to_data_collector(
|
80
|
+
Chef::DataCollector::Messages.run_start_message(current_run_status).to_json
|
81
|
+
)
|
82
|
+
end
|
83
|
+
end
|
84
|
+
|
85
|
+
# see EventDispatch::Base#run_completed
|
86
|
+
# Upon receipt, we will send our run completion message to the
|
87
|
+
# configured DataCollector endpoint.
|
88
|
+
def run_completed(node)
|
89
|
+
send_run_completion(status: "success")
|
90
|
+
end
|
91
|
+
|
92
|
+
# see EventDispatch::Base#run_failed
|
93
|
+
def run_failed(exception)
|
94
|
+
send_run_completion(status: "failure")
|
95
|
+
end
|
96
|
+
|
97
|
+
# see EventDispatch::Base#resource_current_state_loaded
|
98
|
+
# Create a new ResourceReport instance that we'll use to track
|
99
|
+
# the state of this resource during the run. Nested resources are
|
100
|
+
# ignored as they are assumed to be an inline resource of a custom
|
101
|
+
# resource, and we only care about tracking top-level resources.
|
102
|
+
def resource_current_state_loaded(new_resource, action, current_resource)
|
103
|
+
return if nested_resource?(new_resource)
|
104
|
+
update_current_resource_report(
|
105
|
+
Chef::DataCollector::ResourceReport.new(
|
106
|
+
new_resource,
|
107
|
+
action,
|
108
|
+
current_resource
|
109
|
+
)
|
110
|
+
)
|
111
|
+
end
|
112
|
+
|
113
|
+
# see EventDispatch::Base#resource_up_to_date
|
114
|
+
# Mark our ResourceReport status accordingly, and increment the total
|
115
|
+
# resource count.
|
116
|
+
def resource_up_to_date(new_resource, action)
|
117
|
+
current_resource_report.up_to_date unless nested_resource?(new_resource)
|
118
|
+
increment_resource_count
|
119
|
+
end
|
120
|
+
|
121
|
+
# see EventDispatch::Base#resource_skipped
|
122
|
+
# Increment the total resource count. If this is a top-level resource,
|
123
|
+
# we also create a ResourceReport instance (because a skipped resource
|
124
|
+
# does not trigger the resource_current_state_loaded event), and flag
|
125
|
+
# it as skipped.
|
126
|
+
def resource_skipped(new_resource, action, conditional)
|
127
|
+
increment_resource_count
|
128
|
+
return if nested_resource?(new_resource)
|
129
|
+
|
130
|
+
update_current_resource_report(
|
131
|
+
Chef::DataCollector::ResourceReport.new(
|
132
|
+
new_resource,
|
133
|
+
action
|
134
|
+
)
|
135
|
+
)
|
136
|
+
current_resource_report.skipped(conditional)
|
137
|
+
end
|
138
|
+
|
139
|
+
# see EventDispatch::Base#resource_updated
|
140
|
+
# Flag the current ResourceReport instance as updated (as long as it's
|
141
|
+
# a top-level resource) and increment the total resource count.
|
142
|
+
def resource_updated(new_resource, action)
|
143
|
+
current_resource_report.updated unless nested_resource?(new_resource)
|
144
|
+
increment_resource_count
|
145
|
+
end
|
146
|
+
|
147
|
+
# see EventDispatch::Base#resource_failed
|
148
|
+
# Flag the current ResourceReport as failed and supply the exception as
|
149
|
+
# long as it's a top-level resource, increment the total resource count,
|
150
|
+
# and update the run error text with the proper Formatter.
|
151
|
+
def resource_failed(new_resource, action, exception)
|
152
|
+
current_resource_report.failed(exception) unless nested_resource?(new_resource)
|
153
|
+
increment_resource_count
|
154
|
+
update_error_description(
|
155
|
+
Formatters::ErrorMapper.resource_failed(
|
156
|
+
new_resource,
|
157
|
+
action,
|
158
|
+
exception
|
159
|
+
).for_json
|
160
|
+
)
|
161
|
+
end
|
162
|
+
|
163
|
+
# see EventDispatch::Base#resource_completed
|
164
|
+
# Mark the ResourceReport instance as finished (for timing details)
|
165
|
+
# and add it to the list of resources encountered during this run.
|
166
|
+
# This marks the end of this resource during this run.
|
167
|
+
def resource_completed(new_resource)
|
168
|
+
if current_resource_report && !nested_resource?(new_resource)
|
169
|
+
current_resource_report.finish
|
170
|
+
add_updated_resource(current_resource_report)
|
171
|
+
update_current_resource_report(nil)
|
172
|
+
end
|
173
|
+
end
|
174
|
+
|
175
|
+
# see EventDispatch::Base#run_list_expanded
|
176
|
+
# The expanded run list is stored for later use by the run_completed
|
177
|
+
# event and message.
|
178
|
+
def run_list_expanded(run_list_expansion)
|
179
|
+
@expanded_run_list = run_list_expansion
|
180
|
+
end
|
181
|
+
|
182
|
+
# see EventDispatch::Base#run_list_expand_failed
|
183
|
+
# The run error text is updated with the output of the appropriate
|
184
|
+
# formatter.
|
185
|
+
def run_list_expand_failed(node, exception)
|
186
|
+
update_error_description(
|
187
|
+
Formatters::ErrorMapper.run_list_expand_failed(
|
188
|
+
node,
|
189
|
+
exception
|
190
|
+
).for_json
|
191
|
+
)
|
192
|
+
end
|
193
|
+
|
194
|
+
# see EventDispatch::Base#cookbook_resolution_failed
|
195
|
+
# The run error text is updated with the output of the appropriate
|
196
|
+
# formatter.
|
197
|
+
def cookbook_resolution_failed(expanded_run_list, exception)
|
198
|
+
update_error_description(
|
199
|
+
Formatters::ErrorMapper.cookbook_resolution_failed(
|
200
|
+
expanded_run_list,
|
201
|
+
exception
|
202
|
+
).for_json
|
203
|
+
)
|
204
|
+
end
|
205
|
+
|
206
|
+
# see EventDispatch::Base#cookbook_sync_failed
|
207
|
+
# The run error text is updated with the output of the appropriate
|
208
|
+
# formatter.
|
209
|
+
def cookbook_sync_failed(cookbooks, exception)
|
210
|
+
update_error_description(
|
211
|
+
Formatters::ErrorMapper.cookbook_sync_failed(
|
212
|
+
cookbooks,
|
213
|
+
exception
|
214
|
+
).for_json
|
215
|
+
)
|
216
|
+
end
|
217
|
+
|
218
|
+
private
|
219
|
+
|
220
|
+
#
|
221
|
+
# Yields to the passed-in block (which is expected to be some interaction
|
222
|
+
# with the DataCollector endpoint). If some communication failure occurs,
|
223
|
+
# either disable any future communications to the DataCollector endpoint, or
|
224
|
+
# raise an exception (if the user has set
|
225
|
+
# Chef::Config.data_collector.raise_on_failure to true.)
|
226
|
+
#
|
227
|
+
# @param block [Proc] A ruby block to run. Ignored if a command is given.
|
228
|
+
#
|
229
|
+
def disable_reporter_on_error
|
230
|
+
yield
|
231
|
+
rescue Timeout::Error, Errno::EINVAL, Errno::ECONNRESET,
|
232
|
+
Errno::ECONNREFUSED, EOFError, Net::HTTPBadResponse,
|
233
|
+
Net::HTTPHeaderSyntaxError, Net::ProtocolError, OpenSSL::SSL::SSLError => e
|
234
|
+
disable_data_collector_reporter
|
235
|
+
code = if e.respond_to?(:response) && e.response.code
|
236
|
+
e.response.code.to_s
|
237
|
+
else
|
238
|
+
"Exception Code Empty"
|
239
|
+
end
|
240
|
+
|
241
|
+
msg = "Error while reporting run start to Data Collector. " \
|
242
|
+
"URL: #{data_collector_server_url} " \
|
243
|
+
"Exception: #{code} -- #{e.message} "
|
244
|
+
|
245
|
+
if Chef::Config[:data_collector][:raise_on_failure]
|
246
|
+
Chef::Log.error(msg)
|
247
|
+
raise
|
248
|
+
else
|
249
|
+
Chef::Log.warn(msg)
|
250
|
+
end
|
251
|
+
end
|
252
|
+
|
253
|
+
def send_to_data_collector(message)
|
254
|
+
return unless data_collector_accessible?
|
255
|
+
|
256
|
+
Chef::Log.debug("data_collector_reporter: POSTing the following message to #{data_collector_server_url}: #{message}")
|
257
|
+
http.post(nil, message, headers)
|
258
|
+
end
|
259
|
+
|
260
|
+
#
|
261
|
+
# Send any messages to the DataCollector endpoint that are necessary to
|
262
|
+
# indicate the run has completed. Currently, two messages are sent:
|
263
|
+
#
|
264
|
+
# - An "action" message with the node object indicating it's been updated
|
265
|
+
# - An "run_converge" (i.e. RunEnd) message with details about the run,
|
266
|
+
# what resources were modified/up-to-date/skipped, etc.
|
267
|
+
#
|
268
|
+
# @param opts [Hash] Additional details about the run, such as its success/failure.
|
269
|
+
#
|
270
|
+
def send_run_completion(opts)
|
271
|
+
# If run_status is nil we probably failed before the client triggered
|
272
|
+
# the run_started callback. In this case we'll skip updating because
|
273
|
+
# we have nothing to report.
|
274
|
+
return unless run_status
|
275
|
+
|
276
|
+
send_to_data_collector(Chef::DataCollector::Messages.node_update_message(run_status).to_json)
|
277
|
+
send_to_data_collector(
|
278
|
+
Chef::DataCollector::Messages.run_end_message(
|
279
|
+
run_status: run_status,
|
280
|
+
expanded_run_list: expanded_run_list,
|
281
|
+
total_resource_count: resource_count,
|
282
|
+
updated_resources: updated_resources,
|
283
|
+
status: opts[:status],
|
284
|
+
error_descriptions: error_descriptions
|
285
|
+
).to_json
|
286
|
+
)
|
287
|
+
end
|
288
|
+
|
289
|
+
def headers
|
290
|
+
headers = { "Content-Type" => "application/json" }
|
291
|
+
|
292
|
+
unless data_collector_token.nil?
|
293
|
+
headers["x-data-collector-token"] = data_collector_token
|
294
|
+
headers["x-data-collector-auth"] = "version=1.0"
|
295
|
+
end
|
296
|
+
|
297
|
+
headers
|
298
|
+
end
|
299
|
+
|
300
|
+
def data_collector_server_url
|
301
|
+
Chef::Config[:data_collector][:server_url]
|
302
|
+
end
|
303
|
+
|
304
|
+
def data_collector_token
|
305
|
+
Chef::Config[:data_collector][:token]
|
306
|
+
end
|
307
|
+
|
308
|
+
def increment_resource_count
|
309
|
+
@resource_count += 1
|
310
|
+
end
|
311
|
+
|
312
|
+
def add_updated_resource(resource_report)
|
313
|
+
@updated_resources << resource_report
|
314
|
+
end
|
315
|
+
|
316
|
+
def disable_data_collector_reporter
|
317
|
+
@enabled = false
|
318
|
+
end
|
319
|
+
|
320
|
+
def data_collector_accessible?
|
321
|
+
@enabled
|
322
|
+
end
|
323
|
+
|
324
|
+
def update_run_status(run_status)
|
325
|
+
@run_status = run_status
|
326
|
+
end
|
327
|
+
|
328
|
+
def update_current_resource_report(resource_report)
|
329
|
+
@current_resource_report = resource_report
|
330
|
+
end
|
331
|
+
|
332
|
+
def update_error_description(discription_hash)
|
333
|
+
@error_descriptions = discription_hash
|
334
|
+
end
|
335
|
+
|
336
|
+
# If we are getting messages about a resource while we are in the middle of
|
337
|
+
# another resource's update, we assume that the nested resource is just the
|
338
|
+
# implementation of a provider, and we want to hide it from the reporting
|
339
|
+
# output.
|
340
|
+
def nested_resource?(new_resource)
|
341
|
+
@current_resource_report && @current_resource_report.new_resource != new_resource
|
342
|
+
end
|
343
|
+
end
|
344
|
+
end
|
345
|
+
end
|