chef-cli 1.0.3
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 +7 -0
- data/Gemfile +32 -0
- data/LICENSE +201 -0
- data/Rakefile +70 -0
- data/bin/chef +25 -0
- data/chef-cli.gemspec +53 -0
- data/lib/chef-cli.rb +19 -0
- data/lib/chef-cli/authenticated_http.rb +22 -0
- data/lib/chef-cli/builtin_commands.rb +62 -0
- data/lib/chef-cli/chef_runner.rb +114 -0
- data/lib/chef-cli/chef_server_api_multi.rb +73 -0
- data/lib/chef-cli/cli.rb +206 -0
- data/lib/chef-cli/command/base.rb +89 -0
- data/lib/chef-cli/command/clean_policy_cookbooks.rb +115 -0
- data/lib/chef-cli/command/clean_policy_revisions.rb +112 -0
- data/lib/chef-cli/command/delete_policy.rb +121 -0
- data/lib/chef-cli/command/delete_policy_group.rb +121 -0
- data/lib/chef-cli/command/describe_cookbook.rb +98 -0
- data/lib/chef-cli/command/diff.rb +316 -0
- data/lib/chef-cli/command/env.rb +99 -0
- data/lib/chef-cli/command/exec.rb +45 -0
- data/lib/chef-cli/command/export.rb +156 -0
- data/lib/chef-cli/command/gem.rb +48 -0
- data/lib/chef-cli/command/generate.rb +123 -0
- data/lib/chef-cli/command/generator_commands.rb +83 -0
- data/lib/chef-cli/command/generator_commands/attribute.rb +37 -0
- data/lib/chef-cli/command/generator_commands/base.rb +157 -0
- data/lib/chef-cli/command/generator_commands/build_cookbook.rb +126 -0
- data/lib/chef-cli/command/generator_commands/chef_exts/generator_desc_resource.rb +40 -0
- data/lib/chef-cli/command/generator_commands/chef_exts/quieter_doc_formatter.rb +38 -0
- data/lib/chef-cli/command/generator_commands/chef_exts/recipe_dsl_ext.rb +39 -0
- data/lib/chef-cli/command/generator_commands/cookbook.rb +251 -0
- data/lib/chef-cli/command/generator_commands/cookbook_code_file.rb +100 -0
- data/lib/chef-cli/command/generator_commands/cookbook_file.rb +46 -0
- data/lib/chef-cli/command/generator_commands/generator_generator.rb +175 -0
- data/lib/chef-cli/command/generator_commands/helpers.rb +37 -0
- data/lib/chef-cli/command/generator_commands/policyfile.rb +125 -0
- data/lib/chef-cli/command/generator_commands/recipe.rb +37 -0
- data/lib/chef-cli/command/generator_commands/repo.rb +140 -0
- data/lib/chef-cli/command/generator_commands/resource.rb +37 -0
- data/lib/chef-cli/command/generator_commands/template.rb +47 -0
- data/lib/chef-cli/command/install.rb +121 -0
- data/lib/chef-cli/command/provision.rb +38 -0
- data/lib/chef-cli/command/push.rb +118 -0
- data/lib/chef-cli/command/push_archive.rb +126 -0
- data/lib/chef-cli/command/shell_init.rb +185 -0
- data/lib/chef-cli/command/show_policy.rb +164 -0
- data/lib/chef-cli/command/undelete.rb +155 -0
- data/lib/chef-cli/command/update.rb +140 -0
- data/lib/chef-cli/command/verify.rb +548 -0
- data/lib/chef-cli/commands_map.rb +113 -0
- data/lib/chef-cli/completions/bash.sh.erb +5 -0
- data/lib/chef-cli/completions/chef.fish.erb +10 -0
- data/lib/chef-cli/completions/zsh.zsh.erb +21 -0
- data/lib/chef-cli/component_test.rb +226 -0
- data/lib/chef-cli/configurable.rb +88 -0
- data/lib/chef-cli/cookbook_metadata.rb +45 -0
- data/lib/chef-cli/cookbook_omnifetch.rb +32 -0
- data/lib/chef-cli/cookbook_profiler/git.rb +152 -0
- data/lib/chef-cli/cookbook_profiler/identifiers.rb +72 -0
- data/lib/chef-cli/cookbook_profiler/null_scm.rb +31 -0
- data/lib/chef-cli/dist.rb +31 -0
- data/lib/chef-cli/exceptions.rb +153 -0
- data/lib/chef-cli/generator.rb +165 -0
- data/lib/chef-cli/helpers.rb +170 -0
- data/lib/chef-cli/pager.rb +104 -0
- data/lib/chef-cli/policyfile/artifactory_cookbook_source.rb +102 -0
- data/lib/chef-cli/policyfile/attribute_merge_checker.rb +110 -0
- data/lib/chef-cli/policyfile/chef_repo_cookbook_source.rb +138 -0
- data/lib/chef-cli/policyfile/chef_server_cookbook_source.rb +99 -0
- data/lib/chef-cli/policyfile/chef_server_lock_fetcher.rb +167 -0
- data/lib/chef-cli/policyfile/community_cookbook_source.rb +95 -0
- data/lib/chef-cli/policyfile/comparison_base.rb +123 -0
- data/lib/chef-cli/policyfile/cookbook_location_specification.rb +154 -0
- data/lib/chef-cli/policyfile/cookbook_locks.rb +466 -0
- data/lib/chef-cli/policyfile/cookbook_sources.rb +23 -0
- data/lib/chef-cli/policyfile/delivery_supermarket_source.rb +89 -0
- data/lib/chef-cli/policyfile/differ.rb +263 -0
- data/lib/chef-cli/policyfile/dsl.rb +288 -0
- data/lib/chef-cli/policyfile/git_lock_fetcher.rb +265 -0
- data/lib/chef-cli/policyfile/included_policies_cookbook_source.rb +156 -0
- data/lib/chef-cli/policyfile/lister.rb +229 -0
- data/lib/chef-cli/policyfile/local_lock_fetcher.rb +132 -0
- data/lib/chef-cli/policyfile/lock_applier.rb +80 -0
- data/lib/chef-cli/policyfile/lock_fetcher_mixin.rb +37 -0
- data/lib/chef-cli/policyfile/null_cookbook_source.rb +49 -0
- data/lib/chef-cli/policyfile/policyfile_location_specification.rb +128 -0
- data/lib/chef-cli/policyfile/read_cookbook_for_compat_mode_upload.rb +124 -0
- data/lib/chef-cli/policyfile/remote_lock_fetcher.rb +108 -0
- data/lib/chef-cli/policyfile/reports/install.rb +69 -0
- data/lib/chef-cli/policyfile/reports/table_printer.rb +57 -0
- data/lib/chef-cli/policyfile/reports/upload.rb +70 -0
- data/lib/chef-cli/policyfile/solution_dependencies.rb +311 -0
- data/lib/chef-cli/policyfile/source_uri.rb +57 -0
- data/lib/chef-cli/policyfile/storage_config.rb +112 -0
- data/lib/chef-cli/policyfile/undo_record.rb +139 -0
- data/lib/chef-cli/policyfile/undo_stack.rb +128 -0
- data/lib/chef-cli/policyfile/uploader.rb +222 -0
- data/lib/chef-cli/policyfile_compiler.rb +528 -0
- data/lib/chef-cli/policyfile_lock.rb +581 -0
- data/lib/chef-cli/policyfile_services/clean_policies.rb +95 -0
- data/lib/chef-cli/policyfile_services/clean_policy_cookbooks.rb +123 -0
- data/lib/chef-cli/policyfile_services/export_repo.rb +419 -0
- data/lib/chef-cli/policyfile_services/install.rb +167 -0
- data/lib/chef-cli/policyfile_services/push.rb +112 -0
- data/lib/chef-cli/policyfile_services/push_archive.rb +164 -0
- data/lib/chef-cli/policyfile_services/rm_policy.rb +141 -0
- data/lib/chef-cli/policyfile_services/rm_policy_group.rb +85 -0
- data/lib/chef-cli/policyfile_services/show_policy.rb +234 -0
- data/lib/chef-cli/policyfile_services/undelete.rb +108 -0
- data/lib/chef-cli/policyfile_services/update_attributes.rb +110 -0
- data/lib/chef-cli/service_exception_inspectors.rb +24 -0
- data/lib/chef-cli/service_exception_inspectors/base.rb +39 -0
- data/lib/chef-cli/service_exception_inspectors/http.rb +119 -0
- data/lib/chef-cli/service_exceptions.rb +142 -0
- data/lib/chef-cli/shell_out.rb +36 -0
- data/lib/chef-cli/skeletons/code_generator/files/default/Berksfile +3 -0
- data/lib/chef-cli/skeletons/code_generator/files/default/build_cookbook/README.md +146 -0
- data/lib/chef-cli/skeletons/code_generator/files/default/build_cookbook/kitchen.yml +21 -0
- data/lib/chef-cli/skeletons/code_generator/files/default/build_cookbook/test-fixture-recipe.rb +8 -0
- data/lib/chef-cli/skeletons/code_generator/files/default/chefignore +110 -0
- data/lib/chef-cli/skeletons/code_generator/files/default/cookbook_readmes/README-policy.md +9 -0
- data/lib/chef-cli/skeletons/code_generator/files/default/cookbook_readmes/README.md +66 -0
- data/lib/chef-cli/skeletons/code_generator/files/default/delivery-config.json +17 -0
- data/lib/chef-cli/skeletons/code_generator/files/default/delivery-project.toml +34 -0
- data/lib/chef-cli/skeletons/code_generator/files/default/gitignore +22 -0
- data/lib/chef-cli/skeletons/code_generator/files/default/repo/README.md +20 -0
- data/lib/chef-cli/skeletons/code_generator/files/default/repo/cookbooks/example/README.md +27 -0
- data/lib/chef-cli/skeletons/code_generator/files/default/repo/cookbooks/example/attributes/default.rb +7 -0
- data/lib/chef-cli/skeletons/code_generator/files/default/repo/cookbooks/example/metadata.rb +6 -0
- data/lib/chef-cli/skeletons/code_generator/files/default/repo/cookbooks/example/recipes/default.rb +8 -0
- data/lib/chef-cli/skeletons/code_generator/files/default/repo/data_bags/README.md +56 -0
- data/lib/chef-cli/skeletons/code_generator/files/default/repo/data_bags/example/example_item.json +4 -0
- data/lib/chef-cli/skeletons/code_generator/files/default/repo/dot-chef-repo.txt +6 -0
- data/lib/chef-cli/skeletons/code_generator/files/default/repo/environments/README.md +9 -0
- data/lib/chef-cli/skeletons/code_generator/files/default/repo/environments/example.json +13 -0
- data/lib/chef-cli/skeletons/code_generator/files/default/repo/policyfiles/README.md +24 -0
- data/lib/chef-cli/skeletons/code_generator/files/default/repo/roles/README.md +9 -0
- data/lib/chef-cli/skeletons/code_generator/files/default/repo/roles/example.json +13 -0
- data/lib/chef-cli/skeletons/code_generator/files/default/spec_helper.rb +2 -0
- data/lib/chef-cli/skeletons/code_generator/files/default/spec_helper_policyfile.rb +2 -0
- data/lib/chef-cli/skeletons/code_generator/metadata.rb +8 -0
- data/lib/chef-cli/skeletons/code_generator/recipes/attribute.rb +11 -0
- data/lib/chef-cli/skeletons/code_generator/recipes/build_cookbook.rb +175 -0
- data/lib/chef-cli/skeletons/code_generator/recipes/cookbook.rb +167 -0
- data/lib/chef-cli/skeletons/code_generator/recipes/cookbook_file.rb +23 -0
- data/lib/chef-cli/skeletons/code_generator/recipes/helpers.rb +19 -0
- data/lib/chef-cli/skeletons/code_generator/recipes/policyfile.rb +7 -0
- data/lib/chef-cli/skeletons/code_generator/recipes/recipe.rb +50 -0
- data/lib/chef-cli/skeletons/code_generator/recipes/repo.rb +71 -0
- data/lib/chef-cli/skeletons/code_generator/recipes/resource.rb +12 -0
- data/lib/chef-cli/skeletons/code_generator/recipes/template.rb +31 -0
- data/lib/chef-cli/skeletons/code_generator/templates/default/CHANGELOG.md.erb +11 -0
- data/lib/chef-cli/skeletons/code_generator/templates/default/LICENSE.all_rights.erb +3 -0
- data/lib/chef-cli/skeletons/code_generator/templates/default/LICENSE.apachev2.erb +201 -0
- data/lib/chef-cli/skeletons/code_generator/templates/default/LICENSE.gplv2.erb +339 -0
- data/lib/chef-cli/skeletons/code_generator/templates/default/LICENSE.gplv3.erb +674 -0
- data/lib/chef-cli/skeletons/code_generator/templates/default/LICENSE.mit.erb +21 -0
- data/lib/chef-cli/skeletons/code_generator/templates/default/Policyfile.rb.erb +25 -0
- data/lib/chef-cli/skeletons/code_generator/templates/default/README.md.erb +4 -0
- data/lib/chef-cli/skeletons/code_generator/templates/default/attribute.rb.erb +0 -0
- data/lib/chef-cli/skeletons/code_generator/templates/default/build_cookbook/Berksfile.erb +7 -0
- data/lib/chef-cli/skeletons/code_generator/templates/default/build_cookbook/metadata.rb.erb +10 -0
- data/lib/chef-cli/skeletons/code_generator/templates/default/build_cookbook/recipe.rb.erb +9 -0
- data/lib/chef-cli/skeletons/code_generator/templates/default/cookbook_file.erb +0 -0
- data/lib/chef-cli/skeletons/code_generator/templates/default/helpers.rb.erb +39 -0
- data/lib/chef-cli/skeletons/code_generator/templates/default/inspec_default_test.rb.erb +16 -0
- data/lib/chef-cli/skeletons/code_generator/templates/default/kitchen.yml.erb +38 -0
- data/lib/chef-cli/skeletons/code_generator/templates/default/kitchen_dokken.yml.erb +36 -0
- data/lib/chef-cli/skeletons/code_generator/templates/default/kitchen_policyfile.yml.erb +32 -0
- data/lib/chef-cli/skeletons/code_generator/templates/default/metadata.rb.erb +20 -0
- data/lib/chef-cli/skeletons/code_generator/templates/default/recipe.rb.erb +5 -0
- data/lib/chef-cli/skeletons/code_generator/templates/default/recipe_spec.rb.erb +29 -0
- data/lib/chef-cli/skeletons/code_generator/templates/default/repo/gitignore.erb +128 -0
- data/lib/chef-cli/skeletons/code_generator/templates/default/resource.rb.erb +1 -0
- data/lib/chef-cli/skeletons/code_generator/templates/default/template.erb +0 -0
- data/lib/chef-cli/ui.rb +57 -0
- data/lib/chef-cli/version.rb +20 -0
- data/lib/kitchen/provisioner/policyfile_zero.rb +195 -0
- data/spec/shared/a_file_generator.rb +125 -0
- data/spec/shared/a_generated_file.rb +12 -0
- data/spec/shared/command_with_ui_object.rb +11 -0
- data/spec/shared/custom_generator_cookbook.rb +136 -0
- data/spec/shared/fixture_cookbook_checksums.rb +46 -0
- data/spec/shared/setup_git_committer_config.rb +54 -0
- data/spec/shared/setup_git_cookbooks.rb +53 -0
- data/spec/spec_helper.rb +51 -0
- data/spec/test_helpers.rb +84 -0
- data/spec/unit/chef_runner_spec.rb +139 -0
- data/spec/unit/chef_server_api_multi_spec.rb +120 -0
- data/spec/unit/cli_spec.rb +375 -0
- data/spec/unit/command/base_spec.rb +195 -0
- data/spec/unit/command/clean_policy_cookbooks_spec.rb +180 -0
- data/spec/unit/command/clean_policy_revisions_spec.rb +180 -0
- data/spec/unit/command/delete_policy_group_spec.rb +206 -0
- data/spec/unit/command/delete_policy_spec.rb +206 -0
- data/spec/unit/command/diff_spec.rb +311 -0
- data/spec/unit/command/env_spec.rb +86 -0
- data/spec/unit/command/exec_spec.rb +178 -0
- data/spec/unit/command/export_spec.rb +199 -0
- data/spec/unit/command/generate_spec.rb +142 -0
- data/spec/unit/command/generator_commands/attribute_spec.rb +31 -0
- data/spec/unit/command/generator_commands/base_spec.rb +180 -0
- data/spec/unit/command/generator_commands/build_cookbook_spec.rb +377 -0
- data/spec/unit/command/generator_commands/chef_exts/generator_desc_resource_spec.rb +77 -0
- data/spec/unit/command/generator_commands/chef_exts/recipe_dsl_ext_spec.rb +111 -0
- data/spec/unit/command/generator_commands/cookbook_file_spec.rb +31 -0
- data/spec/unit/command/generator_commands/cookbook_spec.rb +769 -0
- data/spec/unit/command/generator_commands/generator_generator_spec.rb +227 -0
- data/spec/unit/command/generator_commands/helpers_spec.rb +31 -0
- data/spec/unit/command/generator_commands/policyfile_spec.rb +223 -0
- data/spec/unit/command/generator_commands/recipe_spec.rb +37 -0
- data/spec/unit/command/generator_commands/repo_spec.rb +374 -0
- data/spec/unit/command/generator_commands/resource_spec.rb +31 -0
- data/spec/unit/command/generator_commands/template_spec.rb +31 -0
- data/spec/unit/command/install_spec.rb +179 -0
- data/spec/unit/command/push_archive_spec.rb +153 -0
- data/spec/unit/command/push_spec.rb +198 -0
- data/spec/unit/command/shell_init_spec.rb +339 -0
- data/spec/unit/command/show_policy_spec.rb +234 -0
- data/spec/unit/command/undelete_spec.rb +244 -0
- data/spec/unit/command/update_spec.rb +283 -0
- data/spec/unit/command/verify_spec.rb +341 -0
- data/spec/unit/commands_map_spec.rb +57 -0
- data/spec/unit/component_test_spec.rb +128 -0
- data/spec/unit/configurable_spec.rb +68 -0
- data/spec/unit/cookbook_metadata_spec.rb +96 -0
- data/spec/unit/cookbook_profiler/git_spec.rb +176 -0
- data/spec/unit/cookbook_profiler/identifiers_spec.rb +81 -0
- data/spec/unit/fixtures/chef-runner-cookbooks/test_cookbook/recipes/recipe_one.rb +9 -0
- data/spec/unit/fixtures/chef-runner-cookbooks/test_cookbook/recipes/recipe_two.rb +9 -0
- data/spec/unit/fixtures/command/cli_test_command.rb +26 -0
- data/spec/unit/fixtures/command/explicit_path_example.rb +7 -0
- data/spec/unit/fixtures/configurable/test_config_loader.rb +5 -0
- data/spec/unit/fixtures/configurable/test_configurable.rb +10 -0
- data/spec/unit/fixtures/cookbook_cache/baz-f59ee7a5bca6a4e606b67f7f856b768d847c39bb/.kitchen.yml +16 -0
- data/spec/unit/fixtures/cookbook_cache/baz-f59ee7a5bca6a4e606b67f7f856b768d847c39bb/Berksfile +3 -0
- data/spec/unit/fixtures/cookbook_cache/baz-f59ee7a5bca6a4e606b67f7f856b768d847c39bb/README.md +4 -0
- data/spec/unit/fixtures/cookbook_cache/baz-f59ee7a5bca6a4e606b67f7f856b768d847c39bb/chefignore +96 -0
- data/spec/unit/fixtures/cookbook_cache/baz-f59ee7a5bca6a4e606b67f7f856b768d847c39bb/metadata.rb +8 -0
- data/spec/unit/fixtures/cookbook_cache/baz-f59ee7a5bca6a4e606b67f7f856b768d847c39bb/recipes/default.rb +8 -0
- data/spec/unit/fixtures/cookbook_cache/dep_of_bar-1.2.3/.kitchen.yml +16 -0
- data/spec/unit/fixtures/cookbook_cache/dep_of_bar-1.2.3/Berksfile +3 -0
- data/spec/unit/fixtures/cookbook_cache/dep_of_bar-1.2.3/README.md +4 -0
- data/spec/unit/fixtures/cookbook_cache/dep_of_bar-1.2.3/chefignore +96 -0
- data/spec/unit/fixtures/cookbook_cache/dep_of_bar-1.2.3/metadata.rb +8 -0
- data/spec/unit/fixtures/cookbook_cache/dep_of_bar-1.2.3/recipes/default.rb +8 -0
- data/spec/unit/fixtures/cookbook_cache/foo-1.0.0/Berksfile +3 -0
- data/spec/unit/fixtures/cookbook_cache/foo-1.0.0/README.md +4 -0
- data/spec/unit/fixtures/cookbook_cache/foo-1.0.0/chefignore +96 -0
- data/spec/unit/fixtures/cookbook_cache/foo-1.0.0/kitchen.yml +16 -0
- data/spec/unit/fixtures/cookbook_cache/foo-1.0.0/metadata.rb +8 -0
- data/spec/unit/fixtures/cookbook_cache/foo-1.0.0/recipes/default.rb +8 -0
- data/spec/unit/fixtures/cookbooks_api/chef_server_universe.json +56 -0
- data/spec/unit/fixtures/cookbooks_api/pruned_chef_server_universe.json +30 -0
- data/spec/unit/fixtures/cookbooks_api/pruned_small_universe.json +1322 -0
- data/spec/unit/fixtures/cookbooks_api/small_universe.json +2987 -0
- data/spec/unit/fixtures/cookbooks_api/universe.json +1 -0
- data/spec/unit/fixtures/cookbooks_api/update_fixtures.rb +33 -0
- data/spec/unit/fixtures/dev_cookbooks/README.md +16 -0
- data/spec/unit/fixtures/dev_cookbooks/bar-cookbook.gitbundle +0 -0
- data/spec/unit/fixtures/eg_omnibus_dir/missing_apps/bin/.keep +0 -0
- data/spec/unit/fixtures/eg_omnibus_dir/missing_apps/embedded/.keep +0 -0
- data/spec/unit/fixtures/eg_omnibus_dir/missing_apps/embedded/bin/.keep +0 -0
- data/spec/unit/fixtures/eg_omnibus_dir/missing_component/bin/.keep +0 -0
- data/spec/unit/fixtures/eg_omnibus_dir/missing_component/embedded/apps/berkshelf/.keep +0 -0
- data/spec/unit/fixtures/eg_omnibus_dir/missing_component/embedded/apps/test-kitchen/.keep +0 -0
- data/spec/unit/fixtures/eg_omnibus_dir/missing_component/embedded/bin/.keep +0 -0
- data/spec/unit/fixtures/eg_omnibus_dir/valid/bin/.keep +0 -0
- data/spec/unit/fixtures/eg_omnibus_dir/valid/embedded/apps/berkshelf/integration_test +2 -0
- data/spec/unit/fixtures/eg_omnibus_dir/valid/embedded/apps/berkshelf/verify_me +5 -0
- data/spec/unit/fixtures/eg_omnibus_dir/valid/embedded/apps/chef-dk/.keep +0 -0
- data/spec/unit/fixtures/eg_omnibus_dir/valid/embedded/apps/chef/verify_me +3 -0
- data/spec/unit/fixtures/eg_omnibus_dir/valid/embedded/apps/test-kitchen/verify_me +2 -0
- data/spec/unit/fixtures/eg_omnibus_dir/valid/embedded/bin/.keep +0 -0
- data/spec/unit/fixtures/example_app/Policyfile.rb +0 -0
- data/spec/unit/fixtures/example_cookbook/.gitignore +17 -0
- data/spec/unit/fixtures/example_cookbook/.kitchen.yml +16 -0
- data/spec/unit/fixtures/example_cookbook/Berksfile +3 -0
- data/spec/unit/fixtures/example_cookbook/README.md +4 -0
- data/spec/unit/fixtures/example_cookbook/chefignore +96 -0
- data/spec/unit/fixtures/example_cookbook/metadata.rb +8 -0
- data/spec/unit/fixtures/example_cookbook/recipes/default.rb +8 -0
- data/spec/unit/fixtures/example_cookbook_metadata_json_only/.gitignore +17 -0
- data/spec/unit/fixtures/example_cookbook_metadata_json_only/.kitchen.yml +16 -0
- data/spec/unit/fixtures/example_cookbook_metadata_json_only/Berksfile +3 -0
- data/spec/unit/fixtures/example_cookbook_metadata_json_only/README.md +4 -0
- data/spec/unit/fixtures/example_cookbook_metadata_json_only/chefignore +96 -0
- data/spec/unit/fixtures/example_cookbook_metadata_json_only/metadata.json +5 -0
- data/spec/unit/fixtures/example_cookbook_metadata_json_only/recipes/default.rb +8 -0
- data/spec/unit/fixtures/example_cookbook_no_metadata/.gitignore +17 -0
- data/spec/unit/fixtures/example_cookbook_no_metadata/.kitchen.yml +16 -0
- data/spec/unit/fixtures/example_cookbook_no_metadata/Berksfile +3 -0
- data/spec/unit/fixtures/example_cookbook_no_metadata/README.md +4 -0
- data/spec/unit/fixtures/example_cookbook_no_metadata/chefignore +96 -0
- data/spec/unit/fixtures/example_cookbook_no_metadata/recipes/default.rb +8 -0
- data/spec/unit/fixtures/local_path_cookbooks/another-local-cookbook/README.md +4 -0
- data/spec/unit/fixtures/local_path_cookbooks/another-local-cookbook/chefignore +96 -0
- data/spec/unit/fixtures/local_path_cookbooks/another-local-cookbook/metadata.rb +8 -0
- data/spec/unit/fixtures/local_path_cookbooks/another-local-cookbook/recipes/default.rb +8 -0
- data/spec/unit/fixtures/local_path_cookbooks/cookbook-with-a-dep/Berksfile +3 -0
- data/spec/unit/fixtures/local_path_cookbooks/cookbook-with-a-dep/README.md +4 -0
- data/spec/unit/fixtures/local_path_cookbooks/cookbook-with-a-dep/chefignore +96 -0
- data/spec/unit/fixtures/local_path_cookbooks/cookbook-with-a-dep/metadata.rb +9 -0
- data/spec/unit/fixtures/local_path_cookbooks/cookbook-with-a-dep/recipes/default.rb +8 -0
- data/spec/unit/fixtures/local_path_cookbooks/local-cookbook/.kitchen.yml +16 -0
- data/spec/unit/fixtures/local_path_cookbooks/local-cookbook/Berksfile +3 -0
- data/spec/unit/fixtures/local_path_cookbooks/local-cookbook/README.md +4 -0
- data/spec/unit/fixtures/local_path_cookbooks/local-cookbook/chefignore +96 -0
- data/spec/unit/fixtures/local_path_cookbooks/local-cookbook/extra/extra_file.txt +0 -0
- data/spec/unit/fixtures/local_path_cookbooks/local-cookbook/metadata.rb +8 -0
- data/spec/unit/fixtures/local_path_cookbooks/local-cookbook/recipes/default.rb +8 -0
- data/spec/unit/fixtures/local_path_cookbooks/metadata-missing/README.md +2 -0
- data/spec/unit/fixtures/local_path_cookbooks/noignore-f59ee7a5bca6a4e606b67f7f856b768d847c39bb/.kitchen.yml +16 -0
- data/spec/unit/fixtures/local_path_cookbooks/noignore-f59ee7a5bca6a4e606b67f7f856b768d847c39bb/README.md +4 -0
- data/spec/unit/fixtures/local_path_cookbooks/noignore-f59ee7a5bca6a4e606b67f7f856b768d847c39bb/metadata.rb +8 -0
- data/spec/unit/fixtures/local_path_cookbooks/noignore-f59ee7a5bca6a4e606b67f7f856b768d847c39bb/recipes/default.rb +8 -0
- data/spec/unit/generator_spec.rb +119 -0
- data/spec/unit/pager_spec.rb +117 -0
- data/spec/unit/policyfile/artifactory_cookbook_source_spec.rb +59 -0
- data/spec/unit/policyfile/attribute_merge_checker_spec.rb +80 -0
- data/spec/unit/policyfile/chef_repo_cookbook_source_spec.rb +93 -0
- data/spec/unit/policyfile/chef_server_cookbook_source_spec.rb +55 -0
- data/spec/unit/policyfile/chef_server_lock_fetcher_spec.rb +161 -0
- data/spec/unit/policyfile/community_cookbook_source_spec.rb +83 -0
- data/spec/unit/policyfile/comparison_base_spec.rb +340 -0
- data/spec/unit/policyfile/cookbook_location_specification_spec.rb +347 -0
- data/spec/unit/policyfile/cookbook_locks_spec.rb +527 -0
- data/spec/unit/policyfile/delivery_supermarket_source_spec.rb +129 -0
- data/spec/unit/policyfile/differ_spec.rb +686 -0
- data/spec/unit/policyfile/git_lock_fetcher_spec.rb +155 -0
- data/spec/unit/policyfile/included_policies_cookbook_source_spec.rb +242 -0
- data/spec/unit/policyfile/lister_spec.rb +268 -0
- data/spec/unit/policyfile/local_lock_fetcher_spec.rb +199 -0
- data/spec/unit/policyfile/lock_applier_spec.rb +100 -0
- data/spec/unit/policyfile/lock_fetcher_mixin_spec.rb +60 -0
- data/spec/unit/policyfile/null_cookbook_source_spec.rb +34 -0
- data/spec/unit/policyfile/read_cookbook_for_compat_mode_upload_spec.rb +92 -0
- data/spec/unit/policyfile/remote_lock_fetcher_spec.rb +129 -0
- data/spec/unit/policyfile/reports/install_spec.rb +114 -0
- data/spec/unit/policyfile/reports/upload_spec.rb +94 -0
- data/spec/unit/policyfile/solution_dependencies_spec.rb +170 -0
- data/spec/unit/policyfile/source_uri_spec.rb +36 -0
- data/spec/unit/policyfile/storage_config_spec.rb +180 -0
- data/spec/unit/policyfile/undo_record_spec.rb +258 -0
- data/spec/unit/policyfile/undo_stack_spec.rb +265 -0
- data/spec/unit/policyfile/uploader_spec.rb +410 -0
- data/spec/unit/policyfile_demands_spec.rb +1197 -0
- data/spec/unit/policyfile_evaluation_spec.rb +628 -0
- data/spec/unit/policyfile_includes_dsl_spec.rb +220 -0
- data/spec/unit/policyfile_includes_spec.rb +720 -0
- data/spec/unit/policyfile_install_with_includes_spec.rb +232 -0
- data/spec/unit/policyfile_lock_build_spec.rb +1065 -0
- data/spec/unit/policyfile_lock_install_spec.rb +137 -0
- data/spec/unit/policyfile_lock_serialization_spec.rb +424 -0
- data/spec/unit/policyfile_lock_validation_spec.rb +608 -0
- data/spec/unit/policyfile_services/clean_policies_spec.rb +236 -0
- data/spec/unit/policyfile_services/clean_policy_cookbooks_spec.rb +272 -0
- data/spec/unit/policyfile_services/export_repo_spec.rb +473 -0
- data/spec/unit/policyfile_services/install_spec.rb +209 -0
- data/spec/unit/policyfile_services/push_archive_spec.rb +359 -0
- data/spec/unit/policyfile_services/push_spec.rb +249 -0
- data/spec/unit/policyfile_services/rm_policy_group_spec.rb +237 -0
- data/spec/unit/policyfile_services/rm_policy_spec.rb +263 -0
- data/spec/unit/policyfile_services/show_policy_spec.rb +887 -0
- data/spec/unit/policyfile_services/undelete_spec.rb +302 -0
- data/spec/unit/policyfile_services/update_attributes_spec.rb +229 -0
- data/spec/unit/policyfile_services/update_spec.rb +162 -0
- data/spec/unit/service_exception_inspectors/base_spec.rb +41 -0
- data/spec/unit/service_exception_inspectors/http_spec.rb +138 -0
- data/spec/unit/shell_out_spec.rb +34 -0
- metadata +796 -0
|
@@ -0,0 +1,93 @@
|
|
|
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 "spec_helper"
|
|
19
|
+
require "chef-cli/policyfile/chef_repo_cookbook_source"
|
|
20
|
+
|
|
21
|
+
describe ChefCLI::Policyfile::ChefRepoCookbookSource do
|
|
22
|
+
|
|
23
|
+
let(:repo_path) do
|
|
24
|
+
File.expand_path("spec/unit/fixtures/local_path_cookbooks", project_root)
|
|
25
|
+
end
|
|
26
|
+
|
|
27
|
+
let(:cookbook_source) { ChefCLI::Policyfile::ChefRepoCookbookSource.new(repo_path) }
|
|
28
|
+
|
|
29
|
+
let(:local_repo_universe) do
|
|
30
|
+
{
|
|
31
|
+
"another-local-cookbook" => {
|
|
32
|
+
"0.1.0" => [],
|
|
33
|
+
},
|
|
34
|
+
"local-cookbook" => {
|
|
35
|
+
"2.3.4" => [],
|
|
36
|
+
},
|
|
37
|
+
"cookbook-with-a-dep" => {
|
|
38
|
+
"9.9.9" => [["another-local-cookbook", "~> 0.1"]],
|
|
39
|
+
},
|
|
40
|
+
"noignore" => {
|
|
41
|
+
"0.1.0" => [],
|
|
42
|
+
},
|
|
43
|
+
}
|
|
44
|
+
end
|
|
45
|
+
|
|
46
|
+
it "gives the set of arguments to `default_source` used to create it" do
|
|
47
|
+
expect(cookbook_source.default_source_args).to eq([:chef_repo, repo_path])
|
|
48
|
+
end
|
|
49
|
+
|
|
50
|
+
it "fetches the universe graph" do
|
|
51
|
+
actual_universe = cookbook_source.universe_graph
|
|
52
|
+
expect(actual_universe).to eql(local_repo_universe)
|
|
53
|
+
end
|
|
54
|
+
|
|
55
|
+
it "generates location options for a cookbook from the given graph" do
|
|
56
|
+
expected_opts = { path: File.join(repo_path, "local-cookbook"), version: "2.3.4" }
|
|
57
|
+
expect(cookbook_source.source_options_for("local-cookbook", "2.3.4")).to eq(expected_opts)
|
|
58
|
+
end
|
|
59
|
+
|
|
60
|
+
it "will append a cookbooks directory to the path if it finds it" do
|
|
61
|
+
expect(Dir).to receive(:exist?).with("#{repo_path}/cookbooks").and_return(true)
|
|
62
|
+
expect(cookbook_source.path).to eql("#{repo_path}/cookbooks")
|
|
63
|
+
end
|
|
64
|
+
|
|
65
|
+
it "the private setter will append a cookbooks directory to the path if finds it" do
|
|
66
|
+
expect(cookbook_source.path).to eql(repo_path)
|
|
67
|
+
expect(Dir).to receive(:exist?).with("#{repo_path}/cookbooks").and_return(true)
|
|
68
|
+
cookbook_source.send(:path=, repo_path)
|
|
69
|
+
expect(cookbook_source.path).to eql("#{repo_path}/cookbooks")
|
|
70
|
+
end
|
|
71
|
+
|
|
72
|
+
context "when created with a block to set source preferences" do
|
|
73
|
+
|
|
74
|
+
subject(:cookbook_source) do
|
|
75
|
+
described_class.new(repo_path) do |s|
|
|
76
|
+
s.preferred_for "foo", "bar", "baz"
|
|
77
|
+
end
|
|
78
|
+
end
|
|
79
|
+
|
|
80
|
+
it "sets the source preferences as given" do
|
|
81
|
+
expect(cookbook_source.preferred_cookbooks).to eq( %w{ foo bar baz } )
|
|
82
|
+
end
|
|
83
|
+
|
|
84
|
+
it "is the preferred source for the requested cookbooks" do
|
|
85
|
+
expect(cookbook_source.preferred_source_for?("foo")).to be(true)
|
|
86
|
+
expect(cookbook_source.preferred_source_for?("bar")).to be(true)
|
|
87
|
+
expect(cookbook_source.preferred_source_for?("baz")).to be(true)
|
|
88
|
+
expect(cookbook_source.preferred_source_for?("razzledazzle")).to be(false)
|
|
89
|
+
end
|
|
90
|
+
|
|
91
|
+
end
|
|
92
|
+
|
|
93
|
+
end
|
|
@@ -0,0 +1,55 @@
|
|
|
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 "spec_helper"
|
|
19
|
+
require "chef-cli/policyfile/chef_server_cookbook_source"
|
|
20
|
+
|
|
21
|
+
describe ChefCLI::Policyfile::ChefServerCookbookSource do
|
|
22
|
+
subject { described_class.new(cookbook_source) }
|
|
23
|
+
|
|
24
|
+
let(:cookbook_source) { "https://chef.example.com/organizations/example" }
|
|
25
|
+
|
|
26
|
+
let(:http_connection) { double("Chef::ServerAPI") }
|
|
27
|
+
|
|
28
|
+
let(:universe_response_encoded) { JSON.parse(IO.read(File.join(fixtures_path, "cookbooks_api/chef_server_universe.json"))) }
|
|
29
|
+
|
|
30
|
+
let(:pruned_universe) { JSON.parse(IO.read(File.join(fixtures_path, "cookbooks_api/pruned_chef_server_universe.json"))) }
|
|
31
|
+
|
|
32
|
+
describe "fetching the Universe graph" do
|
|
33
|
+
|
|
34
|
+
before do
|
|
35
|
+
expect(subject).to receive(:http_connection_for).with(cookbook_source).and_return(http_connection)
|
|
36
|
+
end
|
|
37
|
+
|
|
38
|
+
it "fetches the universe graph" do
|
|
39
|
+
expect(http_connection).to receive(:get).with("/universe").and_return(universe_response_encoded)
|
|
40
|
+
actual_universe = subject.universe_graph
|
|
41
|
+
expect(actual_universe).to have_key("apt")
|
|
42
|
+
expect(actual_universe["apt"]).to eq(pruned_universe["apt"])
|
|
43
|
+
expect(subject.universe_graph).to eq(pruned_universe)
|
|
44
|
+
end
|
|
45
|
+
|
|
46
|
+
it "generates location options for a cookbook from the given graph" do
|
|
47
|
+
expected_opts = {
|
|
48
|
+
chef_server: "https://chef.example.com/organizations/example",
|
|
49
|
+
http_client: http_connection,
|
|
50
|
+
version: "4.2.3",
|
|
51
|
+
}
|
|
52
|
+
expect(subject.source_options_for("ohai", "4.2.3")).to eq(expected_opts)
|
|
53
|
+
end
|
|
54
|
+
end
|
|
55
|
+
end
|
|
@@ -0,0 +1,161 @@
|
|
|
1
|
+
#
|
|
2
|
+
# Copyright:: Copyright (c) 2017 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 "spec_helper"
|
|
19
|
+
require "chef-cli/policyfile/chef_server_lock_fetcher"
|
|
20
|
+
|
|
21
|
+
describe ChefCLI::Policyfile::ChefServerLockFetcher do
|
|
22
|
+
|
|
23
|
+
let(:revision_id) { "6fe753184c8946052d3231bb4212116df28d89a3a5f7ae52832ad408419dd5eb" }
|
|
24
|
+
let(:identifier) { "fab501cfaf747901bd82c1bc706beae7dc3a350c" }
|
|
25
|
+
let(:minimal_lockfile_json) do
|
|
26
|
+
<<~E
|
|
27
|
+
{
|
|
28
|
+
"revision_id": "#{revision_id}",
|
|
29
|
+
"name": "install-example",
|
|
30
|
+
"run_list": [
|
|
31
|
+
"recipe[local-cookbook::default]"
|
|
32
|
+
],
|
|
33
|
+
"cookbook_locks": {
|
|
34
|
+
"local-cookbook": {
|
|
35
|
+
"version": "2.3.4",
|
|
36
|
+
"identifier": "#{identifier}",
|
|
37
|
+
"dotted_decimal_identifier": "70567763561641081.489844270461035.258281553147148",
|
|
38
|
+
"source": "cookbooks/local-cookbook",
|
|
39
|
+
"cache_key": null,
|
|
40
|
+
"scm_info": null,
|
|
41
|
+
"source_options": {
|
|
42
|
+
"path": "cookbooks/local-cookbook"
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
},
|
|
46
|
+
"default_attributes": {},
|
|
47
|
+
"override_attributes": {},
|
|
48
|
+
"solution_dependencies": {
|
|
49
|
+
"Policyfile": [
|
|
50
|
+
[
|
|
51
|
+
"local-cookbook",
|
|
52
|
+
">= 0.0.0"
|
|
53
|
+
]
|
|
54
|
+
],
|
|
55
|
+
"dependencies": {
|
|
56
|
+
"local-cookbook (2.3.4)": [
|
|
57
|
+
|
|
58
|
+
]
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
E
|
|
63
|
+
end
|
|
64
|
+
|
|
65
|
+
def minimal_lockfile
|
|
66
|
+
FFI_Yajl::Parser.parse(minimal_lockfile_json)
|
|
67
|
+
end
|
|
68
|
+
|
|
69
|
+
let(:policy_name) { "chatserver" }
|
|
70
|
+
let(:policy_revision_id) { "somerevisionid" }
|
|
71
|
+
let(:policy_group) { "somegroup" }
|
|
72
|
+
let(:url) { "https://chef.example/organizations/monkeynews" }
|
|
73
|
+
|
|
74
|
+
let(:chef_config) do
|
|
75
|
+
double("ChefConfig").tap do |double|
|
|
76
|
+
allow(double).to receive(:client_key).and_return("key")
|
|
77
|
+
allow(double).to receive(:node_name).and_return("node_name")
|
|
78
|
+
end
|
|
79
|
+
end
|
|
80
|
+
let(:http_client) { instance_double("Chef::ServerAPI", url: url ) }
|
|
81
|
+
|
|
82
|
+
let(:minimal_lockfile_modified) do
|
|
83
|
+
minimal_lockfile.tap do |lockfile|
|
|
84
|
+
lockfile["cookbook_locks"]["local-cookbook"]["source_options"] = {
|
|
85
|
+
"chef_server_artifact" => url,
|
|
86
|
+
"identifier" => identifier,
|
|
87
|
+
}
|
|
88
|
+
end
|
|
89
|
+
end
|
|
90
|
+
|
|
91
|
+
subject(:fetcher) { described_class.new(policy_name, source_options, chef_config) }
|
|
92
|
+
|
|
93
|
+
before do
|
|
94
|
+
allow(Chef::ServerAPI).to receive(:new).with(url, anything).and_return(http_client)
|
|
95
|
+
end
|
|
96
|
+
|
|
97
|
+
context "when using revision id" do
|
|
98
|
+
let(:source_options) do
|
|
99
|
+
{
|
|
100
|
+
server: url,
|
|
101
|
+
policy_name: policy_name,
|
|
102
|
+
policy_revision_id: policy_revision_id,
|
|
103
|
+
}
|
|
104
|
+
end
|
|
105
|
+
|
|
106
|
+
it "calls the chef server to get the policy" do
|
|
107
|
+
expect(http_client).to receive(:get).with("policies/#{policy_name}/revisions/#{policy_revision_id}")
|
|
108
|
+
.and_return(minimal_lockfile)
|
|
109
|
+
expect(fetcher.lock_data).to eq(minimal_lockfile_modified)
|
|
110
|
+
end
|
|
111
|
+
|
|
112
|
+
context "and policy_name is not provided" do
|
|
113
|
+
let(:source_options) do
|
|
114
|
+
{
|
|
115
|
+
server: url,
|
|
116
|
+
policy_revision_id: policy_revision_id,
|
|
117
|
+
}
|
|
118
|
+
end
|
|
119
|
+
|
|
120
|
+
it "calls the chef server to get the policy with the dsl name" do
|
|
121
|
+
expect(http_client).to receive(:get).with("policies/#{policy_name}/revisions/#{policy_revision_id}")
|
|
122
|
+
.and_return(minimal_lockfile)
|
|
123
|
+
expect(fetcher.lock_data).to eq(minimal_lockfile_modified)
|
|
124
|
+
end
|
|
125
|
+
end
|
|
126
|
+
end
|
|
127
|
+
|
|
128
|
+
context "when using policy group" do
|
|
129
|
+
let(:source_options) do
|
|
130
|
+
{
|
|
131
|
+
server: url,
|
|
132
|
+
policy_name: policy_name,
|
|
133
|
+
policy_group: policy_group,
|
|
134
|
+
}
|
|
135
|
+
end
|
|
136
|
+
|
|
137
|
+
let(:source_options_for_lock) do
|
|
138
|
+
source_options.merge({ policy_revision_id: revision_id })
|
|
139
|
+
end
|
|
140
|
+
|
|
141
|
+
it "calls the chef server to get the policy" do
|
|
142
|
+
expect(http_client).to receive(:get).with("policy_groups/#{policy_group}/policies/#{policy_name}")
|
|
143
|
+
.and_return(minimal_lockfile)
|
|
144
|
+
expect(fetcher.lock_data).to eq(minimal_lockfile_modified)
|
|
145
|
+
end
|
|
146
|
+
|
|
147
|
+
it "includes the revision id in the source_options_for_lock" do
|
|
148
|
+
allow(http_client).to receive(:get).with(
|
|
149
|
+
"policy_groups/#{policy_group}/policies/#{policy_name}").and_return(minimal_lockfile)
|
|
150
|
+
|
|
151
|
+
expect(fetcher.source_options_for_lock).to eq(source_options_for_lock)
|
|
152
|
+
end
|
|
153
|
+
|
|
154
|
+
it "correctly applies source_options that were included in the lock" do
|
|
155
|
+
fetcher.apply_locked_source_options(source_options_for_lock)
|
|
156
|
+
expect(http_client).to receive(:get).with(
|
|
157
|
+
"policies/#{policy_name}/revisions/#{revision_id}").and_return(minimal_lockfile)
|
|
158
|
+
fetcher.lock_data
|
|
159
|
+
end
|
|
160
|
+
end
|
|
161
|
+
end
|
|
@@ -0,0 +1,83 @@
|
|
|
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 "spec_helper"
|
|
19
|
+
require "chef-cli/policyfile/community_cookbook_source"
|
|
20
|
+
|
|
21
|
+
describe ChefCLI::Policyfile::CommunityCookbookSource do
|
|
22
|
+
|
|
23
|
+
subject(:cookbook_source) { ChefCLI::Policyfile::CommunityCookbookSource.new }
|
|
24
|
+
|
|
25
|
+
let(:default_community_uri) { "https://supermarket.chef.io" }
|
|
26
|
+
|
|
27
|
+
let(:http_connection) { double("Chef::HTTP::Simple") }
|
|
28
|
+
|
|
29
|
+
let(:universe_response_encoded) { IO.read(File.join(fixtures_path, "cookbooks_api/small_universe.json")) }
|
|
30
|
+
|
|
31
|
+
let(:pruned_universe) { JSON.parse(IO.read(File.join(fixtures_path, "cookbooks_api/pruned_small_universe.json"))) }
|
|
32
|
+
|
|
33
|
+
it "defaults to using the public supermarket over HTTPS" do
|
|
34
|
+
expect(cookbook_source.uri).to eq(default_community_uri)
|
|
35
|
+
end
|
|
36
|
+
|
|
37
|
+
it "gives the set of arguments to `default_source` used to create it" do
|
|
38
|
+
expect(cookbook_source.default_source_args).to eq([:supermarket, default_community_uri])
|
|
39
|
+
end
|
|
40
|
+
|
|
41
|
+
describe "fetching the Universe graph over HTTP" do
|
|
42
|
+
|
|
43
|
+
before do
|
|
44
|
+
expect(Chef::HTTP::Simple).to receive(:new).with(default_community_uri).and_return(http_connection)
|
|
45
|
+
expect(http_connection).to receive(:get).with("/universe").and_return(universe_response_encoded)
|
|
46
|
+
end
|
|
47
|
+
|
|
48
|
+
it "fetches the universe graph" do
|
|
49
|
+
actual_universe = cookbook_source.universe_graph
|
|
50
|
+
expect(actual_universe).to have_key("apt")
|
|
51
|
+
expect(actual_universe["apt"]).to eq(pruned_universe["apt"])
|
|
52
|
+
expect(cookbook_source.universe_graph).to eq(pruned_universe)
|
|
53
|
+
end
|
|
54
|
+
|
|
55
|
+
it "generates location options for a cookbook from the given graph" do
|
|
56
|
+
expected_opts = { artifactserver: "https://supermarket.chef.io/api/v1/cookbooks/apache2/versions/1.10.4/download", version: "1.10.4" }
|
|
57
|
+
expect(cookbook_source.source_options_for("apache2", "1.10.4")).to eq(expected_opts)
|
|
58
|
+
end
|
|
59
|
+
|
|
60
|
+
end
|
|
61
|
+
|
|
62
|
+
context "when created with a block to set source preferences" do
|
|
63
|
+
|
|
64
|
+
subject(:cookbook_source) do
|
|
65
|
+
ChefCLI::Policyfile::CommunityCookbookSource.new do |s|
|
|
66
|
+
s.preferred_for "foo", "bar", "baz"
|
|
67
|
+
end
|
|
68
|
+
end
|
|
69
|
+
|
|
70
|
+
it "sets the source preferences as given" do
|
|
71
|
+
expect(cookbook_source.preferred_cookbooks).to eq( %w{ foo bar baz } )
|
|
72
|
+
end
|
|
73
|
+
|
|
74
|
+
it "is the preferred source for the requested cookbooks" do
|
|
75
|
+
expect(cookbook_source.preferred_source_for?("foo")).to be(true)
|
|
76
|
+
expect(cookbook_source.preferred_source_for?("bar")).to be(true)
|
|
77
|
+
expect(cookbook_source.preferred_source_for?("baz")).to be(true)
|
|
78
|
+
expect(cookbook_source.preferred_source_for?("razzledazzle")).to be(false)
|
|
79
|
+
end
|
|
80
|
+
|
|
81
|
+
end
|
|
82
|
+
|
|
83
|
+
end
|
|
@@ -0,0 +1,340 @@
|
|
|
1
|
+
#
|
|
2
|
+
# Copyright:: Copyright (c) 2015 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 "spec_helper"
|
|
19
|
+
require "chef-cli/policyfile/comparison_base"
|
|
20
|
+
|
|
21
|
+
describe "Policyfile Comparison Bases" do
|
|
22
|
+
|
|
23
|
+
let(:minimal_lockfile_json) do
|
|
24
|
+
<<~E
|
|
25
|
+
{
|
|
26
|
+
"revision_id": "6fe753184c8946052d3231bb4212116df28d89a3a5f7ae52832ad408419dd5eb",
|
|
27
|
+
"name": "install-example",
|
|
28
|
+
"run_list": [
|
|
29
|
+
"recipe[local-cookbook::default]"
|
|
30
|
+
],
|
|
31
|
+
"cookbook_locks": {
|
|
32
|
+
"local-cookbook": {
|
|
33
|
+
"version": "2.3.4",
|
|
34
|
+
"identifier": "fab501cfaf747901bd82c1bc706beae7dc3a350c",
|
|
35
|
+
"dotted_decimal_identifier": "70567763561641081.489844270461035.258281553147148",
|
|
36
|
+
"source": "cookbooks/local-cookbook",
|
|
37
|
+
"cache_key": null,
|
|
38
|
+
"scm_info": null,
|
|
39
|
+
"source_options": {
|
|
40
|
+
"path": "cookbooks/local-cookbook"
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
},
|
|
44
|
+
"default_attributes": {},
|
|
45
|
+
"override_attributes": {},
|
|
46
|
+
"solution_dependencies": {
|
|
47
|
+
"Policyfile": [
|
|
48
|
+
[
|
|
49
|
+
"local-cookbook",
|
|
50
|
+
">= 0.0.0"
|
|
51
|
+
]
|
|
52
|
+
],
|
|
53
|
+
"dependencies": {
|
|
54
|
+
"local-cookbook (2.3.4)": [
|
|
55
|
+
|
|
56
|
+
]
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
E
|
|
61
|
+
end
|
|
62
|
+
|
|
63
|
+
let(:minimal_lockfile) { FFI_Yajl::Parser.parse(minimal_lockfile_json) }
|
|
64
|
+
|
|
65
|
+
describe ChefCLI::Policyfile::ComparisonBase::Local do
|
|
66
|
+
|
|
67
|
+
let(:policyfile_lock_relpath) { "Policyfile.lock.json" }
|
|
68
|
+
|
|
69
|
+
subject(:comparison_base) { described_class.new(policyfile_lock_relpath) }
|
|
70
|
+
|
|
71
|
+
before do
|
|
72
|
+
reset_tempdir
|
|
73
|
+
end
|
|
74
|
+
|
|
75
|
+
after do
|
|
76
|
+
reset_tempdir
|
|
77
|
+
end
|
|
78
|
+
|
|
79
|
+
it "has the lockfile relative path" do
|
|
80
|
+
expect(comparison_base.policyfile_lock_relpath).to eq(policyfile_lock_relpath)
|
|
81
|
+
end
|
|
82
|
+
|
|
83
|
+
it "is named local:RELATIVE_PATH" do
|
|
84
|
+
expect(comparison_base.name).to eq("local:#{policyfile_lock_relpath}")
|
|
85
|
+
end
|
|
86
|
+
|
|
87
|
+
context "when the local lock doesn't exist" do
|
|
88
|
+
|
|
89
|
+
it "raises an exception when reading the lockfile" do
|
|
90
|
+
Dir.chdir(tempdir) do
|
|
91
|
+
expect { comparison_base.lock }.to raise_error(ChefCLI::LockfileNotFound)
|
|
92
|
+
end
|
|
93
|
+
end
|
|
94
|
+
|
|
95
|
+
end
|
|
96
|
+
|
|
97
|
+
context "when the local policyfile lock is not readable", :skip_on_windows do
|
|
98
|
+
|
|
99
|
+
before do
|
|
100
|
+
Dir.chdir(tempdir) do
|
|
101
|
+
FileUtils.touch(policyfile_lock_relpath)
|
|
102
|
+
allow(File).to receive(:readable?).with(policyfile_lock_relpath).and_return(false)
|
|
103
|
+
end
|
|
104
|
+
end
|
|
105
|
+
|
|
106
|
+
it "raises an exception" do
|
|
107
|
+
Dir.chdir(tempdir) do
|
|
108
|
+
expect { comparison_base.lock }.to raise_error(ChefCLI::LockfileNotFound)
|
|
109
|
+
end
|
|
110
|
+
end
|
|
111
|
+
|
|
112
|
+
end
|
|
113
|
+
|
|
114
|
+
context "when the local policyfile lock is malformed" do
|
|
115
|
+
|
|
116
|
+
before do
|
|
117
|
+
Dir.chdir(tempdir) do
|
|
118
|
+
File.open(policyfile_lock_relpath, "w+") { |f| f.print("}}}}}}") }
|
|
119
|
+
end
|
|
120
|
+
end
|
|
121
|
+
|
|
122
|
+
it "raises an exception" do
|
|
123
|
+
Dir.chdir(tempdir) do
|
|
124
|
+
expect { comparison_base.lock }.to raise_error(ChefCLI::MalformedLockfile)
|
|
125
|
+
end
|
|
126
|
+
end
|
|
127
|
+
|
|
128
|
+
end
|
|
129
|
+
|
|
130
|
+
context "when the local lock exists and is valid JSON" do
|
|
131
|
+
|
|
132
|
+
before do
|
|
133
|
+
Dir.chdir(tempdir) do
|
|
134
|
+
File.open(policyfile_lock_relpath, "w+") { |f| f.print(minimal_lockfile_json) }
|
|
135
|
+
end
|
|
136
|
+
end
|
|
137
|
+
|
|
138
|
+
it "reads the local lock and parses the JSON" do
|
|
139
|
+
Dir.chdir(tempdir) do
|
|
140
|
+
expect(comparison_base.lock).to eq(minimal_lockfile)
|
|
141
|
+
end
|
|
142
|
+
end
|
|
143
|
+
|
|
144
|
+
end
|
|
145
|
+
|
|
146
|
+
end
|
|
147
|
+
|
|
148
|
+
describe ChefCLI::Policyfile::ComparisonBase::Git do
|
|
149
|
+
|
|
150
|
+
let(:ref) { "master" }
|
|
151
|
+
|
|
152
|
+
let(:policyfile_lock_relpath) { "policies/MyPolicy.lock.json" }
|
|
153
|
+
|
|
154
|
+
subject(:comparison_base) { described_class.new(ref, policyfile_lock_relpath) }
|
|
155
|
+
|
|
156
|
+
it "has the policyfile lock relative path it was created with" do
|
|
157
|
+
expect(comparison_base.policyfile_lock_relpath).to eq(policyfile_lock_relpath)
|
|
158
|
+
end
|
|
159
|
+
|
|
160
|
+
it "has the ref it was created with" do
|
|
161
|
+
expect(comparison_base.ref).to eq(ref)
|
|
162
|
+
end
|
|
163
|
+
|
|
164
|
+
it "is named git:REF" do
|
|
165
|
+
expect(comparison_base.name).to eq("git:master")
|
|
166
|
+
end
|
|
167
|
+
|
|
168
|
+
it "creates a `git show` command for the policyfile lock and ref" do
|
|
169
|
+
expect(comparison_base.git_cmd_string).to eq("git show master:./policies/MyPolicy.lock.json")
|
|
170
|
+
expect(comparison_base.git_cmd.command).to eq("git show master:./policies/MyPolicy.lock.json")
|
|
171
|
+
end
|
|
172
|
+
|
|
173
|
+
context "when the git command fails" do
|
|
174
|
+
|
|
175
|
+
before do
|
|
176
|
+
allow(comparison_base.git_cmd).to receive(:run_command)
|
|
177
|
+
allow(comparison_base.git_cmd).to receive(:error!).and_raise(Mixlib::ShellOut::ShellCommandFailed)
|
|
178
|
+
allow(comparison_base.git_cmd).to receive(:stderr).and_return("fatal: Not a git repository (or any of the parent directories): .git\n")
|
|
179
|
+
end
|
|
180
|
+
|
|
181
|
+
it "raises an exception when reading the lockfile" do
|
|
182
|
+
expect { comparison_base.lock }.to raise_error(ChefCLI::GitError)
|
|
183
|
+
end
|
|
184
|
+
|
|
185
|
+
end
|
|
186
|
+
|
|
187
|
+
context "when the git command succeeds" do
|
|
188
|
+
|
|
189
|
+
before do
|
|
190
|
+
allow(comparison_base.git_cmd).to receive(:run_command)
|
|
191
|
+
allow(comparison_base.git_cmd).to receive(:error!).and_return(nil)
|
|
192
|
+
end
|
|
193
|
+
|
|
194
|
+
context "and the JSON is malformed" do
|
|
195
|
+
|
|
196
|
+
before do
|
|
197
|
+
allow(comparison_base.git_cmd).to receive(:stdout).and_return("}}}}}")
|
|
198
|
+
end
|
|
199
|
+
|
|
200
|
+
it "raises an exception" do
|
|
201
|
+
expect { comparison_base.lock }.to raise_error(ChefCLI::MalformedLockfile)
|
|
202
|
+
end
|
|
203
|
+
|
|
204
|
+
end
|
|
205
|
+
|
|
206
|
+
context "and the JSON is well-formed" do
|
|
207
|
+
|
|
208
|
+
before do
|
|
209
|
+
allow(comparison_base.git_cmd).to receive(:stdout).and_return(minimal_lockfile_json)
|
|
210
|
+
end
|
|
211
|
+
|
|
212
|
+
it "reads the lockfile and parses the JSON" do
|
|
213
|
+
expect(comparison_base.lock).to eq(minimal_lockfile)
|
|
214
|
+
end
|
|
215
|
+
end
|
|
216
|
+
|
|
217
|
+
end
|
|
218
|
+
|
|
219
|
+
end
|
|
220
|
+
|
|
221
|
+
describe ChefCLI::Policyfile::ComparisonBase::PolicyGroup do
|
|
222
|
+
|
|
223
|
+
let(:group) { "acceptance" }
|
|
224
|
+
let(:policy_name) { "chatserver" }
|
|
225
|
+
let(:http_client) { instance_double("Chef::ServerAPI", url: "https://chef.example/organizations/monkeynews") }
|
|
226
|
+
|
|
227
|
+
subject(:comparison_base) { described_class.new(group, policy_name, http_client) }
|
|
228
|
+
|
|
229
|
+
it "has the group it was created with" do
|
|
230
|
+
expect(comparison_base.group).to eq(group)
|
|
231
|
+
end
|
|
232
|
+
|
|
233
|
+
it "has the policy_name it was created with" do
|
|
234
|
+
expect(comparison_base.policy_name).to eq(policy_name)
|
|
235
|
+
end
|
|
236
|
+
|
|
237
|
+
it "has the HTTP client it was created with" do
|
|
238
|
+
expect(comparison_base.http_client).to eq(http_client)
|
|
239
|
+
end
|
|
240
|
+
|
|
241
|
+
it "is named policy_group:GROUP" do
|
|
242
|
+
expect(comparison_base.name).to eq("policy_group:#{group}")
|
|
243
|
+
end
|
|
244
|
+
|
|
245
|
+
context "when there is a non-404 HTTP error fetching the policyfile lock" do
|
|
246
|
+
|
|
247
|
+
let(:response) do
|
|
248
|
+
Net::HTTPResponse.send(:response_class, "500").new("1.0", "500", "Internal Server Error").tap do |r|
|
|
249
|
+
r.instance_variable_set(:@body, "oops")
|
|
250
|
+
end
|
|
251
|
+
end
|
|
252
|
+
|
|
253
|
+
let(:http_exception) do
|
|
254
|
+
begin
|
|
255
|
+
response.error!
|
|
256
|
+
rescue => e
|
|
257
|
+
e
|
|
258
|
+
end
|
|
259
|
+
end
|
|
260
|
+
|
|
261
|
+
before do
|
|
262
|
+
allow(http_client).to receive(:get).and_raise(http_exception)
|
|
263
|
+
end
|
|
264
|
+
|
|
265
|
+
it "raises an exception" do
|
|
266
|
+
exception = nil
|
|
267
|
+
begin
|
|
268
|
+
comparison_base.lock
|
|
269
|
+
rescue => exception
|
|
270
|
+
expect(exception).to be_a_kind_of(ChefCLI::PolicyfileDownloadError)
|
|
271
|
+
expect(exception.message).to eq("HTTP error attempting to fetch Policyfile lock from https://chef.example/organizations/monkeynews")
|
|
272
|
+
expect(exception.cause).to eq(http_exception)
|
|
273
|
+
end
|
|
274
|
+
expect(exception).to_not be_nil
|
|
275
|
+
end
|
|
276
|
+
|
|
277
|
+
end
|
|
278
|
+
|
|
279
|
+
context "when the server returns 404 fetching the policyfile lock" do
|
|
280
|
+
|
|
281
|
+
let(:response) do
|
|
282
|
+
Net::HTTPResponse.send(:response_class, "404").new("1.0", "404", "Not Found").tap do |r|
|
|
283
|
+
r.instance_variable_set(:@body, "nothin' here, chief")
|
|
284
|
+
end
|
|
285
|
+
end
|
|
286
|
+
|
|
287
|
+
let(:http_exception) do
|
|
288
|
+
begin
|
|
289
|
+
response.error!
|
|
290
|
+
rescue => e
|
|
291
|
+
e
|
|
292
|
+
end
|
|
293
|
+
end
|
|
294
|
+
|
|
295
|
+
before do
|
|
296
|
+
allow(http_client).to receive(:get).and_raise(http_exception)
|
|
297
|
+
end
|
|
298
|
+
|
|
299
|
+
it "raises an exception" do
|
|
300
|
+
exception = nil
|
|
301
|
+
begin
|
|
302
|
+
comparison_base.lock
|
|
303
|
+
rescue => exception
|
|
304
|
+
expect(exception).to be_a_kind_of(ChefCLI::PolicyfileDownloadError)
|
|
305
|
+
expect(exception.message).to eq("No Policyfile lock named 'chatserver' found in policy_group 'acceptance' at https://chef.example/organizations/monkeynews")
|
|
306
|
+
expect(exception.cause).to eq(http_exception)
|
|
307
|
+
end
|
|
308
|
+
expect(exception).to_not be_nil
|
|
309
|
+
end
|
|
310
|
+
|
|
311
|
+
end
|
|
312
|
+
|
|
313
|
+
context "when a non-HTTP error occurs fetching the policyfile lock" do
|
|
314
|
+
|
|
315
|
+
before do
|
|
316
|
+
allow(http_client).to receive(:get).and_raise(Errno::ECONNREFUSED)
|
|
317
|
+
end
|
|
318
|
+
|
|
319
|
+
it "raises an exception" do
|
|
320
|
+
expect { comparison_base.lock }.to raise_error(ChefCLI::PolicyfileDownloadError)
|
|
321
|
+
end
|
|
322
|
+
|
|
323
|
+
end
|
|
324
|
+
|
|
325
|
+
context "when the policyfile lock is fetched from the server" do
|
|
326
|
+
|
|
327
|
+
before do
|
|
328
|
+
expect(http_client).to receive(:get)
|
|
329
|
+
.with("policy_groups/acceptance/policies/chatserver")
|
|
330
|
+
.and_return(minimal_lockfile)
|
|
331
|
+
end
|
|
332
|
+
|
|
333
|
+
it "returns the policyfile lock data" do
|
|
334
|
+
expect(comparison_base.lock).to eq(minimal_lockfile)
|
|
335
|
+
end
|
|
336
|
+
|
|
337
|
+
end
|
|
338
|
+
|
|
339
|
+
end
|
|
340
|
+
end
|