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
@@ -141,10 +141,15 @@ class Chef
|
|
141
141
|
|
142
142
|
def extract_cookbook(upstream_file, version)
|
143
143
|
ui.info("Uncompressing #{@cookbook_name} version #{version}.")
|
144
|
-
# FIXME: Detect if we have the bad tar from git on Windows: https://github.com/opscode/chef/issues/1753
|
145
144
|
extract_command = "tar zxvf \"#{convert_path upstream_file}\""
|
146
145
|
if Chef::Platform.windows?
|
147
|
-
|
146
|
+
tar_version = shell_out("tar --version").stdout.tr("\n", " ")
|
147
|
+
if tar_version =~ /GNU tar/
|
148
|
+
Chef::Log.debug("GNU tar detected, adding --force-local")
|
149
|
+
extract_command << " --force-local"
|
150
|
+
else
|
151
|
+
Chef::Log.debug("non-GNU tar detected, not adding --force-local")
|
152
|
+
end
|
148
153
|
end
|
149
154
|
shell_out!(extract_command, :cwd => @install_path)
|
150
155
|
end
|
@@ -1,4 +1,4 @@
|
|
1
|
-
# Do not edit this file by hand
|
2
|
-
# This file is autogenerated by the docs:list rake task from the available manpages
|
3
|
-
|
4
|
-
HELP_TOPICS = ["chef-shell", "knife-bootstrap", "knife-client", "knife-configure", "knife-cookbook-site", "knife-cookbook", "knife-data-bag", "knife-delete", "knife-deps", "knife-diff", "knife-download", "knife-edit", "knife-environment", "knife-exec", "knife-index-rebuild", "knife-list", "knife-node", "knife-raw", "knife-recipe-list", "knife-role", "knife-search", "knife-show", "knife-ssh", "knife-status", "knife-tag", "knife-upload", "knife-user", "knife-xargs", "knife"]
|
1
|
+
# Do not edit this file by hand
|
2
|
+
# This file is autogenerated by the docs:list rake task from the available manpages
|
3
|
+
|
4
|
+
HELP_TOPICS = ["chef-shell", "knife-bootstrap", "knife-client", "knife-configure", "knife-cookbook-site", "knife-cookbook", "knife-data-bag", "knife-delete", "knife-deps", "knife-diff", "knife-download", "knife-edit", "knife-environment", "knife-exec", "knife-index-rebuild", "knife-list", "knife-node", "knife-raw", "knife-recipe-list", "knife-role", "knife-search", "knife-show", "knife-ssh", "knife-status", "knife-tag", "knife-upload", "knife-user", "knife-xargs", "knife"]
|
data/lib/chef/knife/list.rb
CHANGED
@@ -44,7 +44,6 @@ class Chef
|
|
44
44
|
patterns = name_args.length == 0 ? [""] : name_args
|
45
45
|
|
46
46
|
# Get the top-level matches
|
47
|
-
args = pattern_args_from(patterns)
|
48
47
|
all_results = parallelize(pattern_args_from(patterns)) do |pattern|
|
49
48
|
pattern_results = Chef::ChefFS::FileSystem.list(config[:local] ? local_fs : chef_fs, pattern).to_a
|
50
49
|
|
@@ -95,7 +94,7 @@ class Chef
|
|
95
94
|
printed_something = true
|
96
95
|
end
|
97
96
|
output "#{format_path(result)}:"
|
98
|
-
print_results(children.map { |result| maybe_add_slash(result.
|
97
|
+
print_results(children.map { |result| maybe_add_slash(result.display_name, result.dir?) }.sort, "")
|
99
98
|
end
|
100
99
|
|
101
100
|
exit self.exit_code if self.exit_code
|
data/lib/chef/knife/ssl_check.rb
CHANGED
@@ -257,7 +257,8 @@ ADVICE
|
|
257
257
|
|
258
258
|
def trusted_certificates
|
259
259
|
if configuration.trusted_certs_dir && Dir.exist?(configuration.trusted_certs_dir)
|
260
|
-
|
260
|
+
glob_dir = ChefConfig::PathHelper.escape_glob_dir(configuration.trusted_certs_dir)
|
261
|
+
Dir.glob(File.join(glob_dir, "*.{crt,pem}"))
|
261
262
|
else
|
262
263
|
[]
|
263
264
|
end
|
@@ -22,6 +22,17 @@ require "win32/registry"
|
|
22
22
|
module Win32
|
23
23
|
class Registry
|
24
24
|
|
25
|
+
# ::Win32::Registry#export_string is used when enumerating child
|
26
|
+
# keys and values and re encodes a UTF-16LE to the local codepage.
|
27
|
+
# This can result in encoding incompatibilities if the native codepage
|
28
|
+
# does not support the characters in the registry. There is an open bug
|
29
|
+
# in ruby at https://bugs.ruby-lang.org/issues/11410. Rather than converting
|
30
|
+
# the UTF-16LE originally returned by the win32 api, we encode to UTF-8
|
31
|
+
# which will likely not result in any conversion error.
|
32
|
+
def export_string(str, enc = Encoding.default_internal || "utf-8")
|
33
|
+
str.encode(enc)
|
34
|
+
end
|
35
|
+
|
25
36
|
module API
|
26
37
|
|
27
38
|
extend Chef::ReservedNames::Win32::API::Registry
|
data/lib/chef/nil_argument.rb
CHANGED
@@ -1,3 +1,3 @@
|
|
1
|
-
class Chef
|
2
|
-
NIL_ARGUMENT = Object.new
|
3
|
-
end
|
1
|
+
class Chef
|
2
|
+
NIL_ARGUMENT = Object.new
|
3
|
+
end
|
data/lib/chef/node.rb
CHANGED
@@ -25,7 +25,7 @@ require "chef/mixin/params_validate"
|
|
25
25
|
require "chef/mixin/from_file"
|
26
26
|
require "chef/mixin/deep_merge"
|
27
27
|
require "chef/dsl/include_attribute"
|
28
|
-
require "chef/dsl/
|
28
|
+
require "chef/dsl/universal"
|
29
29
|
require "chef/environment"
|
30
30
|
require "chef/server_api"
|
31
31
|
require "chef/run_list"
|
@@ -58,7 +58,7 @@ class Chef
|
|
58
58
|
|
59
59
|
include Chef::Mixin::FromFile
|
60
60
|
include Chef::DSL::IncludeAttribute
|
61
|
-
include Chef::DSL::
|
61
|
+
include Chef::DSL::Universal
|
62
62
|
|
63
63
|
include Chef::Mixin::ParamsValidate
|
64
64
|
|
@@ -19,6 +19,7 @@
|
|
19
19
|
require "chef/dsl/reboot_pending"
|
20
20
|
require "chef/log"
|
21
21
|
require "chef/platform"
|
22
|
+
require "chef/application/exit_code"
|
22
23
|
|
23
24
|
class Chef
|
24
25
|
class Platform
|
@@ -27,6 +28,8 @@ class Chef
|
|
27
28
|
|
28
29
|
class << self
|
29
30
|
|
31
|
+
include Chef::DSL::RebootPending
|
32
|
+
|
30
33
|
def reboot!(node)
|
31
34
|
reboot_info = node.run_context.reboot_info
|
32
35
|
|
@@ -38,8 +41,16 @@ class Chef
|
|
38
41
|
"shutdown -r +#{reboot_info[:delay_mins]} \"#{reboot_info[:reason]}\""
|
39
42
|
end
|
40
43
|
|
41
|
-
|
42
|
-
|
44
|
+
msg = "Rebooting server at a recipe's request. Details: #{reboot_info.inspect}"
|
45
|
+
begin
|
46
|
+
Chef::Log.warn msg
|
47
|
+
shell_out!(cmd)
|
48
|
+
rescue Mixlib::ShellOut::ShellCommandFailed => e
|
49
|
+
raise Chef::Exceptions::RebootFailed.new(e.message)
|
50
|
+
end
|
51
|
+
|
52
|
+
raise Chef::Exceptions::Reboot.new(msg) if Chef::Application::ExitCode.enforce_rfc_062_exit_codes?
|
53
|
+
Chef::Application::ExitCode.notify_reboot_exit_code_deprecation
|
43
54
|
end
|
44
55
|
|
45
56
|
# this is a wrapper function so Chef::Client only needs a single line of code.
|
@@ -69,7 +69,7 @@ class Chef
|
|
69
69
|
end
|
70
70
|
|
71
71
|
def setup_run_context(specific_recipes = nil)
|
72
|
-
if Chef::Config[:
|
72
|
+
if Chef::Config[:solo_legacy_mode]
|
73
73
|
Chef::Cookbook::FileVendor.fetch_from_disk(Chef::Config[:cookbook_path])
|
74
74
|
cl = Chef::CookbookLoader.new(Chef::Config[:cookbook_path])
|
75
75
|
cl.load_cookbooks
|
@@ -118,7 +118,7 @@ class Chef
|
|
118
118
|
Chef::Log.debug("Building node object for #{node_name}")
|
119
119
|
|
120
120
|
@node =
|
121
|
-
if Chef::Config[:
|
121
|
+
if Chef::Config[:solo_legacy_mode]
|
122
122
|
Chef::Node.build(node_name)
|
123
123
|
else
|
124
124
|
Chef::Node.find_or_create(node_name)
|
@@ -167,7 +167,7 @@ class Chef
|
|
167
167
|
|
168
168
|
# Expands the node's run list. Stores the run_list_expansion object for later use.
|
169
169
|
def expand_run_list
|
170
|
-
@run_list_expansion = if Chef::Config[:
|
170
|
+
@run_list_expansion = if Chef::Config[:solo_legacy_mode]
|
171
171
|
node.expand!("disk")
|
172
172
|
else
|
173
173
|
node.expand!("server")
|
data/lib/chef/provider/git.rb
CHANGED
@@ -25,8 +25,11 @@ class Chef
|
|
25
25
|
class Provider
|
26
26
|
class Git < Chef::Provider
|
27
27
|
|
28
|
+
extend Forwardable
|
28
29
|
provides :git
|
29
30
|
|
31
|
+
def_delegator :@new_resource, :destination, :cwd
|
32
|
+
|
30
33
|
def whyrun_supported?
|
31
34
|
true
|
32
35
|
end
|
@@ -42,11 +45,11 @@ class Chef
|
|
42
45
|
def define_resource_requirements
|
43
46
|
# Parent directory of the target must exist.
|
44
47
|
requirements.assert(:checkout, :sync) do |a|
|
45
|
-
dirname = ::File.dirname(
|
48
|
+
dirname = ::File.dirname(cwd)
|
46
49
|
a.assertion { ::File.directory?(dirname) }
|
47
50
|
a.whyrun("Directory #{dirname} does not exist, this run will fail unless it has been previously created. Assuming it would have been created.")
|
48
51
|
a.failure_message(Chef::Exceptions::MissingParentDirectory,
|
49
|
-
"Cannot clone #{@new_resource} to #{
|
52
|
+
"Cannot clone #{@new_resource} to #{cwd}, the enclosing directory #{dirname} does not exist")
|
50
53
|
end
|
51
54
|
|
52
55
|
requirements.assert(:all_actions) do |a|
|
@@ -79,14 +82,14 @@ class Chef
|
|
79
82
|
enable_submodules
|
80
83
|
add_remotes
|
81
84
|
else
|
82
|
-
Chef::Log.debug "#{@new_resource} checkout destination #{
|
85
|
+
Chef::Log.debug "#{@new_resource} checkout destination #{cwd} already exists or is a non-empty directory"
|
83
86
|
end
|
84
87
|
end
|
85
88
|
|
86
89
|
def action_export
|
87
90
|
action_checkout
|
88
|
-
converge_by("complete the export by removing #{
|
89
|
-
FileUtils.rm_rf(::File.join(
|
91
|
+
converge_by("complete the export by removing #{cwd}.git after checkout") do
|
92
|
+
FileUtils.rm_rf(::File.join(cwd, ".git"))
|
90
93
|
end
|
91
94
|
end
|
92
95
|
|
@@ -105,22 +108,22 @@ class Chef
|
|
105
108
|
end
|
106
109
|
|
107
110
|
def git_minor_version
|
108
|
-
@git_minor_version ||= Gem::Version.new(
|
111
|
+
@git_minor_version ||= Gem::Version.new( git("--version").stdout.split.last )
|
109
112
|
end
|
110
113
|
|
111
114
|
def existing_git_clone?
|
112
|
-
::File.exist?(::File.join(
|
115
|
+
::File.exist?(::File.join(cwd, ".git"))
|
113
116
|
end
|
114
117
|
|
115
118
|
def target_dir_non_existent_or_empty?
|
116
|
-
!::File.exist?(
|
119
|
+
!::File.exist?(cwd) || Dir.entries(cwd).sort == [".", ".."]
|
117
120
|
end
|
118
121
|
|
119
122
|
def find_current_revision
|
120
123
|
Chef::Log.debug("#{@new_resource} finding current git revision")
|
121
124
|
if ::File.exist?(::File.join(cwd, ".git"))
|
122
125
|
# 128 is returned when we're not in a git repo. this is fine
|
123
|
-
result =
|
126
|
+
result = git("rev-parse", "HEAD", cwd: cwd, returns: [0, 128]).stdout.strip
|
124
127
|
end
|
125
128
|
sha_hash?(result) ? result : nil
|
126
129
|
end
|
@@ -137,18 +140,18 @@ class Chef
|
|
137
140
|
end
|
138
141
|
|
139
142
|
def clone
|
140
|
-
converge_by("clone from #{@new_resource.repository} into #{
|
143
|
+
converge_by("clone from #{@new_resource.repository} into #{cwd}") do
|
141
144
|
remote = @new_resource.remote
|
142
145
|
|
143
|
-
|
144
|
-
|
145
|
-
|
146
|
-
|
147
|
-
|
148
|
-
|
146
|
+
clone_cmd = ["clone"]
|
147
|
+
clone_cmd << "-o #{remote}" unless remote == "origin"
|
148
|
+
clone_cmd << "--depth #{@new_resource.depth}" if @new_resource.depth
|
149
|
+
clone_cmd << "--no-single-branch" if @new_resource.depth && git_minor_version >= Gem::Version.new("1.7.10")
|
150
|
+
clone_cmd << "\"#{@new_resource.repository}\""
|
151
|
+
clone_cmd << "\"#{cwd}\""
|
149
152
|
|
150
|
-
|
151
|
-
|
153
|
+
Chef::Log.info "#{@new_resource} cloning repo #{@new_resource.repository} to #{cwd}"
|
154
|
+
git clone_cmd
|
152
155
|
end
|
153
156
|
end
|
154
157
|
|
@@ -157,8 +160,8 @@ class Chef
|
|
157
160
|
|
158
161
|
converge_by("checkout ref #{sha_ref} branch #{@new_resource.revision}") do
|
159
162
|
# checkout into a local branch rather than a detached HEAD
|
160
|
-
|
161
|
-
|
163
|
+
git("branch", "-f", @new_resource.checkout_branch, sha_ref, cwd: cwd)
|
164
|
+
git("checkout", @new_resource.checkout_branch, cwd: cwd)
|
162
165
|
Chef::Log.info "#{@new_resource} checked out branch: #{@new_resource.revision} onto: #{@new_resource.checkout_branch} reference: #{sha_ref}"
|
163
166
|
end
|
164
167
|
end
|
@@ -167,12 +170,10 @@ class Chef
|
|
167
170
|
if @new_resource.enable_submodules
|
168
171
|
converge_by("enable git submodules for #{@new_resource}") do
|
169
172
|
Chef::Log.info "#{@new_resource} synchronizing git submodules"
|
170
|
-
|
171
|
-
shell_out!(command, run_options(:cwd => @new_resource.destination))
|
173
|
+
git("submodule", "sync", cwd: cwd)
|
172
174
|
Chef::Log.info "#{@new_resource} enabling git submodules"
|
173
175
|
# the --recursive flag means we require git 1.6.5+ now, see CHEF-1827
|
174
|
-
|
175
|
-
shell_out!(command, run_options(:cwd => @new_resource.destination))
|
176
|
+
git("submodule", "update", "--init", "--recursive", cwd: cwd)
|
176
177
|
end
|
177
178
|
end
|
178
179
|
end
|
@@ -181,17 +182,18 @@ class Chef
|
|
181
182
|
setup_remote_tracking_branches(@new_resource.remote, @new_resource.repository)
|
182
183
|
converge_by("fetch updates for #{@new_resource.remote}") do
|
183
184
|
# since we're in a local branch already, just reset to specified revision rather than merge
|
184
|
-
fetch_command = "git fetch #{@new_resource.remote} && git fetch #{@new_resource.remote} --tags && git reset --hard #{target_revision}"
|
185
185
|
Chef::Log.debug "Fetching updates from #{new_resource.remote} and resetting to revision #{target_revision}"
|
186
|
-
|
186
|
+
git("fetch", @new_resource.remote, cwd: cwd)
|
187
|
+
git("fetch", @new_resource.remote, "--tags", cwd: cwd)
|
188
|
+
git("reset", "--hard", target_revision, cwd: cwd)
|
187
189
|
end
|
188
190
|
end
|
189
191
|
|
190
192
|
def setup_remote_tracking_branches(remote_name, remote_url)
|
191
193
|
converge_by("set up remote tracking branches for #{remote_url} at #{remote_name}") do
|
192
194
|
Chef::Log.debug "#{@new_resource} configuring remote tracking branches for repository #{remote_url} " + "at remote #{remote_name}"
|
193
|
-
check_remote_command = "
|
194
|
-
remote_status =
|
195
|
+
check_remote_command = ["config", "--get", "remote.#{remote_name}.url"]
|
196
|
+
remote_status = git(check_remote_command, cwd: cwd, returns: [0, 1, 2])
|
195
197
|
case remote_status.exitstatus
|
196
198
|
when 0, 2
|
197
199
|
# * Status 0 means that we already have a remote with this name, so we should update the url
|
@@ -200,12 +202,10 @@ class Chef
|
|
200
202
|
# which we can fix by replacing them all with our target url (hence the --replace-all option)
|
201
203
|
|
202
204
|
if multiple_remotes?(remote_status) || !remote_matches?(remote_url, remote_status)
|
203
|
-
|
204
|
-
shell_out!(update_remote_url_command, run_options(:cwd => @new_resource.destination))
|
205
|
+
git("config", "--replace-all", "remote.#{remote_name}.url", remote_url, cwd: cwd)
|
205
206
|
end
|
206
207
|
when 1
|
207
|
-
|
208
|
-
shell_out!(add_remote_command, run_options(:cwd => @new_resource.destination))
|
208
|
+
git("remote", "add", remote_name, remote_url, cwd: cwd)
|
209
209
|
end
|
210
210
|
end
|
211
211
|
end
|
@@ -282,8 +282,7 @@ class Chef
|
|
282
282
|
end
|
283
283
|
|
284
284
|
def git_ls_remote(rev_pattern)
|
285
|
-
|
286
|
-
shell_out!(command, run_options).stdout
|
285
|
+
git("ls-remote", "\"#{@new_resource.repository}\"", "\"#{rev_pattern}\"").stdout
|
287
286
|
end
|
288
287
|
|
289
288
|
def refs_search(refs, pattern)
|
@@ -301,7 +300,12 @@ class Chef
|
|
301
300
|
# user who is executing `git` not the user running Chef.
|
302
301
|
env["HOME"] = begin
|
303
302
|
require "etc"
|
304
|
-
|
303
|
+
case @new_resource.user
|
304
|
+
when Integer
|
305
|
+
Etc.getpwuid(@new_resource.user).dir
|
306
|
+
else
|
307
|
+
Etc.getpwnam(@new_resource.user.to_s).dir
|
308
|
+
end
|
305
309
|
rescue ArgumentError # user not found
|
306
310
|
raise Chef::Exceptions::User, "Could not determine HOME for specified user '#{@new_resource.user}' for resource '#{@new_resource.name}'"
|
307
311
|
end
|
@@ -315,12 +319,10 @@ class Chef
|
|
315
319
|
run_opts
|
316
320
|
end
|
317
321
|
|
318
|
-
def
|
319
|
-
|
320
|
-
|
321
|
-
|
322
|
-
def git(*args)
|
323
|
-
["git", *args].compact.join(" ")
|
322
|
+
def git(*args, **run_opts)
|
323
|
+
git_command = ["git", args].compact.join(" ")
|
324
|
+
Chef::Log.debug "running #{git_command}"
|
325
|
+
shell_out!(git_command, run_options(run_opts))
|
324
326
|
end
|
325
327
|
|
326
328
|
def sha_hash?(string)
|
@@ -34,7 +34,6 @@ class Chef
|
|
34
34
|
# These were previously provided by Chef::Mixin::RecipeDefinitionDSLCore.
|
35
35
|
# They are not included by its replacement, Chef::DSL::Recipe, but
|
36
36
|
# they may be used in existing LWRPs.
|
37
|
-
include Chef::DSL::PlatformIntrospection
|
38
37
|
include Chef::DSL::DataQuery
|
39
38
|
|
40
39
|
# Allow include_recipe from within LWRP provider code
|
@@ -54,9 +54,8 @@ class Chef
|
|
54
54
|
@new_resource.profile_name
|
55
55
|
end
|
56
56
|
|
57
|
-
|
58
|
-
|
59
|
-
else
|
57
|
+
current_profile = nil
|
58
|
+
if all_profiles && !all_profiles.empty?
|
60
59
|
current_profile = all_profiles["_computerlevel"].find do |item|
|
61
60
|
item["ProfileIdentifier"] == @new_profile_identifier
|
62
61
|
end
|
@@ -22,6 +22,7 @@ require "chef/mixin/subclass_directive"
|
|
22
22
|
require "chef/log"
|
23
23
|
require "chef/file_cache"
|
24
24
|
require "chef/platform"
|
25
|
+
require "chef/decorator/lazy_array"
|
25
26
|
|
26
27
|
class Chef
|
27
28
|
class Provider
|
@@ -256,9 +257,41 @@ class Chef
|
|
256
257
|
options ? " #{options}" : ""
|
257
258
|
end
|
258
259
|
|
259
|
-
#
|
260
|
-
|
261
|
-
|
260
|
+
# Check the current_version against either the candidate_version or the new_version
|
261
|
+
#
|
262
|
+
# For some reason the windows provider subclasses this (to implement passing Arrays to
|
263
|
+
# versions for some reason other than multipackage stuff, which is mildly terrifying).
|
264
|
+
#
|
265
|
+
# This MUST have 'equality' semantics -- the exact thing matches the exact thing.
|
266
|
+
#
|
267
|
+
# The current_version should probably be dropped out of the method signature, it should
|
268
|
+
# always be the first argument.
|
269
|
+
#
|
270
|
+
# The name is not just bad, but i find it completely misleading, consider:
|
271
|
+
#
|
272
|
+
# target_version_already_installed?(current_version, new_version)
|
273
|
+
# target_version_already_installed?(current_version, candidate_version)
|
274
|
+
#
|
275
|
+
# which of those is the 'target_version'? i'd say the new_version and i'm confused when
|
276
|
+
# i see it called with the candidate_version.
|
277
|
+
#
|
278
|
+
# `current_version_equals?(version)` would be a better name
|
279
|
+
def target_version_already_installed?(current_version, target_version)
|
280
|
+
return false unless current_version && target_version
|
281
|
+
current_version == target_version
|
282
|
+
end
|
283
|
+
|
284
|
+
# Check the current_version against the new_resource.version, possibly using fuzzy
|
285
|
+
# matching criteria.
|
286
|
+
#
|
287
|
+
# Subclasses MAY override this to provide fuzzy matching on the resource ('>=' and '~>' stuff)
|
288
|
+
#
|
289
|
+
# This should only ever be offered the same arguments (so they should most likely be
|
290
|
+
# removed from the method signature).
|
291
|
+
#
|
292
|
+
# `new_version_satisfied?()` might be a better name
|
293
|
+
def version_requirement_satisfied?(current_version, new_version)
|
294
|
+
target_version_already_installed?(current_version, new_version)
|
262
295
|
end
|
263
296
|
|
264
297
|
# @todo: extract apt/dpkg specific preseeding to a helper class
|
@@ -354,12 +387,15 @@ class Chef
|
|
354
387
|
each_package do |package_name, new_version, current_version, candidate_version|
|
355
388
|
case action
|
356
389
|
when :upgrade
|
357
|
-
|
358
|
-
|
359
|
-
Chef::Log.debug("#{new_resource} #{package_name}
|
390
|
+
if target_version_already_installed?(current_version, new_version)
|
391
|
+
# this is an odd use case
|
392
|
+
Chef::Log.debug("#{new_resource} #{package_name} #{new_version} is already installed -- you are equality pinning with an :upgrade action, this may be deprecated in the future")
|
360
393
|
target_version_array.push(nil)
|
361
|
-
elsif current_version
|
362
|
-
Chef::Log.debug("#{new_resource} #{package_name}
|
394
|
+
elsif target_version_already_installed?(current_version, candidate_version)
|
395
|
+
Chef::Log.debug("#{new_resource} #{package_name} #{candidate_version} is already installed")
|
396
|
+
target_version_array.push(nil)
|
397
|
+
elsif candidate_version.nil?
|
398
|
+
Chef::Log.debug("#{new_resource} #{package_name} has no candidate_version to upgrade to")
|
363
399
|
target_version_array.push(nil)
|
364
400
|
else
|
365
401
|
Chef::Log.debug("#{new_resource} #{package_name} is out of date, will upgrade to #{candidate_version}")
|
@@ -369,7 +405,7 @@ class Chef
|
|
369
405
|
when :install
|
370
406
|
|
371
407
|
if new_version
|
372
|
-
if
|
408
|
+
if version_requirement_satisfied?(current_version, new_version)
|
373
409
|
Chef::Log.debug("#{new_resource} #{package_name} #{current_version} satisifies #{new_version} requirement")
|
374
410
|
target_version_array.push(nil)
|
375
411
|
else
|
@@ -411,7 +447,7 @@ class Chef
|
|
411
447
|
begin
|
412
448
|
missing = []
|
413
449
|
each_package do |package_name, new_version, current_version, candidate_version|
|
414
|
-
missing.push(package_name) if
|
450
|
+
missing.push(package_name) if current_version.nil? && candidate_version.nil?
|
415
451
|
end
|
416
452
|
missing
|
417
453
|
end
|
@@ -436,7 +472,7 @@ class Chef
|
|
436
472
|
missing = []
|
437
473
|
each_package do |package_name, new_version, current_version, candidate_version|
|
438
474
|
next if new_version.nil? || current_version.nil?
|
439
|
-
if
|
475
|
+
if !version_requirement_satisfied?(current_version, new_version) && candidate_version.nil?
|
440
476
|
missing.push(package_name)
|
441
477
|
end
|
442
478
|
end
|
@@ -468,7 +504,9 @@ class Chef
|
|
468
504
|
|
469
505
|
# @return [Array] candidate_version(s) as an array
|
470
506
|
def candidate_version_array
|
471
|
-
|
507
|
+
# NOTE: even with use_multipackage_api candidate_version may be a bare nil and need wrapping
|
508
|
+
# ( looking at you, dpkg provider... )
|
509
|
+
Chef::Decorator::LazyArray.new { [ candidate_version ].flatten }
|
472
510
|
end
|
473
511
|
|
474
512
|
# @return [Array] current_version(s) as an array
|
@@ -558,7 +596,7 @@ class Chef
|
|
558
596
|
# @param args [String] variable number of string arguments
|
559
597
|
# @return [String] nicely concatenated string or empty string
|
560
598
|
def a_to_s(*args)
|
561
|
-
args.reject { |i| i.nil? || i == "" }.join(" ")
|
599
|
+
args.flatten.reject { |i| i.nil? || i == "" }.join(" ")
|
562
600
|
end
|
563
601
|
end
|
564
602
|
end
|