chef-dk 2.6.2 → 3.0.36
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/Gemfile +126 -121
- data/Gemfile.lock +812 -807
- data/LICENSE +201 -201
- data/README.md +333 -333
- data/Rakefile +74 -74
- data/acceptance/.shared/kitchen_acceptance/.kitchen.digitalocean.yml +27 -27
- data/acceptance/.shared/kitchen_acceptance/.kitchen.ec2.yml +287 -287
- data/acceptance/.shared/kitchen_acceptance/.kitchen.vagrant.yml +52 -52
- data/acceptance/.shared/kitchen_acceptance/libraries/kitchen.rb +51 -51
- data/acceptance/.shared/kitchen_acceptance/metadata.rb +1 -1
- data/acceptance/Gemfile +21 -21
- data/acceptance/Gemfile.lock +334 -334
- data/acceptance/README.md +132 -132
- data/acceptance/trivial/.acceptance/acceptance-cookbook/.gitignore +2 -2
- data/acceptance/trivial/.acceptance/acceptance-cookbook/metadata.rb +2 -2
- data/acceptance/trivial/.acceptance/acceptance-cookbook/recipes/destroy.rb +1 -1
- data/acceptance/trivial/.acceptance/acceptance-cookbook/recipes/provision.rb +1 -1
- data/acceptance/trivial/.acceptance/acceptance-cookbook/recipes/verify.rb +1 -1
- data/acceptance/trivial/.kitchen.yml +7 -7
- data/acceptance/trivial/test/integration/chefdk-current-install/inspec/chef_client_spec.rb +5 -5
- data/bin/chef +25 -25
- data/chef-dk.gemspec +60 -60
- data/lib/chef-dk.rb +19 -19
- data/lib/chef-dk/authenticated_http.rb +22 -22
- data/lib/chef-dk/builtin_commands.rb +59 -59
- data/lib/chef-dk/chef_runner.rb +114 -114
- data/lib/chef-dk/chef_server_api_multi.rb +73 -73
- data/lib/chef-dk/cli.rb +201 -201
- data/lib/chef-dk/command/base.rb +79 -79
- data/lib/chef-dk/command/clean_policy_cookbooks.rb +114 -114
- data/lib/chef-dk/command/clean_policy_revisions.rb +111 -111
- data/lib/chef-dk/command/delete_policy.rb +120 -120
- data/lib/chef-dk/command/delete_policy_group.rb +120 -120
- data/lib/chef-dk/command/diff.rb +315 -315
- data/lib/chef-dk/command/env.rb +89 -89
- data/lib/chef-dk/command/exec.rb +44 -44
- data/lib/chef-dk/command/export.rb +155 -155
- data/lib/chef-dk/command/gem.rb +47 -47
- data/lib/chef-dk/command/generate.rb +125 -125
- data/lib/chef-dk/command/generator_commands.rb +83 -83
- data/lib/chef-dk/command/generator_commands/app.rb +106 -106
- data/lib/chef-dk/command/generator_commands/attribute.rb +36 -36
- data/lib/chef-dk/command/generator_commands/base.rb +157 -157
- data/lib/chef-dk/command/generator_commands/build_cookbook.rb +125 -125
- data/lib/chef-dk/command/generator_commands/chef_exts/generator_desc_resource.rb +85 -85
- data/lib/chef-dk/command/generator_commands/chef_exts/quieter_doc_formatter.rb +38 -38
- data/lib/chef-dk/command/generator_commands/chef_exts/recipe_dsl_ext.rb +39 -39
- data/lib/chef-dk/command/generator_commands/cookbook.rb +241 -241
- data/lib/chef-dk/command/generator_commands/cookbook_code_file.rb +100 -100
- data/lib/chef-dk/command/generator_commands/cookbook_file.rb +45 -45
- data/lib/chef-dk/command/generator_commands/generator_generator.rb +174 -174
- data/lib/chef-dk/command/generator_commands/helpers.rb +36 -36
- data/lib/chef-dk/command/generator_commands/policyfile.rb +124 -126
- data/lib/chef-dk/command/generator_commands/recipe.rb +36 -36
- data/lib/chef-dk/command/generator_commands/repo.rb +123 -123
- data/lib/chef-dk/command/generator_commands/resource.rb +36 -36
- data/lib/chef-dk/command/generator_commands/template.rb +46 -46
- data/lib/chef-dk/command/install.rb +120 -120
- data/lib/chef-dk/command/provision.rb +436 -436
- data/lib/chef-dk/command/push.rb +117 -117
- data/lib/chef-dk/command/push_archive.rb +125 -125
- data/lib/chef-dk/command/shell_init.rb +179 -179
- data/lib/chef-dk/command/show_policy.rb +163 -163
- data/lib/chef-dk/command/undelete.rb +154 -154
- data/lib/chef-dk/command/update.rb +133 -133
- data/lib/chef-dk/command/verify.rb +629 -629
- data/lib/chef-dk/commands_map.rb +113 -113
- data/lib/chef-dk/completions/bash.sh.erb +5 -5
- data/lib/chef-dk/completions/chef.fish.erb +10 -10
- data/lib/chef-dk/completions/zsh.zsh.erb +21 -21
- data/lib/chef-dk/component_test.rb +227 -227
- data/lib/chef-dk/configurable.rb +88 -88
- data/lib/chef-dk/cookbook_metadata.rb +45 -45
- data/lib/chef-dk/cookbook_omnifetch.rb +32 -32
- data/lib/chef-dk/cookbook_profiler/git.rb +152 -151
- data/lib/chef-dk/cookbook_profiler/identifiers.rb +72 -72
- data/lib/chef-dk/cookbook_profiler/null_scm.rb +31 -31
- data/lib/chef-dk/exceptions.rb +151 -150
- data/lib/chef-dk/generator.rb +165 -165
- data/lib/chef-dk/helpers.rb +176 -176
- data/lib/chef-dk/pager.rb +104 -105
- data/lib/chef-dk/policyfile/artifactory_cookbook_source.rb +102 -102
- data/lib/chef-dk/policyfile/attribute_merge_checker.rb +110 -110
- data/lib/chef-dk/policyfile/chef_repo_cookbook_source.rb +138 -138
- data/lib/chef-dk/policyfile/chef_server_cookbook_source.rb +99 -99
- data/lib/chef-dk/policyfile/chef_server_lock_fetcher.rb +167 -164
- data/lib/chef-dk/policyfile/community_cookbook_source.rb +95 -95
- data/lib/chef-dk/policyfile/comparison_base.rb +123 -123
- data/lib/chef-dk/policyfile/cookbook_location_specification.rb +154 -154
- data/lib/chef-dk/policyfile/cookbook_locks.rb +466 -466
- data/lib/chef-dk/policyfile/cookbook_sources.rb +23 -23
- data/lib/chef-dk/policyfile/delivery_supermarket_source.rb +89 -89
- data/lib/chef-dk/policyfile/differ.rb +263 -263
- data/lib/chef-dk/policyfile/dsl.rb +288 -288
- data/lib/chef-dk/policyfile/git_lock_fetcher.rb +265 -0
- data/lib/chef-dk/policyfile/included_policies_cookbook_source.rb +156 -156
- data/lib/chef-dk/policyfile/lister.rb +229 -229
- data/lib/chef-dk/policyfile/local_lock_fetcher.rb +129 -123
- data/lib/chef-dk/policyfile/lock_applier.rb +80 -80
- data/lib/chef-dk/policyfile/null_cookbook_source.rb +49 -49
- data/lib/chef-dk/policyfile/policyfile_location_specification.rb +125 -122
- data/lib/chef-dk/policyfile/read_cookbook_for_compat_mode_upload.rb +124 -124
- data/lib/chef-dk/policyfile/reports/install.rb +69 -69
- data/lib/chef-dk/policyfile/reports/table_printer.rb +57 -57
- data/lib/chef-dk/policyfile/reports/upload.rb +70 -70
- data/lib/chef-dk/policyfile/solution_dependencies.rb +311 -312
- data/lib/chef-dk/policyfile/source_uri.rb +57 -57
- data/lib/chef-dk/policyfile/storage_config.rb +112 -102
- data/lib/chef-dk/policyfile/undo_record.rb +139 -139
- data/lib/chef-dk/policyfile/undo_stack.rb +128 -128
- data/lib/chef-dk/policyfile/uploader.rb +213 -213
- data/lib/chef-dk/policyfile_compiler.rb +528 -528
- data/lib/chef-dk/policyfile_lock.rb +581 -581
- data/lib/chef-dk/policyfile_services/clean_policies.rb +95 -95
- data/lib/chef-dk/policyfile_services/clean_policy_cookbooks.rb +123 -123
- data/lib/chef-dk/policyfile_services/export_repo.rb +419 -420
- data/lib/chef-dk/policyfile_services/install.rb +162 -162
- data/lib/chef-dk/policyfile_services/push.rb +112 -112
- data/lib/chef-dk/policyfile_services/push_archive.rb +164 -200
- data/lib/chef-dk/policyfile_services/rm_policy.rb +141 -141
- data/lib/chef-dk/policyfile_services/rm_policy_group.rb +85 -85
- data/lib/chef-dk/policyfile_services/show_policy.rb +234 -236
- data/lib/chef-dk/policyfile_services/undelete.rb +108 -108
- data/lib/chef-dk/policyfile_services/update_attributes.rb +110 -110
- data/lib/chef-dk/service_exception_inspectors.rb +24 -24
- data/lib/chef-dk/service_exception_inspectors/base.rb +39 -39
- data/lib/chef-dk/service_exception_inspectors/http.rb +119 -119
- data/lib/chef-dk/service_exceptions.rb +142 -142
- data/lib/chef-dk/shell_out.rb +36 -36
- data/lib/chef-dk/skeletons/code_generator/files/default/Berksfile +4 -4
- data/lib/chef-dk/skeletons/code_generator/files/default/build_cookbook/.kitchen.yml +21 -21
- data/lib/chef-dk/skeletons/code_generator/files/default/build_cookbook/README.md +146 -146
- data/lib/chef-dk/skeletons/code_generator/files/default/build_cookbook/test-fixture-recipe.rb +9 -9
- data/lib/chef-dk/skeletons/code_generator/files/default/chefignore +104 -107
- data/lib/chef-dk/skeletons/code_generator/files/default/cookbook_readmes/README-policy.md +9 -9
- data/lib/chef-dk/skeletons/code_generator/files/default/cookbook_readmes/README.md +66 -54
- data/lib/chef-dk/skeletons/code_generator/files/default/delivery-config.json +17 -17
- data/lib/chef-dk/skeletons/code_generator/files/default/delivery-project.toml +36 -36
- data/lib/chef-dk/skeletons/code_generator/files/default/gitignore +22 -22
- data/lib/chef-dk/skeletons/code_generator/files/default/repo/README.md +24 -24
- data/lib/chef-dk/skeletons/code_generator/files/default/repo/cookbooks/example/README.md +27 -27
- data/lib/chef-dk/skeletons/code_generator/files/default/repo/cookbooks/example/attributes/default.rb +8 -8
- data/lib/chef-dk/skeletons/code_generator/files/default/repo/cookbooks/example/metadata.rb +7 -7
- data/lib/chef-dk/skeletons/code_generator/files/default/repo/cookbooks/example/recipes/default.rb +9 -9
- data/lib/chef-dk/skeletons/code_generator/files/default/repo/data_bags/README.md +56 -56
- data/lib/chef-dk/skeletons/code_generator/files/default/repo/data_bags/example/example_item.json +3 -3
- data/lib/chef-dk/skeletons/code_generator/files/default/repo/dot-chef-repo.txt +6 -6
- data/lib/chef-dk/skeletons/code_generator/files/default/repo/environments/README.md +9 -9
- data/lib/chef-dk/skeletons/code_generator/files/default/repo/environments/example.json +12 -12
- data/lib/chef-dk/skeletons/code_generator/files/default/repo/policies/README.md +24 -24
- data/lib/chef-dk/skeletons/code_generator/files/default/repo/roles/README.md +9 -9
- data/lib/chef-dk/skeletons/code_generator/files/default/repo/roles/example.json +12 -12
- data/lib/chef-dk/skeletons/code_generator/files/default/spec_helper.rb +3 -3
- data/lib/chef-dk/skeletons/code_generator/files/default/spec_helper_policyfile.rb +3 -3
- data/lib/chef-dk/skeletons/code_generator/metadata.rb +8 -8
- data/lib/chef-dk/skeletons/code_generator/recipes/app.rb +89 -89
- data/lib/chef-dk/skeletons/code_generator/recipes/attribute.rb +13 -13
- data/lib/chef-dk/skeletons/code_generator/recipes/build_cookbook.rb +177 -177
- data/lib/chef-dk/skeletons/code_generator/recipes/cookbook.rb +158 -152
- data/lib/chef-dk/skeletons/code_generator/recipes/cookbook_file.rb +25 -25
- data/lib/chef-dk/skeletons/code_generator/recipes/helpers.rb +21 -21
- data/lib/chef-dk/skeletons/code_generator/recipes/policyfile.rb +9 -9
- data/lib/chef-dk/skeletons/code_generator/recipes/recipe.rb +52 -52
- data/lib/chef-dk/skeletons/code_generator/recipes/repo.rb +68 -68
- data/lib/chef-dk/skeletons/code_generator/recipes/resource.rb +13 -13
- data/lib/chef-dk/skeletons/code_generator/recipes/template.rb +32 -32
- data/lib/chef-dk/skeletons/code_generator/templates/default/CHANGELOG.md.erb +11 -0
- data/lib/chef-dk/skeletons/code_generator/templates/default/LICENSE.all_rights.erb +3 -3
- data/lib/chef-dk/skeletons/code_generator/templates/default/LICENSE.apachev2.erb +201 -201
- data/lib/chef-dk/skeletons/code_generator/templates/default/LICENSE.gplv2.erb +339 -339
- data/lib/chef-dk/skeletons/code_generator/templates/default/LICENSE.gplv3.erb +674 -674
- data/lib/chef-dk/skeletons/code_generator/templates/default/LICENSE.mit.erb +21 -21
- data/lib/chef-dk/skeletons/code_generator/templates/default/Policyfile.rb.erb +25 -25
- data/lib/chef-dk/skeletons/code_generator/templates/default/README.md.erb +4 -4
- data/lib/chef-dk/skeletons/code_generator/templates/default/build_cookbook/Berksfile.erb +7 -7
- data/lib/chef-dk/skeletons/code_generator/templates/default/build_cookbook/metadata.rb.erb +10 -10
- data/lib/chef-dk/skeletons/code_generator/templates/default/build_cookbook/recipe.rb.erb +8 -8
- data/lib/chef-dk/skeletons/code_generator/templates/default/helpers.rb.erb +39 -39
- data/lib/chef-dk/skeletons/code_generator/templates/default/inspec_default_test.rb.erb +18 -18
- data/lib/chef-dk/skeletons/code_generator/templates/default/kitchen.yml.erb +26 -26
- data/lib/chef-dk/skeletons/code_generator/templates/default/kitchen_policyfile.yml.erb +33 -33
- data/lib/chef-dk/skeletons/code_generator/templates/default/metadata.rb.erb +20 -20
- data/lib/chef-dk/skeletons/code_generator/templates/default/recipe.rb.erb +5 -5
- data/lib/chef-dk/skeletons/code_generator/templates/default/recipe_spec.rb.erb +35 -35
- data/lib/chef-dk/skeletons/code_generator/templates/default/repo/gitignore.erb +128 -128
- data/lib/chef-dk/skeletons/code_generator/templates/default/resource.rb.erb +1 -1
- data/lib/chef-dk/ui.rb +57 -57
- data/lib/chef-dk/version.rb +20 -20
- data/lib/kitchen/provisioner/policyfile_zero.rb +195 -195
- data/omnibus_overrides.rb +25 -25
- data/spec/shared/a_file_generator.rb +125 -125
- data/spec/shared/a_generated_file.rb +12 -12
- data/spec/shared/command_with_ui_object.rb +11 -11
- data/spec/shared/custom_generator_cookbook.rb +136 -136
- data/spec/shared/fixture_cookbook_checksums.rb +46 -46
- data/spec/shared/setup_git_committer_config.rb +54 -54
- data/spec/shared/setup_git_cookbooks.rb +53 -53
- data/spec/spec_helper.rb +51 -51
- data/spec/test_helpers.rb +84 -84
- data/spec/unit/chef_runner_spec.rb +139 -139
- data/spec/unit/chef_server_api_multi_spec.rb +120 -120
- data/spec/unit/cli_spec.rb +377 -377
- data/spec/unit/command/base_spec.rb +172 -172
- data/spec/unit/command/clean_policy_cookbooks_spec.rb +180 -180
- data/spec/unit/command/clean_policy_revisions_spec.rb +180 -180
- data/spec/unit/command/delete_policy_group_spec.rb +206 -206
- data/spec/unit/command/delete_policy_spec.rb +206 -206
- data/spec/unit/command/diff_spec.rb +311 -311
- data/spec/unit/command/env_spec.rb +52 -52
- data/spec/unit/command/exec_spec.rb +178 -178
- data/spec/unit/command/export_spec.rb +199 -199
- data/spec/unit/command/generate_spec.rb +142 -142
- data/spec/unit/command/generator_commands/app_spec.rb +166 -166
- data/spec/unit/command/generator_commands/attribute_spec.rb +31 -31
- data/spec/unit/command/generator_commands/base_spec.rb +181 -181
- data/spec/unit/command/generator_commands/build_cookbook_spec.rb +377 -377
- data/spec/unit/command/generator_commands/chef_exts/generator_desc_resource_spec.rb +97 -97
- data/spec/unit/command/generator_commands/chef_exts/recipe_dsl_ext_spec.rb +111 -111
- data/spec/unit/command/generator_commands/cookbook_file_spec.rb +31 -31
- data/spec/unit/command/generator_commands/cookbook_spec.rb +765 -756
- data/spec/unit/command/generator_commands/generator_generator_spec.rb +227 -227
- data/spec/unit/command/generator_commands/helpers_spec.rb +31 -31
- data/spec/unit/command/generator_commands/policyfile_spec.rb +223 -223
- data/spec/unit/command/generator_commands/recipe_spec.rb +37 -37
- data/spec/unit/command/generator_commands/repo_spec.rb +374 -374
- data/spec/unit/command/generator_commands/resource_spec.rb +31 -31
- data/spec/unit/command/generator_commands/template_spec.rb +31 -31
- data/spec/unit/command/install_spec.rb +179 -179
- data/spec/unit/command/provision_spec.rb +589 -589
- data/spec/unit/command/push_archive_spec.rb +153 -153
- data/spec/unit/command/push_spec.rb +198 -198
- data/spec/unit/command/shell_init_spec.rb +339 -339
- data/spec/unit/command/show_policy_spec.rb +234 -234
- data/spec/unit/command/undelete_spec.rb +244 -244
- data/spec/unit/command/update_spec.rb +283 -283
- data/spec/unit/command/verify_spec.rb +341 -341
- data/spec/unit/commands_map_spec.rb +57 -57
- data/spec/unit/component_test_spec.rb +128 -128
- data/spec/unit/configurable_spec.rb +68 -68
- data/spec/unit/cookbook_metadata_spec.rb +96 -96
- data/spec/unit/cookbook_profiler/git_spec.rb +176 -176
- data/spec/unit/cookbook_profiler/identifiers_spec.rb +81 -81
- data/spec/unit/fixtures/chef-runner-cookbooks/test_cookbook/recipes/recipe_one.rb +9 -9
- data/spec/unit/fixtures/chef-runner-cookbooks/test_cookbook/recipes/recipe_two.rb +9 -9
- data/spec/unit/fixtures/command/cli_test_command.rb +26 -26
- data/spec/unit/fixtures/command/explicit_path_example.rb +7 -7
- data/spec/unit/fixtures/configurable/test_config_loader.rb +5 -5
- data/spec/unit/fixtures/configurable/test_configurable.rb +10 -10
- data/spec/unit/fixtures/cookbook_cache/baz-f59ee7a5bca6a4e606b67f7f856b768d847c39bb/.kitchen.yml +16 -16
- data/spec/unit/fixtures/cookbook_cache/baz-f59ee7a5bca6a4e606b67f7f856b768d847c39bb/Berksfile +3 -3
- data/spec/unit/fixtures/cookbook_cache/baz-f59ee7a5bca6a4e606b67f7f856b768d847c39bb/README.md +4 -4
- data/spec/unit/fixtures/cookbook_cache/baz-f59ee7a5bca6a4e606b67f7f856b768d847c39bb/chefignore +96 -96
- data/spec/unit/fixtures/cookbook_cache/baz-f59ee7a5bca6a4e606b67f7f856b768d847c39bb/metadata.rb +8 -8
- data/spec/unit/fixtures/cookbook_cache/baz-f59ee7a5bca6a4e606b67f7f856b768d847c39bb/recipes/default.rb +8 -8
- data/spec/unit/fixtures/cookbook_cache/dep_of_bar-1.2.3/.kitchen.yml +16 -16
- data/spec/unit/fixtures/cookbook_cache/dep_of_bar-1.2.3/Berksfile +3 -3
- data/spec/unit/fixtures/cookbook_cache/dep_of_bar-1.2.3/README.md +4 -4
- data/spec/unit/fixtures/cookbook_cache/dep_of_bar-1.2.3/chefignore +96 -96
- data/spec/unit/fixtures/cookbook_cache/dep_of_bar-1.2.3/metadata.rb +8 -8
- data/spec/unit/fixtures/cookbook_cache/dep_of_bar-1.2.3/recipes/default.rb +8 -8
- data/spec/unit/fixtures/cookbook_cache/foo-1.0.0/.kitchen.yml +16 -16
- data/spec/unit/fixtures/cookbook_cache/foo-1.0.0/Berksfile +3 -3
- data/spec/unit/fixtures/cookbook_cache/foo-1.0.0/README.md +4 -4
- data/spec/unit/fixtures/cookbook_cache/foo-1.0.0/chefignore +96 -96
- data/spec/unit/fixtures/cookbook_cache/foo-1.0.0/metadata.rb +8 -8
- data/spec/unit/fixtures/cookbook_cache/foo-1.0.0/recipes/default.rb +8 -8
- data/spec/unit/fixtures/cookbooks_api/chef_server_universe.json +56 -56
- data/spec/unit/fixtures/cookbooks_api/pruned_chef_server_universe.json +30 -30
- data/spec/unit/fixtures/cookbooks_api/pruned_small_universe.json +1321 -1321
- data/spec/unit/fixtures/cookbooks_api/small_universe.json +2987 -2987
- data/spec/unit/fixtures/cookbooks_api/universe.json +1 -1
- data/spec/unit/fixtures/cookbooks_api/update_fixtures.rb +33 -33
- data/spec/unit/fixtures/dev_cookbooks/README.md +16 -16
- data/spec/unit/fixtures/eg_omnibus_dir/valid/embedded/apps/berkshelf/integration_test +2 -2
- data/spec/unit/fixtures/eg_omnibus_dir/valid/embedded/apps/berkshelf/verify_me +5 -5
- data/spec/unit/fixtures/eg_omnibus_dir/valid/embedded/apps/chef/verify_me +3 -3
- data/spec/unit/fixtures/eg_omnibus_dir/valid/embedded/apps/test-kitchen/verify_me +2 -2
- data/spec/unit/fixtures/example_cookbook/.gitignore +17 -17
- data/spec/unit/fixtures/example_cookbook/.kitchen.yml +16 -16
- data/spec/unit/fixtures/example_cookbook/Berksfile +3 -3
- data/spec/unit/fixtures/example_cookbook/README.md +4 -4
- data/spec/unit/fixtures/example_cookbook/chefignore +96 -96
- data/spec/unit/fixtures/example_cookbook/metadata.rb +8 -8
- data/spec/unit/fixtures/example_cookbook/recipes/default.rb +8 -8
- data/spec/unit/fixtures/example_cookbook_metadata_json_only/.gitignore +17 -17
- data/spec/unit/fixtures/example_cookbook_metadata_json_only/.kitchen.yml +16 -16
- data/spec/unit/fixtures/example_cookbook_metadata_json_only/Berksfile +3 -3
- data/spec/unit/fixtures/example_cookbook_metadata_json_only/README.md +4 -4
- data/spec/unit/fixtures/example_cookbook_metadata_json_only/chefignore +96 -96
- data/spec/unit/fixtures/example_cookbook_metadata_json_only/metadata.json +5 -5
- data/spec/unit/fixtures/example_cookbook_metadata_json_only/recipes/default.rb +8 -8
- data/spec/unit/fixtures/example_cookbook_no_metadata/.gitignore +17 -17
- data/spec/unit/fixtures/example_cookbook_no_metadata/.kitchen.yml +16 -16
- data/spec/unit/fixtures/example_cookbook_no_metadata/Berksfile +3 -3
- data/spec/unit/fixtures/example_cookbook_no_metadata/README.md +4 -4
- data/spec/unit/fixtures/example_cookbook_no_metadata/chefignore +96 -96
- data/spec/unit/fixtures/example_cookbook_no_metadata/recipes/default.rb +8 -8
- data/spec/unit/fixtures/local_path_cookbooks/another-local-cookbook/README.md +4 -4
- data/spec/unit/fixtures/local_path_cookbooks/another-local-cookbook/chefignore +96 -96
- data/spec/unit/fixtures/local_path_cookbooks/another-local-cookbook/metadata.rb +8 -8
- data/spec/unit/fixtures/local_path_cookbooks/another-local-cookbook/recipes/default.rb +8 -8
- data/spec/unit/fixtures/local_path_cookbooks/cookbook-with-a-dep/Berksfile +3 -3
- data/spec/unit/fixtures/local_path_cookbooks/cookbook-with-a-dep/README.md +4 -4
- data/spec/unit/fixtures/local_path_cookbooks/cookbook-with-a-dep/chefignore +96 -96
- data/spec/unit/fixtures/local_path_cookbooks/cookbook-with-a-dep/metadata.rb +9 -9
- data/spec/unit/fixtures/local_path_cookbooks/cookbook-with-a-dep/recipes/default.rb +8 -8
- data/spec/unit/fixtures/local_path_cookbooks/local-cookbook/.kitchen.yml +16 -16
- data/spec/unit/fixtures/local_path_cookbooks/local-cookbook/Berksfile +3 -3
- data/spec/unit/fixtures/local_path_cookbooks/local-cookbook/README.md +4 -4
- data/spec/unit/fixtures/local_path_cookbooks/local-cookbook/chefignore +96 -96
- data/spec/unit/fixtures/local_path_cookbooks/local-cookbook/metadata.rb +8 -8
- data/spec/unit/fixtures/local_path_cookbooks/local-cookbook/recipes/default.rb +8 -8
- data/spec/unit/fixtures/local_path_cookbooks/metadata-missing/README.md +2 -2
- data/spec/unit/fixtures/local_path_cookbooks/noignore-f59ee7a5bca6a4e606b67f7f856b768d847c39bb/.kitchen.yml +16 -16
- data/spec/unit/fixtures/local_path_cookbooks/noignore-f59ee7a5bca6a4e606b67f7f856b768d847c39bb/README.md +4 -4
- data/spec/unit/fixtures/local_path_cookbooks/noignore-f59ee7a5bca6a4e606b67f7f856b768d847c39bb/metadata.rb +8 -8
- data/spec/unit/fixtures/local_path_cookbooks/noignore-f59ee7a5bca6a4e606b67f7f856b768d847c39bb/recipes/default.rb +8 -8
- data/spec/unit/generator_spec.rb +119 -119
- data/spec/unit/pager_spec.rb +117 -117
- data/spec/unit/policyfile/artifactory_cookbook_source_spec.rb +59 -59
- data/spec/unit/policyfile/attribute_merge_checker_spec.rb +80 -80
- data/spec/unit/policyfile/chef_repo_cookbook_source_spec.rb +93 -93
- data/spec/unit/policyfile/chef_server_cookbook_source_spec.rb +55 -55
- data/spec/unit/policyfile/chef_server_lock_fetcher_spec.rb +161 -161
- data/spec/unit/policyfile/community_cookbook_source_spec.rb +83 -83
- data/spec/unit/policyfile/comparison_base_spec.rb +340 -340
- data/spec/unit/policyfile/cookbook_location_specification_spec.rb +347 -347
- data/spec/unit/policyfile/cookbook_locks_spec.rb +527 -527
- data/spec/unit/policyfile/delivery_supermarket_source_spec.rb +129 -129
- data/spec/unit/policyfile/differ_spec.rb +686 -686
- data/spec/unit/policyfile/git_lock_fetcher_spec.rb +155 -0
- data/spec/unit/policyfile/included_policies_cookbook_source_spec.rb +242 -242
- data/spec/unit/policyfile/lister_spec.rb +268 -268
- data/spec/unit/policyfile/local_lock_fetcher_spec.rb +173 -173
- data/spec/unit/policyfile/lock_applier_spec.rb +100 -100
- data/spec/unit/policyfile/null_cookbook_source_spec.rb +34 -34
- data/spec/unit/policyfile/read_cookbook_for_compat_mode_upload_spec.rb +92 -92
- data/spec/unit/policyfile/reports/install_spec.rb +114 -114
- data/spec/unit/policyfile/reports/upload_spec.rb +94 -94
- data/spec/unit/policyfile/solution_dependencies_spec.rb +170 -170
- data/spec/unit/policyfile/source_uri_spec.rb +36 -36
- data/spec/unit/policyfile/storage_config_spec.rb +180 -180
- data/spec/unit/policyfile/undo_record_spec.rb +258 -258
- data/spec/unit/policyfile/undo_stack_spec.rb +265 -265
- data/spec/unit/policyfile/uploader_spec.rb +409 -409
- data/spec/unit/policyfile_demands_spec.rb +1197 -1197
- data/spec/unit/policyfile_evaluation_spec.rb +628 -638
- data/spec/unit/policyfile_includes_dsl_spec.rb +159 -159
- data/spec/unit/policyfile_includes_spec.rb +720 -720
- data/spec/unit/policyfile_install_with_includes_spec.rb +232 -232
- data/spec/unit/policyfile_lock_build_spec.rb +1065 -1065
- data/spec/unit/policyfile_lock_install_spec.rb +137 -137
- data/spec/unit/policyfile_lock_serialization_spec.rb +424 -424
- data/spec/unit/policyfile_lock_validation_spec.rb +608 -608
- data/spec/unit/policyfile_services/clean_policies_spec.rb +236 -236
- data/spec/unit/policyfile_services/clean_policy_cookbooks_spec.rb +272 -272
- data/spec/unit/policyfile_services/export_repo_spec.rb +473 -478
- data/spec/unit/policyfile_services/install_spec.rb +209 -209
- data/spec/unit/policyfile_services/push_archive_spec.rb +359 -374
- data/spec/unit/policyfile_services/push_spec.rb +249 -249
- data/spec/unit/policyfile_services/rm_policy_group_spec.rb +237 -237
- data/spec/unit/policyfile_services/rm_policy_spec.rb +263 -263
- data/spec/unit/policyfile_services/show_policy_spec.rb +887 -887
- data/spec/unit/policyfile_services/undelete_spec.rb +302 -302
- data/spec/unit/policyfile_services/update_attributes_spec.rb +229 -229
- data/spec/unit/policyfile_services/update_spec.rb +140 -140
- data/spec/unit/service_exception_inspectors/base_spec.rb +41 -41
- data/spec/unit/service_exception_inspectors/http_spec.rb +138 -138
- data/spec/unit/shell_out_spec.rb +34 -34
- data/tasks/announce.rb +57 -57
- data/tasks/bin/bundle-platform.bat +2 -2
- data/tasks/dependencies.rb +89 -89
- data/tasks/templates/prerelease.md.erb +35 -35
- data/tasks/templates/release.md.erb +34 -34
- data/warning.txt +9 -9
- metadata +9 -5
|
@@ -0,0 +1,265 @@
|
|
|
1
|
+
#
|
|
2
|
+
# Copyright:: Copyright (c) 2018 Chef Software Inc.
|
|
3
|
+
# License:: Apache License, Version 2.0
|
|
4
|
+
#
|
|
5
|
+
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
6
|
+
# you may not use this file except in compliance with the License.
|
|
7
|
+
# You may obtain a copy of the License at
|
|
8
|
+
#
|
|
9
|
+
# http://www.apache.org/licenses/LICENSE-2.0
|
|
10
|
+
#
|
|
11
|
+
# Unless required by applicable law or agreed to in writing, software
|
|
12
|
+
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
13
|
+
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
14
|
+
# See the License for the specific language governing permissions and
|
|
15
|
+
# limitations under the License.
|
|
16
|
+
#
|
|
17
|
+
|
|
18
|
+
require "chef-dk/policyfile_lock"
|
|
19
|
+
require "chef-dk/exceptions"
|
|
20
|
+
require "chef-dk/helpers"
|
|
21
|
+
require "mixlib/shellout"
|
|
22
|
+
require "tmpdir"
|
|
23
|
+
|
|
24
|
+
module ChefDK
|
|
25
|
+
module Policyfile
|
|
26
|
+
|
|
27
|
+
# A Policyfile lock fetcher that can read a lock file from a git repository.
|
|
28
|
+
#
|
|
29
|
+
# @author Ryan Hass
|
|
30
|
+
# @author Daniel DeLeo
|
|
31
|
+
#
|
|
32
|
+
# @since 3.0
|
|
33
|
+
#
|
|
34
|
+
class GitLockFetcher
|
|
35
|
+
attr_accessor :name
|
|
36
|
+
attr_accessor :source_options
|
|
37
|
+
attr_accessor :storage_config
|
|
38
|
+
|
|
39
|
+
attr_reader :uri
|
|
40
|
+
attr_reader :revision
|
|
41
|
+
attr_reader :path
|
|
42
|
+
attr_reader :branch
|
|
43
|
+
attr_reader :tag
|
|
44
|
+
attr_reader :ref
|
|
45
|
+
|
|
46
|
+
# Initialize a GitLockFetcher
|
|
47
|
+
#
|
|
48
|
+
# @param name [String] The name of the policyfile
|
|
49
|
+
# @param source_options [Hash] A hash with a :path key pointing at the location
|
|
50
|
+
# of the lock
|
|
51
|
+
def initialize(name, source_options, storage_config)
|
|
52
|
+
@name = name
|
|
53
|
+
@storage_config = storage_config
|
|
54
|
+
@source_options = symbolize_keys(source_options)
|
|
55
|
+
@revision = @source_options[:revision]
|
|
56
|
+
@path = @source_options[:path] || @source_options[:rel]
|
|
57
|
+
@uri = @source_options[:git]
|
|
58
|
+
@branch = @source_options[:branch]
|
|
59
|
+
@tag = @source_options[:tag]
|
|
60
|
+
@ref = @source_options[:ref]
|
|
61
|
+
|
|
62
|
+
# The revision to parse
|
|
63
|
+
@rev_parse = @source_options[:ref] || @source_options[:branch] || @source_options[:tag] || "master"
|
|
64
|
+
end
|
|
65
|
+
|
|
66
|
+
# @return [True] if there were no errors with the provided source_options
|
|
67
|
+
# @return [False] if there were errors with the provided source_options
|
|
68
|
+
def valid?
|
|
69
|
+
errors.empty?
|
|
70
|
+
end
|
|
71
|
+
|
|
72
|
+
# Check the options provided when craeting this class for errors
|
|
73
|
+
#
|
|
74
|
+
# @return [Array<String>] A list of errors found
|
|
75
|
+
def errors
|
|
76
|
+
error_messages = []
|
|
77
|
+
[:git].each do |key|
|
|
78
|
+
error_messages << "include_policy for #{name} is missing key #{key}" unless source_options[key]
|
|
79
|
+
end
|
|
80
|
+
|
|
81
|
+
error_messages
|
|
82
|
+
end
|
|
83
|
+
|
|
84
|
+
# @return [Hash] The source_options that describe how to fetch this exact lock again
|
|
85
|
+
def source_options_for_lock
|
|
86
|
+
source_options.merge({
|
|
87
|
+
revision: revision,
|
|
88
|
+
})
|
|
89
|
+
end
|
|
90
|
+
|
|
91
|
+
# Applies source options from a lock file. This is used to make sure that the same
|
|
92
|
+
# policyfile lock is loaded that was locked
|
|
93
|
+
#
|
|
94
|
+
# @param options_from_lock [Hash] The source options loaded from a policyfile lock
|
|
95
|
+
def apply_locked_source_options(options_from_lock)
|
|
96
|
+
options = options_from_lock.inject({}) do |acc, (key, value)|
|
|
97
|
+
acc[key.to_sym] = value
|
|
98
|
+
acc
|
|
99
|
+
end
|
|
100
|
+
source_options.merge!(options)
|
|
101
|
+
raise ChefDK::InvalidLockfile, "Invalid source_options provided from lock data: #{options_from_lock_file.inspect}" if !valid?
|
|
102
|
+
end
|
|
103
|
+
|
|
104
|
+
# @return [Hash] of the policyfile lock data
|
|
105
|
+
def lock_data
|
|
106
|
+
@lock_data ||= fetch_lock_data.tap do |data|
|
|
107
|
+
data["cookbook_locks"].each do |cookbook_name, cookbook_lock|
|
|
108
|
+
if cookbook_lock["source_options"].has_key?("path")
|
|
109
|
+
cookbook_lock["source_options"].tap do |opt|
|
|
110
|
+
opt["git"] = uri unless opt.has_key?("git")
|
|
111
|
+
opt["revision"] = revision unless opt.has_key?("revision")
|
|
112
|
+
opt["branch"] = branch unless opt.has_key?("branch") || branch.nil?
|
|
113
|
+
opt["tag"] = tag unless opt.has_key?("tag") || branch.nil?
|
|
114
|
+
opt["ref"] = ref unless opt.has_key?("ref") || ref.nil?
|
|
115
|
+
|
|
116
|
+
path_keys = %w{path rel}.map { |path_key| path_key if opt.has_key?(path_key) }.compact
|
|
117
|
+
|
|
118
|
+
path_keys.each do |name|
|
|
119
|
+
# We can safely grab the entire cookbook when the Policyfile defines a cookbook path of itself (".")
|
|
120
|
+
if opt[name] == "."
|
|
121
|
+
opt.delete(name)
|
|
122
|
+
next
|
|
123
|
+
end
|
|
124
|
+
|
|
125
|
+
# Mutate the path key to a rel key so that we identify the source_type
|
|
126
|
+
# as a git repo and not a local directory. Git also doesn't like paths
|
|
127
|
+
# prefixed with `./` and cannot use relative paths outside the repo.
|
|
128
|
+
# http://rubular.com/r/JYpdYHT19p
|
|
129
|
+
pattern = /(^..\/)|(^.\/)/
|
|
130
|
+
opt["rel"] = opt[name].gsub(pattern, "")
|
|
131
|
+
end
|
|
132
|
+
|
|
133
|
+
# Delete the path key if present to ensure we use the git source_type
|
|
134
|
+
opt.delete("path")
|
|
135
|
+
end
|
|
136
|
+
end # cookbook_lock["source_options"]
|
|
137
|
+
end # data["cookbook_locks"].each
|
|
138
|
+
end # fetch_lock_data.tap
|
|
139
|
+
|
|
140
|
+
@lock_data
|
|
141
|
+
end
|
|
142
|
+
|
|
143
|
+
private
|
|
144
|
+
|
|
145
|
+
# Helper method to normalize data.
|
|
146
|
+
#
|
|
147
|
+
# @param [Hash] hash Hash with symbols and/or strings as keys.
|
|
148
|
+
# @return [Hash] Hash with only symbols as keys.
|
|
149
|
+
def symbolize_keys(hash)
|
|
150
|
+
hash.inject({}) { |memo, (k, v)| memo[k.to_sym] = v; memo }
|
|
151
|
+
end
|
|
152
|
+
|
|
153
|
+
def fetch_lock_data
|
|
154
|
+
install unless installed?
|
|
155
|
+
FFI_Yajl::Parser.parse(
|
|
156
|
+
show_file(rev_parse, lockfile_path)
|
|
157
|
+
)
|
|
158
|
+
end
|
|
159
|
+
|
|
160
|
+
# COPYPASTA from CookbookOmnifetch
|
|
161
|
+
def installed?
|
|
162
|
+
!!(revision && cache_path.exist?)
|
|
163
|
+
end
|
|
164
|
+
|
|
165
|
+
# COPYPASTA from CookbookOmnifetch::GitLocation and Berkshelf::GitLocation
|
|
166
|
+
# then munged since we do not have Policyfile validation in scope.
|
|
167
|
+
# Install into the chefdk cookbook store. This method leverages a cached
|
|
168
|
+
# git copy.
|
|
169
|
+
def install
|
|
170
|
+
if cached?
|
|
171
|
+
Dir.chdir(cache_path) do
|
|
172
|
+
git %{fetch --force --tags #{uri} "refs/heads/*:refs/heads/*"}
|
|
173
|
+
end
|
|
174
|
+
else
|
|
175
|
+
git %{clone #{uri} "#{cache_path}" --bare --no-hardlinks}
|
|
176
|
+
end
|
|
177
|
+
|
|
178
|
+
Dir.chdir(cache_path) do
|
|
179
|
+
@revision ||= git %{rev-parse #{rev_parse}}
|
|
180
|
+
end
|
|
181
|
+
end
|
|
182
|
+
|
|
183
|
+
def rev_parse
|
|
184
|
+
source_options[:revision] || @rev_parse
|
|
185
|
+
end
|
|
186
|
+
|
|
187
|
+
# Shows contents of a file from a shallow or full clone repository for a
|
|
188
|
+
# given git version.
|
|
189
|
+
#
|
|
190
|
+
# This method was originally made before I slammed a bunch of copypasta
|
|
191
|
+
# code in which is generally more tied to a specific git ref.
|
|
192
|
+
#
|
|
193
|
+
# @param version Git version as a tag, branch, or ref.
|
|
194
|
+
# @param file Full path to file including filename in repository
|
|
195
|
+
#
|
|
196
|
+
# @return [String] Content of specified file for a given revision.
|
|
197
|
+
def show_file(version, file)
|
|
198
|
+
git("show #{version}:#{file}", cwd: cache_path)
|
|
199
|
+
end
|
|
200
|
+
|
|
201
|
+
# COPYPASTA from CookbookOmnifetch
|
|
202
|
+
# Location an executable in the current user's $PATH
|
|
203
|
+
#
|
|
204
|
+
# @return [String, nil]
|
|
205
|
+
# the path to the executable, or +nil+ if not present
|
|
206
|
+
def which(executable)
|
|
207
|
+
if File.file?(executable) && File.executable?(executable)
|
|
208
|
+
executable
|
|
209
|
+
elsif ENV["PATH"]
|
|
210
|
+
path = ENV["PATH"].split(File::PATH_SEPARATOR).find do |p|
|
|
211
|
+
File.executable?(File.join(p, executable))
|
|
212
|
+
end
|
|
213
|
+
path && File.expand_path(executable, path)
|
|
214
|
+
end
|
|
215
|
+
end
|
|
216
|
+
|
|
217
|
+
# COPYPASTA from CookbookOmnifetch::Git
|
|
218
|
+
# Perform a git command.
|
|
219
|
+
#
|
|
220
|
+
# @param [String] command
|
|
221
|
+
# the command to run
|
|
222
|
+
# @param [Boolean] error
|
|
223
|
+
# whether to raise error if the command fails
|
|
224
|
+
#
|
|
225
|
+
# @raise [String]
|
|
226
|
+
# the +$stdout+ from the command
|
|
227
|
+
def git(command, options = {})
|
|
228
|
+
error = options[:error] || true
|
|
229
|
+
unless which("git") || which("git.exe") || which("git.bat")
|
|
230
|
+
raise GitNotInstalled
|
|
231
|
+
end
|
|
232
|
+
|
|
233
|
+
response = Mixlib::ShellOut.new(%{git #{command}}, options)
|
|
234
|
+
response.run_command
|
|
235
|
+
|
|
236
|
+
if error && response.error?
|
|
237
|
+
raise GitError.new "#{command} #{cache_path}: #{response.stderr}"
|
|
238
|
+
end
|
|
239
|
+
|
|
240
|
+
response.stdout.strip
|
|
241
|
+
end
|
|
242
|
+
|
|
243
|
+
# COPYPASTA from CookbookOmnifetch::Git (then munged by me)
|
|
244
|
+
# The path where this git repository is cached.
|
|
245
|
+
#
|
|
246
|
+
# @return [Pathname]
|
|
247
|
+
def cache_path
|
|
248
|
+
Pathname.new(File.expand_path(File.join(ChefDK::Helpers.chefdk_home, "cache")))
|
|
249
|
+
.join(".cache", "git", Digest::SHA1.hexdigest(uri))
|
|
250
|
+
end
|
|
251
|
+
|
|
252
|
+
# COPYPASTA from CookbookOmnifetch::Git
|
|
253
|
+
# Determine if this git repo has already been downloaded.
|
|
254
|
+
#
|
|
255
|
+
# @return [Boolean]
|
|
256
|
+
def cached?
|
|
257
|
+
cache_path.exist?
|
|
258
|
+
end
|
|
259
|
+
|
|
260
|
+
def lockfile_path
|
|
261
|
+
@path.nil? ? "Policyfile.lock.json" : @path
|
|
262
|
+
end
|
|
263
|
+
end
|
|
264
|
+
end
|
|
265
|
+
end
|
|
@@ -1,156 +1,156 @@
|
|
|
1
|
-
#
|
|
2
|
-
# Copyright:: Copyright (c) 2014 Chef Software Inc.
|
|
3
|
-
# License:: Apache License, Version 2.0
|
|
4
|
-
#
|
|
5
|
-
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
6
|
-
# you may not use this file except in compliance with the License.
|
|
7
|
-
# You may obtain a copy of the License at
|
|
8
|
-
#
|
|
9
|
-
# http://www.apache.org/licenses/LICENSE-2.0
|
|
10
|
-
#
|
|
11
|
-
# Unless required by applicable law or agreed to in writing, software
|
|
12
|
-
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
13
|
-
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
14
|
-
# See the License for the specific language governing permissions and
|
|
15
|
-
# limitations under the License.
|
|
16
|
-
#
|
|
17
|
-
|
|
18
|
-
require "chef-dk/ui"
|
|
19
|
-
|
|
20
|
-
module ChefDK
|
|
21
|
-
module Policyfile
|
|
22
|
-
class IncludedPoliciesCookbookSource
|
|
23
|
-
|
|
24
|
-
class ConflictingCookbookVersions < StandardError
|
|
25
|
-
end
|
|
26
|
-
|
|
27
|
-
class ConflictingCookbookDependencies < StandardError
|
|
28
|
-
end
|
|
29
|
-
|
|
30
|
-
class ConflictingCookbookSources < StandardError
|
|
31
|
-
end
|
|
32
|
-
|
|
33
|
-
# Why do we need this class?
|
|
34
|
-
# If we rely on default sources, we may not have the the universe of cookbooks
|
|
35
|
-
# provided in the included policies
|
|
36
|
-
#
|
|
37
|
-
# This is not meant to be used from the DSL
|
|
38
|
-
|
|
39
|
-
# A list of included policies
|
|
40
|
-
attr_reader :included_policy_location_specs
|
|
41
|
-
# UI object for output
|
|
42
|
-
attr_accessor :ui
|
|
43
|
-
|
|
44
|
-
# Constructor
|
|
45
|
-
#
|
|
46
|
-
def initialize(included_policy_location_specs)
|
|
47
|
-
@included_policy_location_specs = included_policy_location_specs
|
|
48
|
-
@ui = UI.new
|
|
49
|
-
@preferred_cookbooks = []
|
|
50
|
-
yield self if block_given?
|
|
51
|
-
end
|
|
52
|
-
|
|
53
|
-
def default_source_args
|
|
54
|
-
[:included_policies, []]
|
|
55
|
-
end
|
|
56
|
-
|
|
57
|
-
def check_for_conflicts!
|
|
58
|
-
source_options
|
|
59
|
-
universe_graph
|
|
60
|
-
end
|
|
61
|
-
|
|
62
|
-
# All are preferred here
|
|
63
|
-
def preferred_source_for?(cookbook_name)
|
|
64
|
-
universe_graph.include?(cookbook_name)
|
|
65
|
-
end
|
|
66
|
-
|
|
67
|
-
def preferred_cookbooks
|
|
68
|
-
universe_graph.keys
|
|
69
|
-
end
|
|
70
|
-
|
|
71
|
-
def ==(other)
|
|
72
|
-
other.kind_of?(self.class) && other.included_policy_location_specs == included_policy_location_specs
|
|
73
|
-
end
|
|
74
|
-
|
|
75
|
-
# Calls the slurp_metadata! helper once to calculate the @universe_graph
|
|
76
|
-
# and @cookbook_version_paths metadata. Returns the @universe_graph.
|
|
77
|
-
#
|
|
78
|
-
# @return [Hash] universe_graph
|
|
79
|
-
def universe_graph
|
|
80
|
-
@universe_graph ||= build_universe
|
|
81
|
-
end
|
|
82
|
-
|
|
83
|
-
# Returns the metadata (path and version) for an individual cookbook
|
|
84
|
-
#
|
|
85
|
-
# @return [Hash] metadata for a single cookbook version
|
|
86
|
-
def source_options_for(cookbook_name, cookbook_version)
|
|
87
|
-
source_options[cookbook_name][cookbook_version]
|
|
88
|
-
end
|
|
89
|
-
|
|
90
|
-
def null?
|
|
91
|
-
false
|
|
92
|
-
end
|
|
93
|
-
|
|
94
|
-
def desc
|
|
95
|
-
"included_policies()"
|
|
96
|
-
end
|
|
97
|
-
|
|
98
|
-
private
|
|
99
|
-
|
|
100
|
-
def build_universe
|
|
101
|
-
included_policy_location_specs.inject({}) do |acc, policy_spec|
|
|
102
|
-
lock = policy_spec.policyfile_lock
|
|
103
|
-
cookbook_dependencies = lock.solution_dependencies.cookbook_dependencies
|
|
104
|
-
cookbook_dependencies.each do |(cookbook, deps)|
|
|
105
|
-
name = cookbook.name
|
|
106
|
-
version = cookbook.version
|
|
107
|
-
mapped_deps = deps.map do |dep|
|
|
108
|
-
[dep[0], dep[1].to_s]
|
|
109
|
-
end
|
|
110
|
-
if acc[name]
|
|
111
|
-
if acc[name][version]
|
|
112
|
-
if acc[name][version] != mapped_deps
|
|
113
|
-
raise ConflictingCookbookDependencies.new("Conflicting dependencies provided for cookbook #{name}")
|
|
114
|
-
end
|
|
115
|
-
else
|
|
116
|
-
raise ConflictingCookbookVersions.new("Multiple versions provided for cookbook #{name}")
|
|
117
|
-
end
|
|
118
|
-
else
|
|
119
|
-
acc[name] = {}
|
|
120
|
-
acc[name][version] = mapped_deps
|
|
121
|
-
end
|
|
122
|
-
end
|
|
123
|
-
acc
|
|
124
|
-
end
|
|
125
|
-
end
|
|
126
|
-
|
|
127
|
-
def source_options
|
|
128
|
-
@source_options ||= build_source_options
|
|
129
|
-
end
|
|
130
|
-
|
|
131
|
-
## Collect all the source options
|
|
132
|
-
def build_source_options
|
|
133
|
-
included_policy_location_specs.inject({}) do |acc, policy_spec|
|
|
134
|
-
lock = policy_spec.policyfile_lock
|
|
135
|
-
lock.cookbook_locks.each do |(name, cookbook_lock)|
|
|
136
|
-
version = cookbook_lock.version
|
|
137
|
-
if acc[name]
|
|
138
|
-
if acc[name][version]
|
|
139
|
-
if acc[name][version] != cookbook_lock.source_options
|
|
140
|
-
raise ConflictingCookbookSources.new("Conflicting sources provided for cookbook #{name}")
|
|
141
|
-
end
|
|
142
|
-
else
|
|
143
|
-
raise ConflictingCookbookVersions.new("Multiple sources provided for cookbook #{name}")
|
|
144
|
-
end
|
|
145
|
-
else
|
|
146
|
-
acc[name] = {}
|
|
147
|
-
acc[name][version] = cookbook_lock.source_options
|
|
148
|
-
end
|
|
149
|
-
end
|
|
150
|
-
acc
|
|
151
|
-
end
|
|
152
|
-
end
|
|
153
|
-
|
|
154
|
-
end
|
|
155
|
-
end
|
|
156
|
-
end
|
|
1
|
+
#
|
|
2
|
+
# Copyright:: Copyright (c) 2014-2018 Chef Software Inc.
|
|
3
|
+
# License:: Apache License, Version 2.0
|
|
4
|
+
#
|
|
5
|
+
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
6
|
+
# you may not use this file except in compliance with the License.
|
|
7
|
+
# You may obtain a copy of the License at
|
|
8
|
+
#
|
|
9
|
+
# http://www.apache.org/licenses/LICENSE-2.0
|
|
10
|
+
#
|
|
11
|
+
# Unless required by applicable law or agreed to in writing, software
|
|
12
|
+
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
13
|
+
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
14
|
+
# See the License for the specific language governing permissions and
|
|
15
|
+
# limitations under the License.
|
|
16
|
+
#
|
|
17
|
+
|
|
18
|
+
require "chef-dk/ui"
|
|
19
|
+
|
|
20
|
+
module ChefDK
|
|
21
|
+
module Policyfile
|
|
22
|
+
class IncludedPoliciesCookbookSource
|
|
23
|
+
|
|
24
|
+
class ConflictingCookbookVersions < StandardError
|
|
25
|
+
end
|
|
26
|
+
|
|
27
|
+
class ConflictingCookbookDependencies < StandardError
|
|
28
|
+
end
|
|
29
|
+
|
|
30
|
+
class ConflictingCookbookSources < StandardError
|
|
31
|
+
end
|
|
32
|
+
|
|
33
|
+
# Why do we need this class?
|
|
34
|
+
# If we rely on default sources, we may not have the the universe of cookbooks
|
|
35
|
+
# provided in the included policies
|
|
36
|
+
#
|
|
37
|
+
# This is not meant to be used from the DSL
|
|
38
|
+
|
|
39
|
+
# A list of included policies
|
|
40
|
+
attr_reader :included_policy_location_specs
|
|
41
|
+
# UI object for output
|
|
42
|
+
attr_accessor :ui
|
|
43
|
+
|
|
44
|
+
# Constructor
|
|
45
|
+
#
|
|
46
|
+
def initialize(included_policy_location_specs)
|
|
47
|
+
@included_policy_location_specs = included_policy_location_specs
|
|
48
|
+
@ui = UI.new
|
|
49
|
+
@preferred_cookbooks = []
|
|
50
|
+
yield self if block_given?
|
|
51
|
+
end
|
|
52
|
+
|
|
53
|
+
def default_source_args
|
|
54
|
+
[:included_policies, []]
|
|
55
|
+
end
|
|
56
|
+
|
|
57
|
+
def check_for_conflicts!
|
|
58
|
+
source_options
|
|
59
|
+
universe_graph
|
|
60
|
+
end
|
|
61
|
+
|
|
62
|
+
# All are preferred here
|
|
63
|
+
def preferred_source_for?(cookbook_name)
|
|
64
|
+
universe_graph.include?(cookbook_name)
|
|
65
|
+
end
|
|
66
|
+
|
|
67
|
+
def preferred_cookbooks
|
|
68
|
+
universe_graph.keys
|
|
69
|
+
end
|
|
70
|
+
|
|
71
|
+
def ==(other)
|
|
72
|
+
other.kind_of?(self.class) && other.included_policy_location_specs == included_policy_location_specs
|
|
73
|
+
end
|
|
74
|
+
|
|
75
|
+
# Calls the slurp_metadata! helper once to calculate the @universe_graph
|
|
76
|
+
# and @cookbook_version_paths metadata. Returns the @universe_graph.
|
|
77
|
+
#
|
|
78
|
+
# @return [Hash] universe_graph
|
|
79
|
+
def universe_graph
|
|
80
|
+
@universe_graph ||= build_universe
|
|
81
|
+
end
|
|
82
|
+
|
|
83
|
+
# Returns the metadata (path and version) for an individual cookbook
|
|
84
|
+
#
|
|
85
|
+
# @return [Hash] metadata for a single cookbook version
|
|
86
|
+
def source_options_for(cookbook_name, cookbook_version)
|
|
87
|
+
source_options[cookbook_name][cookbook_version]
|
|
88
|
+
end
|
|
89
|
+
|
|
90
|
+
def null?
|
|
91
|
+
false
|
|
92
|
+
end
|
|
93
|
+
|
|
94
|
+
def desc
|
|
95
|
+
"included_policies()"
|
|
96
|
+
end
|
|
97
|
+
|
|
98
|
+
private
|
|
99
|
+
|
|
100
|
+
def build_universe
|
|
101
|
+
included_policy_location_specs.inject({}) do |acc, policy_spec|
|
|
102
|
+
lock = policy_spec.policyfile_lock
|
|
103
|
+
cookbook_dependencies = lock.solution_dependencies.cookbook_dependencies
|
|
104
|
+
cookbook_dependencies.each do |(cookbook, deps)|
|
|
105
|
+
name = cookbook.name
|
|
106
|
+
version = cookbook.version
|
|
107
|
+
mapped_deps = deps.map do |dep|
|
|
108
|
+
[dep[0], dep[1].to_s]
|
|
109
|
+
end
|
|
110
|
+
if acc[name]
|
|
111
|
+
if acc[name][version]
|
|
112
|
+
if acc[name][version] != mapped_deps
|
|
113
|
+
raise ConflictingCookbookDependencies.new("Conflicting dependencies provided for cookbook #{name}")
|
|
114
|
+
end
|
|
115
|
+
else
|
|
116
|
+
raise ConflictingCookbookVersions.new("Multiple versions provided for cookbook #{name}")
|
|
117
|
+
end
|
|
118
|
+
else
|
|
119
|
+
acc[name] = {}
|
|
120
|
+
acc[name][version] = mapped_deps
|
|
121
|
+
end
|
|
122
|
+
end
|
|
123
|
+
acc
|
|
124
|
+
end
|
|
125
|
+
end
|
|
126
|
+
|
|
127
|
+
def source_options
|
|
128
|
+
@source_options ||= build_source_options
|
|
129
|
+
end
|
|
130
|
+
|
|
131
|
+
## Collect all the source options
|
|
132
|
+
def build_source_options
|
|
133
|
+
included_policy_location_specs.inject({}) do |acc, policy_spec|
|
|
134
|
+
lock = policy_spec.policyfile_lock
|
|
135
|
+
lock.cookbook_locks.each do |(name, cookbook_lock)|
|
|
136
|
+
version = cookbook_lock.version
|
|
137
|
+
if acc[name]
|
|
138
|
+
if acc[name][version]
|
|
139
|
+
if acc[name][version] != cookbook_lock.source_options
|
|
140
|
+
raise ConflictingCookbookSources.new("Conflicting sources provided for cookbook #{name}")
|
|
141
|
+
end
|
|
142
|
+
else
|
|
143
|
+
raise ConflictingCookbookVersions.new("Multiple sources provided for cookbook #{name}")
|
|
144
|
+
end
|
|
145
|
+
else
|
|
146
|
+
acc[name] = {}
|
|
147
|
+
acc[name][version] = cookbook_lock.source_options
|
|
148
|
+
end
|
|
149
|
+
end
|
|
150
|
+
acc
|
|
151
|
+
end
|
|
152
|
+
end
|
|
153
|
+
|
|
154
|
+
end
|
|
155
|
+
end
|
|
156
|
+
end
|