chef-dk 2.4.17 → 2.5.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 +5 -5
- data/Gemfile +121 -119
- data/Gemfile.lock +802 -817
- 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 -20
- 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 +126 -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 +151 -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 +150 -150
- data/lib/chef-dk/generator.rb +165 -165
- data/lib/chef-dk/helpers.rb +176 -176
- data/lib/chef-dk/pager.rb +105 -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 +164 -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/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 +123 -122
- 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 +122 -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 +312 -312
- data/lib/chef-dk/policyfile/source_uri.rb +57 -57
- data/lib/chef-dk/policyfile/storage_config.rb +102 -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 +420 -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 +200 -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 +236 -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 +107 -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 +54 -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 +152 -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/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 +22 -22
- 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 +756 -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/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 -161
- 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 +638 -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 +478 -478
- data/spec/unit/policyfile_services/install_spec.rb +209 -209
- data/spec/unit/policyfile_services/push_archive_spec.rb +374 -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 +5 -5
|
@@ -1,629 +1,629 @@
|
|
|
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/command/base"
|
|
19
|
-
require "chef-dk/exceptions"
|
|
20
|
-
require "chef-dk/component_test"
|
|
21
|
-
|
|
22
|
-
module ChefDK
|
|
23
|
-
module Command
|
|
24
|
-
class Verify < ChefDK::Command::Base
|
|
25
|
-
|
|
26
|
-
include ChefDK::Helpers
|
|
27
|
-
|
|
28
|
-
banner "Usage: chef verify [component, ...] [options]"
|
|
29
|
-
|
|
30
|
-
option :omnibus_dir,
|
|
31
|
-
:long => "--omnibus-dir OMNIBUS_DIR",
|
|
32
|
-
:description => "Alternate path to omnibus install (used for testing)"
|
|
33
|
-
|
|
34
|
-
option :unit,
|
|
35
|
-
:long => "--unit",
|
|
36
|
-
:description => "Run bundled app unit tests (only smoke tests run by default)"
|
|
37
|
-
|
|
38
|
-
option :integration,
|
|
39
|
-
:long => "--integration",
|
|
40
|
-
:description => "Run integration tests. Possibly dangerous, for development systems only"
|
|
41
|
-
|
|
42
|
-
option :verbose,
|
|
43
|
-
:long => "--verbose",
|
|
44
|
-
:description => "Display all test output, not just failing tests"
|
|
45
|
-
|
|
46
|
-
class << self
|
|
47
|
-
def add_component(name, _delete_me = nil)
|
|
48
|
-
component = ComponentTest.new(name)
|
|
49
|
-
yield component if block_given? #delete this conditional
|
|
50
|
-
component_map[name] = component
|
|
51
|
-
end
|
|
52
|
-
|
|
53
|
-
def component(name)
|
|
54
|
-
component_map[name]
|
|
55
|
-
end
|
|
56
|
-
|
|
57
|
-
def components
|
|
58
|
-
component_map.values
|
|
59
|
-
end
|
|
60
|
-
|
|
61
|
-
def component_map
|
|
62
|
-
@component_map ||= {}
|
|
63
|
-
end
|
|
64
|
-
end
|
|
65
|
-
|
|
66
|
-
def components
|
|
67
|
-
self.class.components
|
|
68
|
-
end
|
|
69
|
-
|
|
70
|
-
bundle_install_mutex = Mutex.new
|
|
71
|
-
|
|
72
|
-
#
|
|
73
|
-
# Components included in Chef Development kit:
|
|
74
|
-
# :base_dir => Relative path of the component w.r.t. omnibus_apps_dir
|
|
75
|
-
# :gem_base_dir => Takes a gem name instead and uses first gem found
|
|
76
|
-
# :test_cmd => Test command to be launched for the component
|
|
77
|
-
#
|
|
78
|
-
add_component "berkshelf" do |c|
|
|
79
|
-
c.gem_base_dir = "berkshelf"
|
|
80
|
-
# For berks the real command to run is "#{embedded_bin("bundle")} exec thor spec:ci"
|
|
81
|
-
# We can't run it right now since graphviz specs are included in the
|
|
82
|
-
# test suite by default. We will be able to switch to that command when/if
|
|
83
|
-
# Graphviz is added to omnibus.
|
|
84
|
-
c.unit_test do
|
|
85
|
-
bundle_install_mutex.synchronize { sh("#{embedded_bin("bundle")} install") }
|
|
86
|
-
sh("#{embedded_bin("bundle")} exec #{embedded_bin("rspec")} --color --format progress spec/unit --tag ~graphviz")
|
|
87
|
-
end
|
|
88
|
-
c.integration_test do
|
|
89
|
-
bundle_install_mutex.synchronize { sh("#{embedded_bin("bundle")} install") }
|
|
90
|
-
sh("#{embedded_bin("bundle")} exec #{embedded_bin("cucumber")} --color --format progress --tags ~@no_run --tags ~@spawn --tags ~@graphviz --strict")
|
|
91
|
-
end
|
|
92
|
-
|
|
93
|
-
c.smoke_test do
|
|
94
|
-
tmpdir do |cwd|
|
|
95
|
-
FileUtils.touch(File.join(cwd, "Berksfile"))
|
|
96
|
-
sh("#{bin("berks")} install", cwd: cwd)
|
|
97
|
-
end
|
|
98
|
-
end
|
|
99
|
-
end
|
|
100
|
-
|
|
101
|
-
add_component "test-kitchen" do |c|
|
|
102
|
-
c.gem_base_dir = "test-kitchen"
|
|
103
|
-
c.unit_test do
|
|
104
|
-
bundle_install_mutex.synchronize { sh("#{embedded_bin("bundle")} install") }
|
|
105
|
-
sh("#{embedded_bin("bundle")} exec rake unit")
|
|
106
|
-
end
|
|
107
|
-
c.integration_test do
|
|
108
|
-
bundle_install_mutex.synchronize { sh("#{embedded_bin("bundle")} install") }
|
|
109
|
-
sh("#{embedded_bin("bundle")} exec rake features")
|
|
110
|
-
end
|
|
111
|
-
|
|
112
|
-
# NOTE: By default, kitchen tries to be helpful and install a driver
|
|
113
|
-
# gem for you. This causes a race condition when running the tests
|
|
114
|
-
# concurrently, because rubygems breaks when there are partially
|
|
115
|
-
# installed gems in the gem repository. Instructing kitchen to create a
|
|
116
|
-
# gemfile instead avoids the gem installation.
|
|
117
|
-
c.smoke_test { run_in_tmpdir("kitchen init --create-gemfile") }
|
|
118
|
-
end
|
|
119
|
-
|
|
120
|
-
add_component "tk-policyfile-provisioner" do |c|
|
|
121
|
-
|
|
122
|
-
c.gem_base_dir = "chef-dk"
|
|
123
|
-
|
|
124
|
-
c.smoke_test do
|
|
125
|
-
tmpdir do |cwd|
|
|
126
|
-
File.open(File.join(cwd, ".kitchen.yml"), "w+") do |f|
|
|
127
|
-
f.print(<<-KITCHEN_YML)
|
|
128
|
-
---
|
|
129
|
-
driver:
|
|
130
|
-
name: dummy
|
|
131
|
-
network:
|
|
132
|
-
- ["forwarded_port", {guest: 80, host: 8080}]
|
|
133
|
-
|
|
134
|
-
provisioner:
|
|
135
|
-
name: policyfile_zero
|
|
136
|
-
require_chef_omnibus: 12.3.0
|
|
137
|
-
|
|
138
|
-
platforms:
|
|
139
|
-
- name: ubuntu-14.04
|
|
140
|
-
|
|
141
|
-
suites:
|
|
142
|
-
- name: default
|
|
143
|
-
run_list:
|
|
144
|
-
- recipe[aar::default]
|
|
145
|
-
attributes:
|
|
146
|
-
|
|
147
|
-
KITCHEN_YML
|
|
148
|
-
end
|
|
149
|
-
|
|
150
|
-
sh("kitchen list", cwd: cwd)
|
|
151
|
-
|
|
152
|
-
end
|
|
153
|
-
end
|
|
154
|
-
|
|
155
|
-
end
|
|
156
|
-
|
|
157
|
-
add_component "chef-client" do |c|
|
|
158
|
-
c.gem_base_dir = "chef"
|
|
159
|
-
c.unit_test do
|
|
160
|
-
bundle_install_mutex.synchronize { sh("#{embedded_bin("bundle")} install") }
|
|
161
|
-
sh("#{embedded_bin("bundle")} exec #{embedded_bin("rspec")} -fp -t '~volatile_from_verify' spec/unit")
|
|
162
|
-
end
|
|
163
|
-
c.integration_test do
|
|
164
|
-
bundle_install_mutex.synchronize { sh("#{embedded_bin("bundle")} install") }
|
|
165
|
-
sh("#{embedded_bin("bundle")} exec #{embedded_bin("rspec")} -fp spec/integration spec/functional")
|
|
166
|
-
end
|
|
167
|
-
|
|
168
|
-
c.smoke_test do
|
|
169
|
-
tmpdir do |cwd|
|
|
170
|
-
FileUtils.touch(File.join(cwd, "apply.rb"))
|
|
171
|
-
sh("#{bin("chef-apply")} apply.rb", cwd: cwd)
|
|
172
|
-
end
|
|
173
|
-
end
|
|
174
|
-
end
|
|
175
|
-
|
|
176
|
-
add_component "chef-dk" do |c|
|
|
177
|
-
c.gem_base_dir = "chef-dk"
|
|
178
|
-
c.unit_test do
|
|
179
|
-
bundle_install_mutex.synchronize { sh("#{embedded_bin("bundle")} install") }
|
|
180
|
-
sh("#{embedded_bin("bundle")} exec #{embedded_bin("rspec")}")
|
|
181
|
-
end
|
|
182
|
-
c.smoke_test do
|
|
183
|
-
run_in_tmpdir("#{bin("chef")} generate cookbook example")
|
|
184
|
-
end
|
|
185
|
-
end
|
|
186
|
-
|
|
187
|
-
# entirely possible this needs to be driven by a utility method in chef-provisioning.
|
|
188
|
-
add_component "chef-provisioning" do |c|
|
|
189
|
-
c.gem_base_dir = "chef-dk"
|
|
190
|
-
|
|
191
|
-
c.smoke_test do
|
|
192
|
-
# ------------
|
|
193
|
-
# we want to avoid hard-coding driver names, but calling Gem::Specification produces a warning;
|
|
194
|
-
# changing $VERBOSE seems to be the best way to silence it.
|
|
195
|
-
verbose = $VERBOSE
|
|
196
|
-
$VERBOSE = nil
|
|
197
|
-
|
|
198
|
-
# construct a hash of { driver_name => [version1, version2, ...]}
|
|
199
|
-
driver_versions = {}
|
|
200
|
-
Gem::Specification.all.map { |gs| [gs.name, gs.version] }.
|
|
201
|
-
select { |n| n[0] =~ /^chef-provisioning-/ }.
|
|
202
|
-
each { |gem, version| (driver_versions[gem] ||= []) << version }
|
|
203
|
-
|
|
204
|
-
drivers = Gem::Specification.all.map { |gs| gs.name }.
|
|
205
|
-
select { |n| n =~ /^chef-provisioning-/ }.
|
|
206
|
-
uniq
|
|
207
|
-
|
|
208
|
-
versions = Gem::Specification.find_all_by_name("chef-provisioning").map { |s| s.version }
|
|
209
|
-
$VERBOSE = verbose
|
|
210
|
-
# ------------
|
|
211
|
-
failures = []
|
|
212
|
-
|
|
213
|
-
# ------------
|
|
214
|
-
# fail the verify if we have more than one version of chef-provisioning or any of its drivers.
|
|
215
|
-
def format_gem_failure(name, versions)
|
|
216
|
-
<<-EOS
|
|
217
|
-
#{name} has multiple versions installed:
|
|
218
|
-
#{versions.sort.map { |gv| " #{gv}" }.join("\n")}
|
|
219
|
-
EOS
|
|
220
|
-
end
|
|
221
|
-
|
|
222
|
-
failures << format_gem_failure("chef-provisioning", versions) if versions.size > 1
|
|
223
|
-
|
|
224
|
-
driver_versions.keys.sort.each do |driver_name|
|
|
225
|
-
v = driver_versions[driver_name]
|
|
226
|
-
failures << format_gem_failure(driver_name, v) if v.size > 1
|
|
227
|
-
end
|
|
228
|
-
|
|
229
|
-
if failures.size > 0
|
|
230
|
-
failures << <<-EOS
|
|
231
|
-
|
|
232
|
-
Some applications may need or prefer different versions of the chef-provisioning gem or its drivers, so
|
|
233
|
-
this multiple-version check can fail if a user has installed new versions of those libraries.
|
|
234
|
-
EOS
|
|
235
|
-
end
|
|
236
|
-
|
|
237
|
-
# ------------
|
|
238
|
-
# load the core gem and all of the drivers (ignoring versions).
|
|
239
|
-
require "chef/provisioning"
|
|
240
|
-
drivers.map { |d| "#{d.tr('-', '/')}_driver" }.each do |driver_gem|
|
|
241
|
-
begin
|
|
242
|
-
begin
|
|
243
|
-
require driver_gem
|
|
244
|
-
rescue LoadError
|
|
245
|
-
# anomalously, chef-provisioning-fog does not have a fog_driver.rb. (9/2015)
|
|
246
|
-
require "#{driver_gem}/driver.rb"
|
|
247
|
-
end
|
|
248
|
-
rescue LoadError => ex
|
|
249
|
-
puts ex
|
|
250
|
-
end
|
|
251
|
-
end
|
|
252
|
-
|
|
253
|
-
# ------------
|
|
254
|
-
# look for version dependency conflicts.
|
|
255
|
-
tmpdir do |cwd|
|
|
256
|
-
versions.each do |provisioning_version|
|
|
257
|
-
gemfile = "chef-provisioning-#{provisioning_version}-chefdk-test.gemfile"
|
|
258
|
-
|
|
259
|
-
# write out the gemfile for this chef-provisioning version, and see if Bundler can make it go.
|
|
260
|
-
with_file(File.join(cwd, gemfile)) do |f|
|
|
261
|
-
f.puts %Q{gem "chef-provisioning", "= #{provisioning_version}"}
|
|
262
|
-
drivers.each { |d| f.puts %Q{gem "#{d}"} }
|
|
263
|
-
end
|
|
264
|
-
|
|
265
|
-
result = bundle_install_mutex.synchronize do
|
|
266
|
-
sh("#{embedded_bin("bundle")} install --local --quiet", cwd: cwd, env: { "BUNDLE_GEMFILE" => gemfile })
|
|
267
|
-
end
|
|
268
|
-
|
|
269
|
-
if result.exitstatus != 0
|
|
270
|
-
failures << result.stdout
|
|
271
|
-
end
|
|
272
|
-
end # end provisioning versions.
|
|
273
|
-
|
|
274
|
-
failures.each { |fail| puts fail }
|
|
275
|
-
|
|
276
|
-
# dubious on Windows.
|
|
277
|
-
# this is weird, but we seem to require a Mixlib::ShellOut as the return value. suggestions
|
|
278
|
-
# welcome.
|
|
279
|
-
sh(failures.size > 0 ? "false" : "true")
|
|
280
|
-
end
|
|
281
|
-
end
|
|
282
|
-
end
|
|
283
|
-
|
|
284
|
-
add_component "chefspec" do |c|
|
|
285
|
-
c.gem_base_dir = "chefspec"
|
|
286
|
-
c.unit_test do
|
|
287
|
-
bundle_install_mutex.synchronize { sh("#{embedded_bin("bundle")} install") }
|
|
288
|
-
sh("#{embedded_bin("bundle")} exec #{embedded_bin("rake")} unit")
|
|
289
|
-
end
|
|
290
|
-
c.smoke_test do
|
|
291
|
-
tmpdir do |cwd|
|
|
292
|
-
FileUtils.mkdir(File.join(cwd, "spec"))
|
|
293
|
-
with_file(File.join(cwd, "spec", "spec_helper.rb")) do |f|
|
|
294
|
-
f.write <<-EOF
|
|
295
|
-
require 'chefspec'
|
|
296
|
-
require 'chefspec/berkshelf'
|
|
297
|
-
require 'chefspec/cacher'
|
|
298
|
-
|
|
299
|
-
RSpec.configure do |config|
|
|
300
|
-
config.expect_with(:rspec) { |c| c.syntax = :expect }
|
|
301
|
-
end
|
|
302
|
-
EOF
|
|
303
|
-
end
|
|
304
|
-
FileUtils.touch(File.join(cwd, "Berksfile"))
|
|
305
|
-
with_file(File.join(cwd, "spec", "foo_spec.rb")) do |f|
|
|
306
|
-
f.write <<-EOF
|
|
307
|
-
require 'spec_helper'
|
|
308
|
-
EOF
|
|
309
|
-
end
|
|
310
|
-
sh(embedded_bin("rspec"), cwd: cwd)
|
|
311
|
-
end
|
|
312
|
-
end
|
|
313
|
-
end
|
|
314
|
-
|
|
315
|
-
add_component "generated-cookbooks-pass-chefspec" do |c|
|
|
316
|
-
|
|
317
|
-
c.gem_base_dir = "chef-dk"
|
|
318
|
-
c.smoke_test do
|
|
319
|
-
tmpdir do |cwd|
|
|
320
|
-
sh("#{bin("chef")} generate cookbook example", cwd: cwd)
|
|
321
|
-
cb_cwd = File.join(cwd, "example")
|
|
322
|
-
sh(embedded_bin("rspec"), cwd: cb_cwd)
|
|
323
|
-
end
|
|
324
|
-
end
|
|
325
|
-
end
|
|
326
|
-
|
|
327
|
-
add_component "fauxhai" do |c|
|
|
328
|
-
c.gem_base_dir = "fauxhai"
|
|
329
|
-
c.smoke_test { sh("#{embedded_bin("gem")} list fauxhai") }
|
|
330
|
-
end
|
|
331
|
-
|
|
332
|
-
add_component "knife-spork" do |c|
|
|
333
|
-
c.gem_base_dir = "knife-spork"
|
|
334
|
-
c.smoke_test { sh("#{bin("knife")} spork info") }
|
|
335
|
-
end
|
|
336
|
-
|
|
337
|
-
add_component "kitchen-vagrant" do |c|
|
|
338
|
-
c.gem_base_dir = "kitchen-vagrant"
|
|
339
|
-
# The build is not passing in travis, so no tests
|
|
340
|
-
c.smoke_test { sh("#{embedded_bin("gem")} list kitchen-vagrant") }
|
|
341
|
-
end
|
|
342
|
-
|
|
343
|
-
add_component "package installation" do |c|
|
|
344
|
-
|
|
345
|
-
c.gem_base_dir = "chef-dk"
|
|
346
|
-
|
|
347
|
-
c.smoke_test do
|
|
348
|
-
|
|
349
|
-
if File.directory?(usr_bin_prefix)
|
|
350
|
-
sh!("#{usr_bin_path("berks")} -v")
|
|
351
|
-
sh!("#{usr_bin_path("chef")} -v")
|
|
352
|
-
sh!("#{usr_bin_path("chef-client")} -v")
|
|
353
|
-
sh!("#{usr_bin_path("chef-solo")} -v")
|
|
354
|
-
sh!("#{usr_bin_path("delivery")} -V") unless Chef::Platform.windows?
|
|
355
|
-
|
|
356
|
-
# In `knife`, `knife -v` follows a different code path that skips
|
|
357
|
-
# command/plugin loading; `knife -h` loads commands and plugins, but
|
|
358
|
-
# it exits with code 1, which is the same as a load error. Running
|
|
359
|
-
# `knife exec` forces command loading to happen and this command
|
|
360
|
-
# exits 0, which runs most of the code.
|
|
361
|
-
#
|
|
362
|
-
# See also: https://github.com/chef/chef-dk/issues/227
|
|
363
|
-
sh!("#{usr_bin_path("knife")} exec -E true")
|
|
364
|
-
|
|
365
|
-
tmpdir do |dir|
|
|
366
|
-
# Kitchen tries to create a .kitchen dir even when just running
|
|
367
|
-
# `kitchen -v`:
|
|
368
|
-
sh!("#{usr_bin_path("kitchen")} -v", cwd: dir)
|
|
369
|
-
end
|
|
370
|
-
|
|
371
|
-
sh!("#{usr_bin_path("ohai")} -v")
|
|
372
|
-
sh!("#{usr_bin_path("foodcritic")} -V")
|
|
373
|
-
sh!("#{usr_bin_path("inspec")} version")
|
|
374
|
-
end
|
|
375
|
-
|
|
376
|
-
# Test blocks are expected to return a Mixlib::ShellOut compatible
|
|
377
|
-
# object:
|
|
378
|
-
ComponentTest::NullTestResult.new
|
|
379
|
-
end
|
|
380
|
-
end
|
|
381
|
-
|
|
382
|
-
add_component "openssl" do |c|
|
|
383
|
-
# https://github.com/chef/chef-dk/issues/420
|
|
384
|
-
c.gem_base_dir = "chef"
|
|
385
|
-
|
|
386
|
-
test = <<-EOF.gsub(/^\s+/, "")
|
|
387
|
-
require "net/http"
|
|
388
|
-
|
|
389
|
-
uris = %w{https://www.google.com https://chef.io/ https://ec2.amazonaws.com}
|
|
390
|
-
uris.each do |uri|
|
|
391
|
-
uri = URI(uri)
|
|
392
|
-
puts "Fetching \#{uri} for SSL check"
|
|
393
|
-
Net::HTTP.get uri
|
|
394
|
-
end
|
|
395
|
-
EOF
|
|
396
|
-
|
|
397
|
-
c.unit_test do
|
|
398
|
-
tmpdir do |cwd|
|
|
399
|
-
with_file(File.join(cwd, "openssl.rb")) do |f|
|
|
400
|
-
f.write test
|
|
401
|
-
end
|
|
402
|
-
sh!("#{Gem.ruby} openssl.rb", cwd: cwd)
|
|
403
|
-
end
|
|
404
|
-
end
|
|
405
|
-
end
|
|
406
|
-
|
|
407
|
-
add_component "inspec" do |c|
|
|
408
|
-
c.gem_base_dir = "inspec"
|
|
409
|
-
|
|
410
|
-
# Commenting out the unit and integration tests for now until we figure
|
|
411
|
-
# out the bundler error
|
|
412
|
-
#c.unit_test { sh("#{embedded_bin("bundle")} exec rake test:isolated") }
|
|
413
|
-
# This runs Test Kitchen (using kitchen-inspec) with some inspec tests
|
|
414
|
-
#c.integration_test { sh("#{embedded_bin("bundle")} exec rake test:vm") }
|
|
415
|
-
|
|
416
|
-
# It would be nice to use a chef generator to create these specs, but
|
|
417
|
-
# we dont have that yet. So we do it manually.
|
|
418
|
-
c.smoke_test do
|
|
419
|
-
tmpdir do |cwd|
|
|
420
|
-
File.open(File.join(cwd, "some_spec.rb"), "w+") do |f|
|
|
421
|
-
f.print <<-INSPEC_TEST
|
|
422
|
-
rule '01' do
|
|
423
|
-
impact 0.7
|
|
424
|
-
title 'Some Test'
|
|
425
|
-
desc 'Make sure inspec is installed and loading correct'
|
|
426
|
-
describe 1 do
|
|
427
|
-
it { should eq(1) }
|
|
428
|
-
end
|
|
429
|
-
end
|
|
430
|
-
INSPEC_TEST
|
|
431
|
-
end
|
|
432
|
-
# TODO when we appbundle inspec, no longer `chef exec`
|
|
433
|
-
sh("#{bin("chef")} exec #{embedded_bin("inspec")} exec .", cwd: cwd)
|
|
434
|
-
end
|
|
435
|
-
end
|
|
436
|
-
end
|
|
437
|
-
|
|
438
|
-
add_component "delivery-cli" do |c|
|
|
439
|
-
# We'll want to come back and revisit getting unit tests added -
|
|
440
|
-
# currently running the tests depends on cargo , which is not included
|
|
441
|
-
# in our package.
|
|
442
|
-
c.base_dir = "bin"
|
|
443
|
-
c.smoke_test do
|
|
444
|
-
tmpdir do |cwd|
|
|
445
|
-
sh!("delivery setup --user=shipit --server=delivery.shipit.io --ent=chef --org=squirrels", cwd: cwd)
|
|
446
|
-
end
|
|
447
|
-
end
|
|
448
|
-
end
|
|
449
|
-
|
|
450
|
-
if Chef::Platform.windows?
|
|
451
|
-
add_component "git" do |c|
|
|
452
|
-
c.base_dir = "embedded/bin"
|
|
453
|
-
c.smoke_test do
|
|
454
|
-
tmpdir do |cwd|
|
|
455
|
-
sh!("#{embedded_bin("git")} config -l")
|
|
456
|
-
sh!("#{embedded_bin("git")} clone https://github.com/chef/chef-provisioning", cwd: cwd)
|
|
457
|
-
end
|
|
458
|
-
end
|
|
459
|
-
end
|
|
460
|
-
else
|
|
461
|
-
add_component "git" do |c|
|
|
462
|
-
c.base_dir = "gitbin"
|
|
463
|
-
c.smoke_test do
|
|
464
|
-
tmpdir do |cwd|
|
|
465
|
-
sh!("#{File.join(omnibus_root, "gitbin", "git")} config -l")
|
|
466
|
-
sh!("#{File.join(omnibus_root, "gitbin", "git")} clone https://github.com/chef/chef-provisioning", cwd: cwd)
|
|
467
|
-
|
|
468
|
-
# If /usr/bin/git is a symlink, fail the test.
|
|
469
|
-
# Note that this test cannot go last because it does not return a
|
|
470
|
-
# Mixlib::Shellout object in the windows case, which will break the tests.
|
|
471
|
-
failure_str = "#{nix_platform_native_bin_dir}/git contains a symlink which might mean we accidentally overwrote system git via chefdk."
|
|
472
|
-
result = sh("readlink #{nix_platform_native_bin_dir}/git")
|
|
473
|
-
# if a symlink was found, test to see if it is in a chefdk install
|
|
474
|
-
if result.status.exitstatus == 0
|
|
475
|
-
raise failure_str if result.stdout =~ /chefdk/
|
|
476
|
-
end
|
|
477
|
-
|
|
478
|
-
# <chef_dk>/bin/ should not contain a git binary.
|
|
479
|
-
failure_str = "`<chef_dk>/bin/git --help` should fail as git should be installed in gitbin"
|
|
480
|
-
fail_if_exit_zero("#{bin("git")} --help", failure_str)
|
|
481
|
-
end
|
|
482
|
-
end
|
|
483
|
-
end
|
|
484
|
-
end
|
|
485
|
-
|
|
486
|
-
add_component "opscode-pushy-client" do |c|
|
|
487
|
-
c.gem_base_dir = "opscode-pushy-client"
|
|
488
|
-
# TODO the unit tests are currently failing in master
|
|
489
|
-
# c.unit_test do
|
|
490
|
-
# bundle_install_mutex.synchronize { sh("#{embedded_bin("bundle")} install") }
|
|
491
|
-
# sh("#{embedded_bin("bundle")} exec rake spec")
|
|
492
|
-
# end
|
|
493
|
-
|
|
494
|
-
c.smoke_test do
|
|
495
|
-
tmpdir do |cwd|
|
|
496
|
-
sh("#{bin("pushy-client")} -v", cwd: cwd)
|
|
497
|
-
end
|
|
498
|
-
end
|
|
499
|
-
end
|
|
500
|
-
|
|
501
|
-
# We try and use some chef-sugar code to make sure it loads correctly
|
|
502
|
-
add_component "chef-sugar" do |c|
|
|
503
|
-
c.gem_base_dir = "chef-sugar"
|
|
504
|
-
c.smoke_test do
|
|
505
|
-
tmpdir do |cwd|
|
|
506
|
-
with_file(File.join(cwd, "foo.rb")) do |f|
|
|
507
|
-
f.write <<-EOF
|
|
508
|
-
require 'chef/sugar'
|
|
509
|
-
log 'something' do
|
|
510
|
-
not_if { _64_bit? }
|
|
511
|
-
end
|
|
512
|
-
EOF
|
|
513
|
-
end
|
|
514
|
-
sh("chef-apply foo.rb", cwd: cwd)
|
|
515
|
-
end
|
|
516
|
-
end
|
|
517
|
-
end
|
|
518
|
-
|
|
519
|
-
attr_reader :verification_threads
|
|
520
|
-
attr_reader :verification_results
|
|
521
|
-
attr_reader :verification_status
|
|
522
|
-
|
|
523
|
-
def initialize
|
|
524
|
-
super
|
|
525
|
-
@verification_threads = [ ]
|
|
526
|
-
@verification_results = [ ]
|
|
527
|
-
@verification_status = 0
|
|
528
|
-
end
|
|
529
|
-
|
|
530
|
-
def run(params = [ ])
|
|
531
|
-
err("[WARN] This is an internal command used by the ChefDK development team. If you are a ChefDK user, please do not run it.")
|
|
532
|
-
@components_filter = parse_options(params)
|
|
533
|
-
|
|
534
|
-
validate_components!
|
|
535
|
-
invoke_tests
|
|
536
|
-
wait_for_tests
|
|
537
|
-
report_results
|
|
538
|
-
|
|
539
|
-
verification_status
|
|
540
|
-
end
|
|
541
|
-
|
|
542
|
-
def omnibus_root
|
|
543
|
-
config[:omnibus_dir] || super
|
|
544
|
-
end
|
|
545
|
-
|
|
546
|
-
def validate_components!
|
|
547
|
-
components.each do |component|
|
|
548
|
-
component.omnibus_root = omnibus_root
|
|
549
|
-
component.assert_present!
|
|
550
|
-
end
|
|
551
|
-
end
|
|
552
|
-
|
|
553
|
-
def components_to_test
|
|
554
|
-
if @components_filter.empty?
|
|
555
|
-
components
|
|
556
|
-
else
|
|
557
|
-
components.select do |component|
|
|
558
|
-
@components_filter.include?(component.name.to_s)
|
|
559
|
-
end
|
|
560
|
-
end
|
|
561
|
-
end
|
|
562
|
-
|
|
563
|
-
def invoke_tests
|
|
564
|
-
components_to_test.each do |component|
|
|
565
|
-
# Run the component specs in parallel
|
|
566
|
-
verification_threads << Thread.new do
|
|
567
|
-
|
|
568
|
-
results = []
|
|
569
|
-
|
|
570
|
-
results << component.run_smoke_test
|
|
571
|
-
|
|
572
|
-
if config[:unit]
|
|
573
|
-
results << component.run_unit_test
|
|
574
|
-
end
|
|
575
|
-
|
|
576
|
-
if config[:integration]
|
|
577
|
-
results << component.run_integration_test
|
|
578
|
-
end
|
|
579
|
-
|
|
580
|
-
if results.any? { |r| r.exitstatus != 0 }
|
|
581
|
-
component_status = 1
|
|
582
|
-
@verification_status = 1
|
|
583
|
-
else
|
|
584
|
-
component_status = 0
|
|
585
|
-
end
|
|
586
|
-
|
|
587
|
-
{
|
|
588
|
-
:component => component,
|
|
589
|
-
:results => results,
|
|
590
|
-
:component_status => component_status,
|
|
591
|
-
}
|
|
592
|
-
end
|
|
593
|
-
|
|
594
|
-
msg("Running verification for component '#{component.name}'")
|
|
595
|
-
end
|
|
596
|
-
end
|
|
597
|
-
|
|
598
|
-
def wait_for_tests
|
|
599
|
-
until verification_threads.empty?
|
|
600
|
-
verification_threads.each do |t|
|
|
601
|
-
if t.join(1)
|
|
602
|
-
verification_threads.delete t
|
|
603
|
-
verification_results << t.value
|
|
604
|
-
t.value[:results].each do |result|
|
|
605
|
-
if config[:verbose] || t.value[:component_status] != 0
|
|
606
|
-
msg("")
|
|
607
|
-
msg(result.stdout)
|
|
608
|
-
msg(result.stderr) if result.stderr
|
|
609
|
-
end
|
|
610
|
-
end
|
|
611
|
-
else
|
|
612
|
-
$stdout.write "."
|
|
613
|
-
end
|
|
614
|
-
end
|
|
615
|
-
end
|
|
616
|
-
end
|
|
617
|
-
|
|
618
|
-
def report_results
|
|
619
|
-
msg("")
|
|
620
|
-
msg("---------------------------------------------")
|
|
621
|
-
verification_results.each do |result|
|
|
622
|
-
message = result[:component_status] == 0 ? "succeeded" : "failed"
|
|
623
|
-
msg("Verification of component '#{result[:component].name}' #{message}.")
|
|
624
|
-
end
|
|
625
|
-
end
|
|
626
|
-
|
|
627
|
-
end
|
|
628
|
-
end
|
|
629
|
-
end
|
|
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/command/base"
|
|
19
|
+
require "chef-dk/exceptions"
|
|
20
|
+
require "chef-dk/component_test"
|
|
21
|
+
|
|
22
|
+
module ChefDK
|
|
23
|
+
module Command
|
|
24
|
+
class Verify < ChefDK::Command::Base
|
|
25
|
+
|
|
26
|
+
include ChefDK::Helpers
|
|
27
|
+
|
|
28
|
+
banner "Usage: chef verify [component, ...] [options]"
|
|
29
|
+
|
|
30
|
+
option :omnibus_dir,
|
|
31
|
+
:long => "--omnibus-dir OMNIBUS_DIR",
|
|
32
|
+
:description => "Alternate path to omnibus install (used for testing)"
|
|
33
|
+
|
|
34
|
+
option :unit,
|
|
35
|
+
:long => "--unit",
|
|
36
|
+
:description => "Run bundled app unit tests (only smoke tests run by default)"
|
|
37
|
+
|
|
38
|
+
option :integration,
|
|
39
|
+
:long => "--integration",
|
|
40
|
+
:description => "Run integration tests. Possibly dangerous, for development systems only"
|
|
41
|
+
|
|
42
|
+
option :verbose,
|
|
43
|
+
:long => "--verbose",
|
|
44
|
+
:description => "Display all test output, not just failing tests"
|
|
45
|
+
|
|
46
|
+
class << self
|
|
47
|
+
def add_component(name, _delete_me = nil)
|
|
48
|
+
component = ComponentTest.new(name)
|
|
49
|
+
yield component if block_given? #delete this conditional
|
|
50
|
+
component_map[name] = component
|
|
51
|
+
end
|
|
52
|
+
|
|
53
|
+
def component(name)
|
|
54
|
+
component_map[name]
|
|
55
|
+
end
|
|
56
|
+
|
|
57
|
+
def components
|
|
58
|
+
component_map.values
|
|
59
|
+
end
|
|
60
|
+
|
|
61
|
+
def component_map
|
|
62
|
+
@component_map ||= {}
|
|
63
|
+
end
|
|
64
|
+
end
|
|
65
|
+
|
|
66
|
+
def components
|
|
67
|
+
self.class.components
|
|
68
|
+
end
|
|
69
|
+
|
|
70
|
+
bundle_install_mutex = Mutex.new
|
|
71
|
+
|
|
72
|
+
#
|
|
73
|
+
# Components included in Chef Development kit:
|
|
74
|
+
# :base_dir => Relative path of the component w.r.t. omnibus_apps_dir
|
|
75
|
+
# :gem_base_dir => Takes a gem name instead and uses first gem found
|
|
76
|
+
# :test_cmd => Test command to be launched for the component
|
|
77
|
+
#
|
|
78
|
+
add_component "berkshelf" do |c|
|
|
79
|
+
c.gem_base_dir = "berkshelf"
|
|
80
|
+
# For berks the real command to run is "#{embedded_bin("bundle")} exec thor spec:ci"
|
|
81
|
+
# We can't run it right now since graphviz specs are included in the
|
|
82
|
+
# test suite by default. We will be able to switch to that command when/if
|
|
83
|
+
# Graphviz is added to omnibus.
|
|
84
|
+
c.unit_test do
|
|
85
|
+
bundle_install_mutex.synchronize { sh("#{embedded_bin("bundle")} install") }
|
|
86
|
+
sh("#{embedded_bin("bundle")} exec #{embedded_bin("rspec")} --color --format progress spec/unit --tag ~graphviz")
|
|
87
|
+
end
|
|
88
|
+
c.integration_test do
|
|
89
|
+
bundle_install_mutex.synchronize { sh("#{embedded_bin("bundle")} install") }
|
|
90
|
+
sh("#{embedded_bin("bundle")} exec #{embedded_bin("cucumber")} --color --format progress --tags ~@no_run --tags ~@spawn --tags ~@graphviz --strict")
|
|
91
|
+
end
|
|
92
|
+
|
|
93
|
+
c.smoke_test do
|
|
94
|
+
tmpdir do |cwd|
|
|
95
|
+
FileUtils.touch(File.join(cwd, "Berksfile"))
|
|
96
|
+
sh("#{bin("berks")} install", cwd: cwd)
|
|
97
|
+
end
|
|
98
|
+
end
|
|
99
|
+
end
|
|
100
|
+
|
|
101
|
+
add_component "test-kitchen" do |c|
|
|
102
|
+
c.gem_base_dir = "test-kitchen"
|
|
103
|
+
c.unit_test do
|
|
104
|
+
bundle_install_mutex.synchronize { sh("#{embedded_bin("bundle")} install") }
|
|
105
|
+
sh("#{embedded_bin("bundle")} exec rake unit")
|
|
106
|
+
end
|
|
107
|
+
c.integration_test do
|
|
108
|
+
bundle_install_mutex.synchronize { sh("#{embedded_bin("bundle")} install") }
|
|
109
|
+
sh("#{embedded_bin("bundle")} exec rake features")
|
|
110
|
+
end
|
|
111
|
+
|
|
112
|
+
# NOTE: By default, kitchen tries to be helpful and install a driver
|
|
113
|
+
# gem for you. This causes a race condition when running the tests
|
|
114
|
+
# concurrently, because rubygems breaks when there are partially
|
|
115
|
+
# installed gems in the gem repository. Instructing kitchen to create a
|
|
116
|
+
# gemfile instead avoids the gem installation.
|
|
117
|
+
c.smoke_test { run_in_tmpdir("kitchen init --create-gemfile") }
|
|
118
|
+
end
|
|
119
|
+
|
|
120
|
+
add_component "tk-policyfile-provisioner" do |c|
|
|
121
|
+
|
|
122
|
+
c.gem_base_dir = "chef-dk"
|
|
123
|
+
|
|
124
|
+
c.smoke_test do
|
|
125
|
+
tmpdir do |cwd|
|
|
126
|
+
File.open(File.join(cwd, ".kitchen.yml"), "w+") do |f|
|
|
127
|
+
f.print(<<-KITCHEN_YML)
|
|
128
|
+
---
|
|
129
|
+
driver:
|
|
130
|
+
name: dummy
|
|
131
|
+
network:
|
|
132
|
+
- ["forwarded_port", {guest: 80, host: 8080}]
|
|
133
|
+
|
|
134
|
+
provisioner:
|
|
135
|
+
name: policyfile_zero
|
|
136
|
+
require_chef_omnibus: 12.3.0
|
|
137
|
+
|
|
138
|
+
platforms:
|
|
139
|
+
- name: ubuntu-14.04
|
|
140
|
+
|
|
141
|
+
suites:
|
|
142
|
+
- name: default
|
|
143
|
+
run_list:
|
|
144
|
+
- recipe[aar::default]
|
|
145
|
+
attributes:
|
|
146
|
+
|
|
147
|
+
KITCHEN_YML
|
|
148
|
+
end
|
|
149
|
+
|
|
150
|
+
sh("kitchen list", cwd: cwd)
|
|
151
|
+
|
|
152
|
+
end
|
|
153
|
+
end
|
|
154
|
+
|
|
155
|
+
end
|
|
156
|
+
|
|
157
|
+
add_component "chef-client" do |c|
|
|
158
|
+
c.gem_base_dir = "chef"
|
|
159
|
+
c.unit_test do
|
|
160
|
+
bundle_install_mutex.synchronize { sh("#{embedded_bin("bundle")} install") }
|
|
161
|
+
sh("#{embedded_bin("bundle")} exec #{embedded_bin("rspec")} -fp -t '~volatile_from_verify' spec/unit")
|
|
162
|
+
end
|
|
163
|
+
c.integration_test do
|
|
164
|
+
bundle_install_mutex.synchronize { sh("#{embedded_bin("bundle")} install") }
|
|
165
|
+
sh("#{embedded_bin("bundle")} exec #{embedded_bin("rspec")} -fp spec/integration spec/functional")
|
|
166
|
+
end
|
|
167
|
+
|
|
168
|
+
c.smoke_test do
|
|
169
|
+
tmpdir do |cwd|
|
|
170
|
+
FileUtils.touch(File.join(cwd, "apply.rb"))
|
|
171
|
+
sh("#{bin("chef-apply")} apply.rb", cwd: cwd)
|
|
172
|
+
end
|
|
173
|
+
end
|
|
174
|
+
end
|
|
175
|
+
|
|
176
|
+
add_component "chef-dk" do |c|
|
|
177
|
+
c.gem_base_dir = "chef-dk"
|
|
178
|
+
c.unit_test do
|
|
179
|
+
bundle_install_mutex.synchronize { sh("#{embedded_bin("bundle")} install") }
|
|
180
|
+
sh("#{embedded_bin("bundle")} exec #{embedded_bin("rspec")}")
|
|
181
|
+
end
|
|
182
|
+
c.smoke_test do
|
|
183
|
+
run_in_tmpdir("#{bin("chef")} generate cookbook example")
|
|
184
|
+
end
|
|
185
|
+
end
|
|
186
|
+
|
|
187
|
+
# entirely possible this needs to be driven by a utility method in chef-provisioning.
|
|
188
|
+
add_component "chef-provisioning" do |c|
|
|
189
|
+
c.gem_base_dir = "chef-dk"
|
|
190
|
+
|
|
191
|
+
c.smoke_test do
|
|
192
|
+
# ------------
|
|
193
|
+
# we want to avoid hard-coding driver names, but calling Gem::Specification produces a warning;
|
|
194
|
+
# changing $VERBOSE seems to be the best way to silence it.
|
|
195
|
+
verbose = $VERBOSE
|
|
196
|
+
$VERBOSE = nil
|
|
197
|
+
|
|
198
|
+
# construct a hash of { driver_name => [version1, version2, ...]}
|
|
199
|
+
driver_versions = {}
|
|
200
|
+
Gem::Specification.all.map { |gs| [gs.name, gs.version] }.
|
|
201
|
+
select { |n| n[0] =~ /^chef-provisioning-/ }.
|
|
202
|
+
each { |gem, version| (driver_versions[gem] ||= []) << version }
|
|
203
|
+
|
|
204
|
+
drivers = Gem::Specification.all.map { |gs| gs.name }.
|
|
205
|
+
select { |n| n =~ /^chef-provisioning-/ }.
|
|
206
|
+
uniq
|
|
207
|
+
|
|
208
|
+
versions = Gem::Specification.find_all_by_name("chef-provisioning").map { |s| s.version }
|
|
209
|
+
$VERBOSE = verbose
|
|
210
|
+
# ------------
|
|
211
|
+
failures = []
|
|
212
|
+
|
|
213
|
+
# ------------
|
|
214
|
+
# fail the verify if we have more than one version of chef-provisioning or any of its drivers.
|
|
215
|
+
def format_gem_failure(name, versions)
|
|
216
|
+
<<-EOS
|
|
217
|
+
#{name} has multiple versions installed:
|
|
218
|
+
#{versions.sort.map { |gv| " #{gv}" }.join("\n")}
|
|
219
|
+
EOS
|
|
220
|
+
end
|
|
221
|
+
|
|
222
|
+
failures << format_gem_failure("chef-provisioning", versions) if versions.size > 1
|
|
223
|
+
|
|
224
|
+
driver_versions.keys.sort.each do |driver_name|
|
|
225
|
+
v = driver_versions[driver_name]
|
|
226
|
+
failures << format_gem_failure(driver_name, v) if v.size > 1
|
|
227
|
+
end
|
|
228
|
+
|
|
229
|
+
if failures.size > 0
|
|
230
|
+
failures << <<-EOS
|
|
231
|
+
|
|
232
|
+
Some applications may need or prefer different versions of the chef-provisioning gem or its drivers, so
|
|
233
|
+
this multiple-version check can fail if a user has installed new versions of those libraries.
|
|
234
|
+
EOS
|
|
235
|
+
end
|
|
236
|
+
|
|
237
|
+
# ------------
|
|
238
|
+
# load the core gem and all of the drivers (ignoring versions).
|
|
239
|
+
require "chef/provisioning"
|
|
240
|
+
drivers.map { |d| "#{d.tr('-', '/')}_driver" }.each do |driver_gem|
|
|
241
|
+
begin
|
|
242
|
+
begin
|
|
243
|
+
require driver_gem
|
|
244
|
+
rescue LoadError
|
|
245
|
+
# anomalously, chef-provisioning-fog does not have a fog_driver.rb. (9/2015)
|
|
246
|
+
require "#{driver_gem}/driver.rb"
|
|
247
|
+
end
|
|
248
|
+
rescue LoadError => ex
|
|
249
|
+
puts ex
|
|
250
|
+
end
|
|
251
|
+
end
|
|
252
|
+
|
|
253
|
+
# ------------
|
|
254
|
+
# look for version dependency conflicts.
|
|
255
|
+
tmpdir do |cwd|
|
|
256
|
+
versions.each do |provisioning_version|
|
|
257
|
+
gemfile = "chef-provisioning-#{provisioning_version}-chefdk-test.gemfile"
|
|
258
|
+
|
|
259
|
+
# write out the gemfile for this chef-provisioning version, and see if Bundler can make it go.
|
|
260
|
+
with_file(File.join(cwd, gemfile)) do |f|
|
|
261
|
+
f.puts %Q{gem "chef-provisioning", "= #{provisioning_version}"}
|
|
262
|
+
drivers.each { |d| f.puts %Q{gem "#{d}"} }
|
|
263
|
+
end
|
|
264
|
+
|
|
265
|
+
result = bundle_install_mutex.synchronize do
|
|
266
|
+
sh("#{embedded_bin("bundle")} install --local --quiet", cwd: cwd, env: { "BUNDLE_GEMFILE" => gemfile })
|
|
267
|
+
end
|
|
268
|
+
|
|
269
|
+
if result.exitstatus != 0
|
|
270
|
+
failures << result.stdout
|
|
271
|
+
end
|
|
272
|
+
end # end provisioning versions.
|
|
273
|
+
|
|
274
|
+
failures.each { |fail| puts fail }
|
|
275
|
+
|
|
276
|
+
# dubious on Windows.
|
|
277
|
+
# this is weird, but we seem to require a Mixlib::ShellOut as the return value. suggestions
|
|
278
|
+
# welcome.
|
|
279
|
+
sh(failures.size > 0 ? "false" : "true")
|
|
280
|
+
end
|
|
281
|
+
end
|
|
282
|
+
end
|
|
283
|
+
|
|
284
|
+
add_component "chefspec" do |c|
|
|
285
|
+
c.gem_base_dir = "chefspec"
|
|
286
|
+
c.unit_test do
|
|
287
|
+
bundle_install_mutex.synchronize { sh("#{embedded_bin("bundle")} install") }
|
|
288
|
+
sh("#{embedded_bin("bundle")} exec #{embedded_bin("rake")} unit")
|
|
289
|
+
end
|
|
290
|
+
c.smoke_test do
|
|
291
|
+
tmpdir do |cwd|
|
|
292
|
+
FileUtils.mkdir(File.join(cwd, "spec"))
|
|
293
|
+
with_file(File.join(cwd, "spec", "spec_helper.rb")) do |f|
|
|
294
|
+
f.write <<-EOF
|
|
295
|
+
require 'chefspec'
|
|
296
|
+
require 'chefspec/berkshelf'
|
|
297
|
+
require 'chefspec/cacher'
|
|
298
|
+
|
|
299
|
+
RSpec.configure do |config|
|
|
300
|
+
config.expect_with(:rspec) { |c| c.syntax = :expect }
|
|
301
|
+
end
|
|
302
|
+
EOF
|
|
303
|
+
end
|
|
304
|
+
FileUtils.touch(File.join(cwd, "Berksfile"))
|
|
305
|
+
with_file(File.join(cwd, "spec", "foo_spec.rb")) do |f|
|
|
306
|
+
f.write <<-EOF
|
|
307
|
+
require 'spec_helper'
|
|
308
|
+
EOF
|
|
309
|
+
end
|
|
310
|
+
sh(embedded_bin("rspec"), cwd: cwd)
|
|
311
|
+
end
|
|
312
|
+
end
|
|
313
|
+
end
|
|
314
|
+
|
|
315
|
+
add_component "generated-cookbooks-pass-chefspec" do |c|
|
|
316
|
+
|
|
317
|
+
c.gem_base_dir = "chef-dk"
|
|
318
|
+
c.smoke_test do
|
|
319
|
+
tmpdir do |cwd|
|
|
320
|
+
sh("#{bin("chef")} generate cookbook example", cwd: cwd)
|
|
321
|
+
cb_cwd = File.join(cwd, "example")
|
|
322
|
+
sh(embedded_bin("rspec"), cwd: cb_cwd)
|
|
323
|
+
end
|
|
324
|
+
end
|
|
325
|
+
end
|
|
326
|
+
|
|
327
|
+
add_component "fauxhai" do |c|
|
|
328
|
+
c.gem_base_dir = "fauxhai"
|
|
329
|
+
c.smoke_test { sh("#{embedded_bin("gem")} list fauxhai") }
|
|
330
|
+
end
|
|
331
|
+
|
|
332
|
+
add_component "knife-spork" do |c|
|
|
333
|
+
c.gem_base_dir = "knife-spork"
|
|
334
|
+
c.smoke_test { sh("#{bin("knife")} spork info") }
|
|
335
|
+
end
|
|
336
|
+
|
|
337
|
+
add_component "kitchen-vagrant" do |c|
|
|
338
|
+
c.gem_base_dir = "kitchen-vagrant"
|
|
339
|
+
# The build is not passing in travis, so no tests
|
|
340
|
+
c.smoke_test { sh("#{embedded_bin("gem")} list kitchen-vagrant") }
|
|
341
|
+
end
|
|
342
|
+
|
|
343
|
+
add_component "package installation" do |c|
|
|
344
|
+
|
|
345
|
+
c.gem_base_dir = "chef-dk"
|
|
346
|
+
|
|
347
|
+
c.smoke_test do
|
|
348
|
+
|
|
349
|
+
if File.directory?(usr_bin_prefix)
|
|
350
|
+
sh!("#{usr_bin_path("berks")} -v")
|
|
351
|
+
sh!("#{usr_bin_path("chef")} -v")
|
|
352
|
+
sh!("#{usr_bin_path("chef-client")} -v")
|
|
353
|
+
sh!("#{usr_bin_path("chef-solo")} -v")
|
|
354
|
+
sh!("#{usr_bin_path("delivery")} -V") unless Chef::Platform.windows?
|
|
355
|
+
|
|
356
|
+
# In `knife`, `knife -v` follows a different code path that skips
|
|
357
|
+
# command/plugin loading; `knife -h` loads commands and plugins, but
|
|
358
|
+
# it exits with code 1, which is the same as a load error. Running
|
|
359
|
+
# `knife exec` forces command loading to happen and this command
|
|
360
|
+
# exits 0, which runs most of the code.
|
|
361
|
+
#
|
|
362
|
+
# See also: https://github.com/chef/chef-dk/issues/227
|
|
363
|
+
sh!("#{usr_bin_path("knife")} exec -E true")
|
|
364
|
+
|
|
365
|
+
tmpdir do |dir|
|
|
366
|
+
# Kitchen tries to create a .kitchen dir even when just running
|
|
367
|
+
# `kitchen -v`:
|
|
368
|
+
sh!("#{usr_bin_path("kitchen")} -v", cwd: dir)
|
|
369
|
+
end
|
|
370
|
+
|
|
371
|
+
sh!("#{usr_bin_path("ohai")} -v")
|
|
372
|
+
sh!("#{usr_bin_path("foodcritic")} -V")
|
|
373
|
+
sh!("#{usr_bin_path("inspec")} version")
|
|
374
|
+
end
|
|
375
|
+
|
|
376
|
+
# Test blocks are expected to return a Mixlib::ShellOut compatible
|
|
377
|
+
# object:
|
|
378
|
+
ComponentTest::NullTestResult.new
|
|
379
|
+
end
|
|
380
|
+
end
|
|
381
|
+
|
|
382
|
+
add_component "openssl" do |c|
|
|
383
|
+
# https://github.com/chef/chef-dk/issues/420
|
|
384
|
+
c.gem_base_dir = "chef"
|
|
385
|
+
|
|
386
|
+
test = <<-EOF.gsub(/^\s+/, "")
|
|
387
|
+
require "net/http"
|
|
388
|
+
|
|
389
|
+
uris = %w{https://www.google.com https://chef.io/ https://ec2.amazonaws.com}
|
|
390
|
+
uris.each do |uri|
|
|
391
|
+
uri = URI(uri)
|
|
392
|
+
puts "Fetching \#{uri} for SSL check"
|
|
393
|
+
Net::HTTP.get uri
|
|
394
|
+
end
|
|
395
|
+
EOF
|
|
396
|
+
|
|
397
|
+
c.unit_test do
|
|
398
|
+
tmpdir do |cwd|
|
|
399
|
+
with_file(File.join(cwd, "openssl.rb")) do |f|
|
|
400
|
+
f.write test
|
|
401
|
+
end
|
|
402
|
+
sh!("#{Gem.ruby} openssl.rb", cwd: cwd)
|
|
403
|
+
end
|
|
404
|
+
end
|
|
405
|
+
end
|
|
406
|
+
|
|
407
|
+
add_component "inspec" do |c|
|
|
408
|
+
c.gem_base_dir = "inspec"
|
|
409
|
+
|
|
410
|
+
# Commenting out the unit and integration tests for now until we figure
|
|
411
|
+
# out the bundler error
|
|
412
|
+
#c.unit_test { sh("#{embedded_bin("bundle")} exec rake test:isolated") }
|
|
413
|
+
# This runs Test Kitchen (using kitchen-inspec) with some inspec tests
|
|
414
|
+
#c.integration_test { sh("#{embedded_bin("bundle")} exec rake test:vm") }
|
|
415
|
+
|
|
416
|
+
# It would be nice to use a chef generator to create these specs, but
|
|
417
|
+
# we dont have that yet. So we do it manually.
|
|
418
|
+
c.smoke_test do
|
|
419
|
+
tmpdir do |cwd|
|
|
420
|
+
File.open(File.join(cwd, "some_spec.rb"), "w+") do |f|
|
|
421
|
+
f.print <<-INSPEC_TEST
|
|
422
|
+
rule '01' do
|
|
423
|
+
impact 0.7
|
|
424
|
+
title 'Some Test'
|
|
425
|
+
desc 'Make sure inspec is installed and loading correct'
|
|
426
|
+
describe 1 do
|
|
427
|
+
it { should eq(1) }
|
|
428
|
+
end
|
|
429
|
+
end
|
|
430
|
+
INSPEC_TEST
|
|
431
|
+
end
|
|
432
|
+
# TODO when we appbundle inspec, no longer `chef exec`
|
|
433
|
+
sh("#{bin("chef")} exec #{embedded_bin("inspec")} exec .", cwd: cwd)
|
|
434
|
+
end
|
|
435
|
+
end
|
|
436
|
+
end
|
|
437
|
+
|
|
438
|
+
add_component "delivery-cli" do |c|
|
|
439
|
+
# We'll want to come back and revisit getting unit tests added -
|
|
440
|
+
# currently running the tests depends on cargo , which is not included
|
|
441
|
+
# in our package.
|
|
442
|
+
c.base_dir = "bin"
|
|
443
|
+
c.smoke_test do
|
|
444
|
+
tmpdir do |cwd|
|
|
445
|
+
sh!("delivery setup --user=shipit --server=delivery.shipit.io --ent=chef --org=squirrels", cwd: cwd)
|
|
446
|
+
end
|
|
447
|
+
end
|
|
448
|
+
end
|
|
449
|
+
|
|
450
|
+
if Chef::Platform.windows?
|
|
451
|
+
add_component "git" do |c|
|
|
452
|
+
c.base_dir = "embedded/bin"
|
|
453
|
+
c.smoke_test do
|
|
454
|
+
tmpdir do |cwd|
|
|
455
|
+
sh!("#{embedded_bin("git")} config -l")
|
|
456
|
+
sh!("#{embedded_bin("git")} clone https://github.com/chef/chef-provisioning", cwd: cwd)
|
|
457
|
+
end
|
|
458
|
+
end
|
|
459
|
+
end
|
|
460
|
+
else
|
|
461
|
+
add_component "git" do |c|
|
|
462
|
+
c.base_dir = "gitbin"
|
|
463
|
+
c.smoke_test do
|
|
464
|
+
tmpdir do |cwd|
|
|
465
|
+
sh!("#{File.join(omnibus_root, "gitbin", "git")} config -l")
|
|
466
|
+
sh!("#{File.join(omnibus_root, "gitbin", "git")} clone https://github.com/chef/chef-provisioning", cwd: cwd)
|
|
467
|
+
|
|
468
|
+
# If /usr/bin/git is a symlink, fail the test.
|
|
469
|
+
# Note that this test cannot go last because it does not return a
|
|
470
|
+
# Mixlib::Shellout object in the windows case, which will break the tests.
|
|
471
|
+
failure_str = "#{nix_platform_native_bin_dir}/git contains a symlink which might mean we accidentally overwrote system git via chefdk."
|
|
472
|
+
result = sh("readlink #{nix_platform_native_bin_dir}/git")
|
|
473
|
+
# if a symlink was found, test to see if it is in a chefdk install
|
|
474
|
+
if result.status.exitstatus == 0
|
|
475
|
+
raise failure_str if result.stdout =~ /chefdk/
|
|
476
|
+
end
|
|
477
|
+
|
|
478
|
+
# <chef_dk>/bin/ should not contain a git binary.
|
|
479
|
+
failure_str = "`<chef_dk>/bin/git --help` should fail as git should be installed in gitbin"
|
|
480
|
+
fail_if_exit_zero("#{bin("git")} --help", failure_str)
|
|
481
|
+
end
|
|
482
|
+
end
|
|
483
|
+
end
|
|
484
|
+
end
|
|
485
|
+
|
|
486
|
+
add_component "opscode-pushy-client" do |c|
|
|
487
|
+
c.gem_base_dir = "opscode-pushy-client"
|
|
488
|
+
# TODO the unit tests are currently failing in master
|
|
489
|
+
# c.unit_test do
|
|
490
|
+
# bundle_install_mutex.synchronize { sh("#{embedded_bin("bundle")} install") }
|
|
491
|
+
# sh("#{embedded_bin("bundle")} exec rake spec")
|
|
492
|
+
# end
|
|
493
|
+
|
|
494
|
+
c.smoke_test do
|
|
495
|
+
tmpdir do |cwd|
|
|
496
|
+
sh("#{bin("pushy-client")} -v", cwd: cwd)
|
|
497
|
+
end
|
|
498
|
+
end
|
|
499
|
+
end
|
|
500
|
+
|
|
501
|
+
# We try and use some chef-sugar code to make sure it loads correctly
|
|
502
|
+
add_component "chef-sugar" do |c|
|
|
503
|
+
c.gem_base_dir = "chef-sugar"
|
|
504
|
+
c.smoke_test do
|
|
505
|
+
tmpdir do |cwd|
|
|
506
|
+
with_file(File.join(cwd, "foo.rb")) do |f|
|
|
507
|
+
f.write <<-EOF
|
|
508
|
+
require 'chef/sugar'
|
|
509
|
+
log 'something' do
|
|
510
|
+
not_if { _64_bit? }
|
|
511
|
+
end
|
|
512
|
+
EOF
|
|
513
|
+
end
|
|
514
|
+
sh("chef-apply foo.rb", cwd: cwd)
|
|
515
|
+
end
|
|
516
|
+
end
|
|
517
|
+
end
|
|
518
|
+
|
|
519
|
+
attr_reader :verification_threads
|
|
520
|
+
attr_reader :verification_results
|
|
521
|
+
attr_reader :verification_status
|
|
522
|
+
|
|
523
|
+
def initialize
|
|
524
|
+
super
|
|
525
|
+
@verification_threads = [ ]
|
|
526
|
+
@verification_results = [ ]
|
|
527
|
+
@verification_status = 0
|
|
528
|
+
end
|
|
529
|
+
|
|
530
|
+
def run(params = [ ])
|
|
531
|
+
err("[WARN] This is an internal command used by the ChefDK development team. If you are a ChefDK user, please do not run it.")
|
|
532
|
+
@components_filter = parse_options(params)
|
|
533
|
+
|
|
534
|
+
validate_components!
|
|
535
|
+
invoke_tests
|
|
536
|
+
wait_for_tests
|
|
537
|
+
report_results
|
|
538
|
+
|
|
539
|
+
verification_status
|
|
540
|
+
end
|
|
541
|
+
|
|
542
|
+
def omnibus_root
|
|
543
|
+
config[:omnibus_dir] || super
|
|
544
|
+
end
|
|
545
|
+
|
|
546
|
+
def validate_components!
|
|
547
|
+
components.each do |component|
|
|
548
|
+
component.omnibus_root = omnibus_root
|
|
549
|
+
component.assert_present!
|
|
550
|
+
end
|
|
551
|
+
end
|
|
552
|
+
|
|
553
|
+
def components_to_test
|
|
554
|
+
if @components_filter.empty?
|
|
555
|
+
components
|
|
556
|
+
else
|
|
557
|
+
components.select do |component|
|
|
558
|
+
@components_filter.include?(component.name.to_s)
|
|
559
|
+
end
|
|
560
|
+
end
|
|
561
|
+
end
|
|
562
|
+
|
|
563
|
+
def invoke_tests
|
|
564
|
+
components_to_test.each do |component|
|
|
565
|
+
# Run the component specs in parallel
|
|
566
|
+
verification_threads << Thread.new do
|
|
567
|
+
|
|
568
|
+
results = []
|
|
569
|
+
|
|
570
|
+
results << component.run_smoke_test
|
|
571
|
+
|
|
572
|
+
if config[:unit]
|
|
573
|
+
results << component.run_unit_test
|
|
574
|
+
end
|
|
575
|
+
|
|
576
|
+
if config[:integration]
|
|
577
|
+
results << component.run_integration_test
|
|
578
|
+
end
|
|
579
|
+
|
|
580
|
+
if results.any? { |r| r.exitstatus != 0 }
|
|
581
|
+
component_status = 1
|
|
582
|
+
@verification_status = 1
|
|
583
|
+
else
|
|
584
|
+
component_status = 0
|
|
585
|
+
end
|
|
586
|
+
|
|
587
|
+
{
|
|
588
|
+
:component => component,
|
|
589
|
+
:results => results,
|
|
590
|
+
:component_status => component_status,
|
|
591
|
+
}
|
|
592
|
+
end
|
|
593
|
+
|
|
594
|
+
msg("Running verification for component '#{component.name}'")
|
|
595
|
+
end
|
|
596
|
+
end
|
|
597
|
+
|
|
598
|
+
def wait_for_tests
|
|
599
|
+
until verification_threads.empty?
|
|
600
|
+
verification_threads.each do |t|
|
|
601
|
+
if t.join(1)
|
|
602
|
+
verification_threads.delete t
|
|
603
|
+
verification_results << t.value
|
|
604
|
+
t.value[:results].each do |result|
|
|
605
|
+
if config[:verbose] || t.value[:component_status] != 0
|
|
606
|
+
msg("")
|
|
607
|
+
msg(result.stdout)
|
|
608
|
+
msg(result.stderr) if result.stderr
|
|
609
|
+
end
|
|
610
|
+
end
|
|
611
|
+
else
|
|
612
|
+
$stdout.write "."
|
|
613
|
+
end
|
|
614
|
+
end
|
|
615
|
+
end
|
|
616
|
+
end
|
|
617
|
+
|
|
618
|
+
def report_results
|
|
619
|
+
msg("")
|
|
620
|
+
msg("---------------------------------------------")
|
|
621
|
+
verification_results.each do |result|
|
|
622
|
+
message = result[:component_status] == 0 ? "succeeded" : "failed"
|
|
623
|
+
msg("Verification of component '#{result[:component].name}' #{message}.")
|
|
624
|
+
end
|
|
625
|
+
end
|
|
626
|
+
|
|
627
|
+
end
|
|
628
|
+
end
|
|
629
|
+
end
|