inspec-core 2.1.67
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/CHANGELOG.md +3136 -0
- data/Gemfile +56 -0
- data/LICENSE +14 -0
- data/MAINTAINERS.md +33 -0
- data/MAINTAINERS.toml +52 -0
- data/README.md +453 -0
- data/bin/inspec +12 -0
- data/docs/.gitignore +2 -0
- data/docs/README.md +40 -0
- data/docs/dev/control-eval.md +62 -0
- data/docs/dsl_inspec.md +258 -0
- data/docs/dsl_resource.md +100 -0
- data/docs/glossary.md +99 -0
- data/docs/habitat.md +192 -0
- data/docs/inspec_and_friends.md +114 -0
- data/docs/matchers.md +169 -0
- data/docs/migration.md +293 -0
- data/docs/platforms.md +119 -0
- data/docs/plugin_kitchen_inspec.md +50 -0
- data/docs/profiles.md +378 -0
- data/docs/reporters.md +105 -0
- data/docs/resources/aide_conf.md.erb +76 -0
- data/docs/resources/apache.md.erb +67 -0
- data/docs/resources/apache_conf.md.erb +68 -0
- data/docs/resources/apt.md.erb +71 -0
- data/docs/resources/audit_policy.md.erb +47 -0
- data/docs/resources/auditd.md.erb +79 -0
- data/docs/resources/auditd_conf.md.erb +68 -0
- data/docs/resources/bash.md.erb +75 -0
- data/docs/resources/bond.md.erb +90 -0
- data/docs/resources/bridge.md.erb +57 -0
- data/docs/resources/bsd_service.md.erb +67 -0
- data/docs/resources/chocolatey_package.md.erb +58 -0
- data/docs/resources/command.md.erb +138 -0
- data/docs/resources/cpan.md.erb +79 -0
- data/docs/resources/cran.md.erb +64 -0
- data/docs/resources/crontab.md.erb +89 -0
- data/docs/resources/csv.md.erb +54 -0
- data/docs/resources/dh_params.md.erb +205 -0
- data/docs/resources/directory.md.erb +30 -0
- data/docs/resources/docker.md.erb +219 -0
- data/docs/resources/docker_container.md.erb +103 -0
- data/docs/resources/docker_image.md.erb +94 -0
- data/docs/resources/docker_service.md.erb +114 -0
- data/docs/resources/elasticsearch.md.erb +242 -0
- data/docs/resources/etc_fstab.md.erb +125 -0
- data/docs/resources/etc_group.md.erb +75 -0
- data/docs/resources/etc_hosts.md.erb +78 -0
- data/docs/resources/etc_hosts_allow.md.erb +74 -0
- data/docs/resources/etc_hosts_deny.md.erb +74 -0
- data/docs/resources/file.md.erb +526 -0
- data/docs/resources/filesystem.md.erb +41 -0
- data/docs/resources/firewalld.md.erb +107 -0
- data/docs/resources/gem.md.erb +79 -0
- data/docs/resources/group.md.erb +61 -0
- data/docs/resources/grub_conf.md.erb +101 -0
- data/docs/resources/host.md.erb +86 -0
- data/docs/resources/http.md.erb +197 -0
- data/docs/resources/iis_app.md.erb +122 -0
- data/docs/resources/iis_site.md.erb +135 -0
- data/docs/resources/inetd_conf.md.erb +94 -0
- data/docs/resources/ini.md.erb +76 -0
- data/docs/resources/interface.md.erb +58 -0
- data/docs/resources/iptables.md.erb +64 -0
- data/docs/resources/json.md.erb +63 -0
- data/docs/resources/kernel_module.md.erb +120 -0
- data/docs/resources/kernel_parameter.md.erb +53 -0
- data/docs/resources/key_rsa.md.erb +85 -0
- data/docs/resources/launchd_service.md.erb +57 -0
- data/docs/resources/limits_conf.md.erb +75 -0
- data/docs/resources/login_defs.md.erb +71 -0
- data/docs/resources/mount.md.erb +69 -0
- data/docs/resources/mssql_session.md.erb +60 -0
- data/docs/resources/mysql_conf.md.erb +99 -0
- data/docs/resources/mysql_session.md.erb +74 -0
- data/docs/resources/nginx.md.erb +79 -0
- data/docs/resources/nginx_conf.md.erb +138 -0
- data/docs/resources/npm.md.erb +60 -0
- data/docs/resources/ntp_conf.md.erb +60 -0
- data/docs/resources/oneget.md.erb +53 -0
- data/docs/resources/oracledb_session.md.erb +52 -0
- data/docs/resources/os.md.erb +141 -0
- data/docs/resources/os_env.md.erb +91 -0
- data/docs/resources/package.md.erb +120 -0
- data/docs/resources/packages.md.erb +67 -0
- data/docs/resources/parse_config.md.erb +103 -0
- data/docs/resources/parse_config_file.md.erb +138 -0
- data/docs/resources/passwd.md.erb +141 -0
- data/docs/resources/pip.md.erb +67 -0
- data/docs/resources/port.md.erb +137 -0
- data/docs/resources/postgres_conf.md.erb +79 -0
- data/docs/resources/postgres_hba_conf.md.erb +93 -0
- data/docs/resources/postgres_ident_conf.md.erb +76 -0
- data/docs/resources/postgres_session.md.erb +69 -0
- data/docs/resources/powershell.md.erb +102 -0
- data/docs/resources/processes.md.erb +109 -0
- data/docs/resources/rabbitmq_config.md.erb +41 -0
- data/docs/resources/registry_key.md.erb +158 -0
- data/docs/resources/runit_service.md.erb +57 -0
- data/docs/resources/security_policy.md.erb +47 -0
- data/docs/resources/service.md.erb +121 -0
- data/docs/resources/shadow.md.erb +146 -0
- data/docs/resources/ssh_config.md.erb +73 -0
- data/docs/resources/sshd_config.md.erb +83 -0
- data/docs/resources/ssl.md.erb +119 -0
- data/docs/resources/sys_info.md.erb +42 -0
- data/docs/resources/systemd_service.md.erb +57 -0
- data/docs/resources/sysv_service.md.erb +57 -0
- data/docs/resources/upstart_service.md.erb +57 -0
- data/docs/resources/user.md.erb +140 -0
- data/docs/resources/users.md.erb +127 -0
- data/docs/resources/vbscript.md.erb +55 -0
- data/docs/resources/virtualization.md.erb +57 -0
- data/docs/resources/windows_feature.md.erb +47 -0
- data/docs/resources/windows_hotfix.md.erb +53 -0
- data/docs/resources/windows_task.md.erb +95 -0
- data/docs/resources/wmi.md.erb +81 -0
- data/docs/resources/x509_certificate.md.erb +151 -0
- data/docs/resources/xinetd_conf.md.erb +156 -0
- data/docs/resources/xml.md.erb +85 -0
- data/docs/resources/yaml.md.erb +69 -0
- data/docs/resources/yum.md.erb +98 -0
- data/docs/resources/zfs_dataset.md.erb +53 -0
- data/docs/resources/zfs_pool.md.erb +47 -0
- data/docs/ruby_usage.md +203 -0
- data/docs/shared/matcher_be.md.erb +1 -0
- data/docs/shared/matcher_cmp.md.erb +43 -0
- data/docs/shared/matcher_eq.md.erb +3 -0
- data/docs/shared/matcher_include.md.erb +1 -0
- data/docs/shared/matcher_match.md.erb +1 -0
- data/docs/shell.md +217 -0
- data/examples/README.md +8 -0
- data/examples/inheritance/README.md +65 -0
- data/examples/inheritance/controls/example.rb +14 -0
- data/examples/inheritance/inspec.yml +15 -0
- data/examples/kitchen-ansible/.kitchen.yml +25 -0
- data/examples/kitchen-ansible/Gemfile +19 -0
- data/examples/kitchen-ansible/README.md +53 -0
- data/examples/kitchen-ansible/files/nginx.repo +6 -0
- data/examples/kitchen-ansible/tasks/main.yml +16 -0
- data/examples/kitchen-ansible/test/integration/default/default.yml +5 -0
- data/examples/kitchen-ansible/test/integration/default/web_spec.rb +28 -0
- data/examples/kitchen-chef/.kitchen.yml +20 -0
- data/examples/kitchen-chef/Berksfile +3 -0
- data/examples/kitchen-chef/Gemfile +19 -0
- data/examples/kitchen-chef/README.md +27 -0
- data/examples/kitchen-chef/metadata.rb +7 -0
- data/examples/kitchen-chef/recipes/default.rb +6 -0
- data/examples/kitchen-chef/recipes/nginx.rb +30 -0
- data/examples/kitchen-chef/test/integration/default/web_spec.rb +28 -0
- data/examples/kitchen-puppet/.kitchen.yml +23 -0
- data/examples/kitchen-puppet/Gemfile +20 -0
- data/examples/kitchen-puppet/Puppetfile +25 -0
- data/examples/kitchen-puppet/README.md +53 -0
- data/examples/kitchen-puppet/manifests/site.pp +33 -0
- data/examples/kitchen-puppet/metadata.json +11 -0
- data/examples/kitchen-puppet/modules/.gitkeep +0 -0
- data/examples/kitchen-puppet/test/integration/default/web_spec.rb +28 -0
- data/examples/meta-profile/README.md +37 -0
- data/examples/meta-profile/controls/example.rb +13 -0
- data/examples/meta-profile/inspec.yml +13 -0
- data/examples/profile-attribute.yml +2 -0
- data/examples/profile-attribute/README.md +14 -0
- data/examples/profile-attribute/controls/example.rb +11 -0
- data/examples/profile-attribute/inspec.yml +8 -0
- data/examples/profile-sensitive/README.md +29 -0
- data/examples/profile-sensitive/controls/sensitive-failures.rb +9 -0
- data/examples/profile-sensitive/controls/sensitive.rb +9 -0
- data/examples/profile-sensitive/inspec.yml +8 -0
- data/examples/profile/README.md +48 -0
- data/examples/profile/controls/example.rb +23 -0
- data/examples/profile/controls/gordon.rb +36 -0
- data/examples/profile/controls/meta.rb +34 -0
- data/examples/profile/inspec.yml +10 -0
- data/examples/profile/libraries/gordon_config.rb +59 -0
- data/inspec-core.gemspec +43 -0
- data/lib/bundles/README.md +3 -0
- data/lib/bundles/inspec-artifact.rb +7 -0
- data/lib/bundles/inspec-artifact/README.md +1 -0
- data/lib/bundles/inspec-artifact/cli.rb +277 -0
- data/lib/bundles/inspec-compliance.rb +16 -0
- data/lib/bundles/inspec-compliance/.kitchen.yml +20 -0
- data/lib/bundles/inspec-compliance/README.md +193 -0
- data/lib/bundles/inspec-compliance/api.rb +360 -0
- data/lib/bundles/inspec-compliance/api/login.rb +193 -0
- data/lib/bundles/inspec-compliance/bootstrap.sh +41 -0
- data/lib/bundles/inspec-compliance/cli.rb +260 -0
- data/lib/bundles/inspec-compliance/configuration.rb +103 -0
- data/lib/bundles/inspec-compliance/http.rb +125 -0
- data/lib/bundles/inspec-compliance/images/cc-token.png +0 -0
- data/lib/bundles/inspec-compliance/support.rb +36 -0
- data/lib/bundles/inspec-compliance/target.rb +106 -0
- data/lib/bundles/inspec-compliance/test/integration/default/cli.rb +93 -0
- data/lib/bundles/inspec-habitat.rb +12 -0
- data/lib/bundles/inspec-habitat/cli.rb +36 -0
- data/lib/bundles/inspec-habitat/log.rb +10 -0
- data/lib/bundles/inspec-habitat/profile.rb +391 -0
- data/lib/bundles/inspec-init.rb +8 -0
- data/lib/bundles/inspec-init/README.md +31 -0
- data/lib/bundles/inspec-init/cli.rb +97 -0
- data/lib/bundles/inspec-init/templates/profile/README.md +3 -0
- data/lib/bundles/inspec-init/templates/profile/controls/example.rb +19 -0
- data/lib/bundles/inspec-init/templates/profile/inspec.yml +8 -0
- data/lib/bundles/inspec-init/templates/profile/libraries/.gitkeep +0 -0
- data/lib/bundles/inspec-supermarket.rb +13 -0
- data/lib/bundles/inspec-supermarket/README.md +45 -0
- data/lib/bundles/inspec-supermarket/api.rb +84 -0
- data/lib/bundles/inspec-supermarket/cli.rb +73 -0
- data/lib/bundles/inspec-supermarket/target.rb +34 -0
- data/lib/fetchers/git.rb +163 -0
- data/lib/fetchers/local.rb +74 -0
- data/lib/fetchers/mock.rb +35 -0
- data/lib/fetchers/url.rb +247 -0
- data/lib/inspec.rb +24 -0
- data/lib/inspec/archive/tar.rb +29 -0
- data/lib/inspec/archive/zip.rb +19 -0
- data/lib/inspec/backend.rb +93 -0
- data/lib/inspec/base_cli.rb +368 -0
- data/lib/inspec/cached_fetcher.rb +66 -0
- data/lib/inspec/cli.rb +292 -0
- data/lib/inspec/completions/bash.sh.erb +45 -0
- data/lib/inspec/completions/fish.sh.erb +34 -0
- data/lib/inspec/completions/zsh.sh.erb +61 -0
- data/lib/inspec/control_eval_context.rb +179 -0
- data/lib/inspec/dependencies/cache.rb +72 -0
- data/lib/inspec/dependencies/dependency_set.rb +92 -0
- data/lib/inspec/dependencies/lockfile.rb +115 -0
- data/lib/inspec/dependencies/requirement.rb +123 -0
- data/lib/inspec/dependencies/resolver.rb +86 -0
- data/lib/inspec/describe.rb +27 -0
- data/lib/inspec/dsl.rb +66 -0
- data/lib/inspec/dsl_shared.rb +33 -0
- data/lib/inspec/env_printer.rb +157 -0
- data/lib/inspec/errors.rb +14 -0
- data/lib/inspec/exceptions.rb +12 -0
- data/lib/inspec/expect.rb +45 -0
- data/lib/inspec/fetcher.rb +45 -0
- data/lib/inspec/file_provider.rb +275 -0
- data/lib/inspec/formatters.rb +3 -0
- data/lib/inspec/formatters/base.rb +259 -0
- data/lib/inspec/formatters/json_rspec.rb +20 -0
- data/lib/inspec/formatters/show_progress.rb +12 -0
- data/lib/inspec/library_eval_context.rb +58 -0
- data/lib/inspec/log.rb +11 -0
- data/lib/inspec/metadata.rb +247 -0
- data/lib/inspec/method_source.rb +24 -0
- data/lib/inspec/objects.rb +14 -0
- data/lib/inspec/objects/attribute.rb +75 -0
- data/lib/inspec/objects/control.rb +61 -0
- data/lib/inspec/objects/describe.rb +92 -0
- data/lib/inspec/objects/each_loop.rb +36 -0
- data/lib/inspec/objects/list.rb +15 -0
- data/lib/inspec/objects/or_test.rb +40 -0
- data/lib/inspec/objects/ruby_helper.rb +15 -0
- data/lib/inspec/objects/tag.rb +27 -0
- data/lib/inspec/objects/test.rb +87 -0
- data/lib/inspec/objects/value.rb +27 -0
- data/lib/inspec/plugins.rb +60 -0
- data/lib/inspec/plugins/cli.rb +24 -0
- data/lib/inspec/plugins/fetcher.rb +86 -0
- data/lib/inspec/plugins/resource.rb +135 -0
- data/lib/inspec/plugins/secret.rb +15 -0
- data/lib/inspec/plugins/source_reader.rb +40 -0
- data/lib/inspec/polyfill.rb +12 -0
- data/lib/inspec/profile.rb +513 -0
- data/lib/inspec/profile_context.rb +208 -0
- data/lib/inspec/profile_vendor.rb +66 -0
- data/lib/inspec/reporters.rb +60 -0
- data/lib/inspec/reporters/automate.rb +76 -0
- data/lib/inspec/reporters/base.rb +25 -0
- data/lib/inspec/reporters/cli.rb +356 -0
- data/lib/inspec/reporters/json.rb +116 -0
- data/lib/inspec/reporters/json_min.rb +48 -0
- data/lib/inspec/reporters/junit.rb +78 -0
- data/lib/inspec/require_loader.rb +33 -0
- data/lib/inspec/resource.rb +190 -0
- data/lib/inspec/rule.rb +280 -0
- data/lib/inspec/runner.rb +345 -0
- data/lib/inspec/runner_mock.rb +41 -0
- data/lib/inspec/runner_rspec.rb +175 -0
- data/lib/inspec/runtime_profile.rb +26 -0
- data/lib/inspec/schema.rb +213 -0
- data/lib/inspec/secrets.rb +19 -0
- data/lib/inspec/secrets/yaml.rb +30 -0
- data/lib/inspec/shell.rb +220 -0
- data/lib/inspec/shell_detector.rb +90 -0
- data/lib/inspec/source_reader.rb +29 -0
- data/lib/inspec/version.rb +8 -0
- data/lib/matchers/matchers.rb +339 -0
- data/lib/resources/aide_conf.rb +151 -0
- data/lib/resources/apache.rb +48 -0
- data/lib/resources/apache_conf.rb +149 -0
- data/lib/resources/apt.rb +149 -0
- data/lib/resources/audit_policy.rb +63 -0
- data/lib/resources/auditd.rb +231 -0
- data/lib/resources/auditd_conf.rb +46 -0
- data/lib/resources/bash.rb +35 -0
- data/lib/resources/bond.rb +69 -0
- data/lib/resources/bridge.rb +122 -0
- data/lib/resources/chocolatey_package.rb +78 -0
- data/lib/resources/command.rb +73 -0
- data/lib/resources/cpan.rb +58 -0
- data/lib/resources/cran.rb +64 -0
- data/lib/resources/crontab.rb +169 -0
- data/lib/resources/csv.rb +56 -0
- data/lib/resources/dh_params.rb +77 -0
- data/lib/resources/directory.rb +25 -0
- data/lib/resources/docker.rb +236 -0
- data/lib/resources/docker_container.rb +89 -0
- data/lib/resources/docker_image.rb +83 -0
- data/lib/resources/docker_object.rb +57 -0
- data/lib/resources/docker_service.rb +90 -0
- data/lib/resources/elasticsearch.rb +169 -0
- data/lib/resources/etc_fstab.rb +94 -0
- data/lib/resources/etc_group.rb +154 -0
- data/lib/resources/etc_hosts.rb +66 -0
- data/lib/resources/etc_hosts_allow_deny.rb +112 -0
- data/lib/resources/file.rb +298 -0
- data/lib/resources/filesystem.rb +31 -0
- data/lib/resources/firewalld.rb +143 -0
- data/lib/resources/gem.rb +70 -0
- data/lib/resources/groups.rb +215 -0
- data/lib/resources/grub_conf.rb +227 -0
- data/lib/resources/host.rb +306 -0
- data/lib/resources/http.rb +253 -0
- data/lib/resources/iis_app.rb +101 -0
- data/lib/resources/iis_site.rb +148 -0
- data/lib/resources/inetd_conf.rb +54 -0
- data/lib/resources/ini.rb +29 -0
- data/lib/resources/interface.rb +129 -0
- data/lib/resources/iptables.rb +80 -0
- data/lib/resources/json.rb +111 -0
- data/lib/resources/kernel_module.rb +107 -0
- data/lib/resources/kernel_parameter.rb +58 -0
- data/lib/resources/key_rsa.rb +63 -0
- data/lib/resources/limits_conf.rb +46 -0
- data/lib/resources/login_def.rb +57 -0
- data/lib/resources/mount.rb +88 -0
- data/lib/resources/mssql_session.rb +101 -0
- data/lib/resources/mysql.rb +82 -0
- data/lib/resources/mysql_conf.rb +127 -0
- data/lib/resources/mysql_session.rb +85 -0
- data/lib/resources/nginx.rb +96 -0
- data/lib/resources/nginx_conf.rb +226 -0
- data/lib/resources/npm.rb +48 -0
- data/lib/resources/ntp_conf.rb +51 -0
- data/lib/resources/oneget.rb +71 -0
- data/lib/resources/oracledb_session.rb +139 -0
- data/lib/resources/os.rb +36 -0
- data/lib/resources/os_env.rb +86 -0
- data/lib/resources/package.rb +370 -0
- data/lib/resources/packages.rb +111 -0
- data/lib/resources/parse_config.rb +112 -0
- data/lib/resources/passwd.rb +76 -0
- data/lib/resources/pip.rb +130 -0
- data/lib/resources/platform.rb +109 -0
- data/lib/resources/port.rb +771 -0
- data/lib/resources/postgres.rb +131 -0
- data/lib/resources/postgres_conf.rb +114 -0
- data/lib/resources/postgres_hba_conf.rb +90 -0
- data/lib/resources/postgres_ident_conf.rb +79 -0
- data/lib/resources/postgres_session.rb +71 -0
- data/lib/resources/powershell.rb +67 -0
- data/lib/resources/processes.rb +204 -0
- data/lib/resources/rabbitmq_conf.rb +51 -0
- data/lib/resources/registry_key.rb +297 -0
- data/lib/resources/security_policy.rb +180 -0
- data/lib/resources/service.rb +794 -0
- data/lib/resources/shadow.rb +159 -0
- data/lib/resources/ssh_conf.rb +97 -0
- data/lib/resources/ssl.rb +99 -0
- data/lib/resources/sys_info.rb +28 -0
- data/lib/resources/toml.rb +32 -0
- data/lib/resources/users.rb +654 -0
- data/lib/resources/vbscript.rb +68 -0
- data/lib/resources/virtualization.rb +247 -0
- data/lib/resources/windows_feature.rb +84 -0
- data/lib/resources/windows_hotfix.rb +35 -0
- data/lib/resources/windows_task.rb +102 -0
- data/lib/resources/wmi.rb +110 -0
- data/lib/resources/x509_certificate.rb +137 -0
- data/lib/resources/xinetd.rb +106 -0
- data/lib/resources/xml.rb +46 -0
- data/lib/resources/yaml.rb +43 -0
- data/lib/resources/yum.rb +180 -0
- data/lib/resources/zfs_dataset.rb +60 -0
- data/lib/resources/zfs_pool.rb +49 -0
- data/lib/source_readers/flat.rb +39 -0
- data/lib/source_readers/inspec.rb +75 -0
- data/lib/utils/command_wrapper.rb +27 -0
- data/lib/utils/convert.rb +12 -0
- data/lib/utils/database_helpers.rb +77 -0
- data/lib/utils/enumerable_delegation.rb +9 -0
- data/lib/utils/erlang_parser.rb +192 -0
- data/lib/utils/file_reader.rb +25 -0
- data/lib/utils/filter.rb +273 -0
- data/lib/utils/filter_array.rb +27 -0
- data/lib/utils/find_files.rb +47 -0
- data/lib/utils/hash.rb +41 -0
- data/lib/utils/json_log.rb +18 -0
- data/lib/utils/latest_version.rb +22 -0
- data/lib/utils/modulator.rb +12 -0
- data/lib/utils/nginx_parser.rb +105 -0
- data/lib/utils/object_traversal.rb +49 -0
- data/lib/utils/parser.rb +274 -0
- data/lib/utils/pkey_reader.rb +15 -0
- data/lib/utils/plugin_registry.rb +93 -0
- data/lib/utils/simpleconfig.rb +120 -0
- data/lib/utils/spdx.rb +13 -0
- data/lib/utils/spdx.txt +344 -0
- metadata +713 -0
data/docs/migration.md
ADDED
@@ -0,0 +1,293 @@
|
|
1
|
+
---
|
2
|
+
title: InSpec Migration Guide
|
3
|
+
---
|
4
|
+
|
5
|
+
# Migrate from Serverspec to InSpec
|
6
|
+
|
7
|
+
## How is InSpec different from Serverspec
|
8
|
+
|
9
|
+
We've written a complete blog post about that topic: [The Road to InSpec](https://blog.chef.io/2015/11/04/the-road-to-inspec/)
|
10
|
+
|
11
|
+
## Is InSpec suitable for infrastructure testing?
|
12
|
+
|
13
|
+
InSpec is a framework that allows you to run infrastructure testing as well as compliance testing. The compliance features are always optional and provide customers a way to use InSpec for both use-cases. To ensure we build the best infrastructure testing, we migrate our cookbooks [chef-cookbooks](https://github.com/chef-cookbooks) to InSpec.
|
14
|
+
|
15
|
+
## Which Serverspec resources are available in InSpec?
|
16
|
+
|
17
|
+
The following resources are available in InSpec:
|
18
|
+
|
19
|
+
| Serverspec | InSpec |
|
20
|
+
|:------------------------------------------------------------------------------------------:|:------------------------------------------------------------------------------------:|
|
21
|
+
| [`bond`](http://serverspec.org/resource_types.html#bond) | [`bond`](https://www.inspec.io/docs/reference/resources/bond/) |
|
22
|
+
| [`bridge`](http://serverspec.org/resource_types.html#bridge) | [`bridge`](https://www.inspec.io/docs/reference/resources/bridge/) |
|
23
|
+
| [`command`](http://serverspec.org/resource_types.html#command) | [`command`](https://www.inspec.io/docs/reference/resources/command/) |
|
24
|
+
| [`cron`](http://serverspec.org/resource_types.html#cron) | [`crontab`](https://www.inspec.io/docs/reference/resources/crontab/) |
|
25
|
+
| [`docker_container`](http://serverspec.org/resource_types.html#docker_container) | [`docker_container`](https://www.inspec.io/docs/reference/resources/docker_container/) |
|
26
|
+
| [`docker_image`](http://serverspec.org/resource_types.html#docker_image) | [`docker_image`](https://www.inspec.io/docs/reference/resources/docker_image/) |
|
27
|
+
| [`file`](http://serverspec.org/resource_types.html#file) | [`file`](https://www.inspec.io/docs/reference/resources/file/) |
|
28
|
+
| [`group`](http://serverspec.org/resource_types.html#group) | [`group`](https://www.inspec.io/docs/reference/resources/group/) |
|
29
|
+
| [`host`](http://serverspec.org/resource_types.html#host) | [`host`](https://www.inspec.io/docs/reference/resources/host/) |
|
30
|
+
| [`interface`](http://serverspec.org/resource_types.html#interface) | [`interface`](https://www.inspec.io/docs/reference/resources/interface/) |
|
31
|
+
| [`iis_website`](http://serverspec.org/resource_types.html#iis_website) | [`iis_website`](https://www.inspec.io/docs/reference/resources/iis_website/) |
|
32
|
+
| [`iis_app_pool`](http://serverspec.org/resource_types.html#iis_app_pool) | [`iis_website`](https://www.inspec.io/docs/reference/resources/iis_website/) |
|
33
|
+
| [`iptables`](http://serverspec.org/resource_types.html#iptables) | [`iptables`](https://www.inspec.io/docs/reference/resources/iptables/) |
|
34
|
+
| [`kernel_module`](http://serverspec.org/resource_types.html#kernel_module) | [`kernel_module`](https://www.inspec.io/docs/reference/resources/kernel_module/) |
|
35
|
+
| [`linux_kernel_parameter`](http://serverspec.org/resource_types.html#linux_kernel_parameter) | [`kernel_parameter`](https://www.inspec.io/docs/reference/resources/kernel_parameter/) |
|
36
|
+
| [`mysql_config`](http://serverspec.org/resource_types.html#mysql_config) | [`mysql_conf`](https://www.inspec.io/docs/reference/resources/mysql_conf/) |
|
37
|
+
| [`package`](http://serverspec.org/resource_types.html#package) | [`package`](https://www.inspec.io/docs/reference/resources/package/) |
|
38
|
+
| [`port`](http://serverspec.org/resource_types.html#port) | [`port`](https://www.inspec.io/docs/reference/resources/port/) |
|
39
|
+
| [`ppa`](http://serverspec.org/resource_types.html#ppa) | [`apt`](https://www.inspec.io/docs/reference/resources/apt/) |
|
40
|
+
| [`process`](http://serverspec.org/resource_types.html#process) | [`processes`](https://www.inspec.io/docs/reference/resources/processes/) |
|
41
|
+
| [`service`](http://serverspec.org/resource_types.html#service) | [`service`](https://www.inspec.io/docs/reference/resources/service/) |
|
42
|
+
| [`user`](http://serverspec.org/resource_types.html#user) | [`user`](https://www.inspec.io/docs/reference/resources/user/) |
|
43
|
+
| [`windows_feature`](http://serverspec.org/resource_types.html#windows_feature) | [`windows_feature`](https://www.inspec.io/docs/reference/resources/windows_feature/) |
|
44
|
+
| [`windows_registry_key`](http://serverspec.org/resource_types.html#windows_registry_key) | [`registry_key`](https://www.inspec.io/docs/reference/resources/registry_key/) |
|
45
|
+
| [`x509_certificate`](http://serverspec.org/resource_types.html#x509_certificate) | [`x509_certificate`](https://www.inspec.io/docs/reference/resources/x509_certificate/) |
|
46
|
+
| [`yumrepo`](http://serverspec.org/resource_types.html#yumrepo) | [`yum`](https://www.inspec.io/docs/reference/resources/yum/) |
|
47
|
+
| [`zfs`](http://serverspec.org/resource_types.html#zfs) | [`zfs_pool`](https://www.inspec.io/docs/reference/resources/zfs_pool/) |
|
48
|
+
|
49
|
+
Some Serverspec resources are not available yet. We will implement those resources based on user feedback. If you need a resource that is not available in InSpec, please open an [Github issue](https://github.com/chef/inspec/issues). The list of resources that are not available in InSpec:
|
50
|
+
|
51
|
+
* [`cgroup`](http://serverspec.org/resource_types.html#cgroup)
|
52
|
+
* [`default_gateway`](http://serverspec.org/resource_types.html#default_gateway)
|
53
|
+
* [`ip6tables`](http://serverspec.org/resource_types.html#ip6tables)
|
54
|
+
* [`ipfilter`](http://serverspec.org/resource_types.html#ipfilter)
|
55
|
+
* [`ipnat`](http://serverspec.org/resource_types.html#ipnat)
|
56
|
+
* [`linux_audit_system`](http://serverspec.org/resource_types.html#linux_audit_system)
|
57
|
+
* [`lxc`](http://serverspec.org/resource_types.html#lxc)
|
58
|
+
* [`mail_alias`](http://serverspec.org/resource_types.html#mail_alias)
|
59
|
+
* [`php_config`](http://serverspec.org/resource_types.html#php_config)
|
60
|
+
* [`routing_table`](http://serverspec.org/resource_types.html#routing_table)
|
61
|
+
* [`selinux`](http://serverspec.org/resource_types.html#selinux)
|
62
|
+
* [`selinux_module`](http://serverspec.org/resource_types.html#selinux_module)
|
63
|
+
* [`x509_private_key`](http://serverspec.org/resource_types.html#x509_private_key)
|
64
|
+
|
65
|
+
In addition InSpec provides additional [resources](https://www.inspec.io/docs/reference/resources/) that are not available in Serverspec:
|
66
|
+
|
67
|
+
* [`apache_conf`](https://www.inspec.io/docs/reference/resources/apache_conf/)
|
68
|
+
* [`apt`](https://www.inspec.io/docs/reference/resources/apt/)
|
69
|
+
* [`audit_policy`](https://www.inspec.io/docs/reference/resources/audit_policy/)
|
70
|
+
* [`auditd_conf`](https://www.inspec.io/docs/reference/resources/auditd_conf/)
|
71
|
+
* [`bash`](https://www.inspec.io/docs/reference/resources/bash/)
|
72
|
+
* [`csv`](https://www.inspec.io/docs/reference/resources/csv/)
|
73
|
+
* [`etc_shadow`](https://www.inspec.io/docs/reference/resources/etc_shadow/)
|
74
|
+
* [`gem`](https://www.inspec.io/docs/reference/resources/gem/)
|
75
|
+
* [`grub_conf`](https://www.inspec.io/docs/reference/resources/grub_conf/)
|
76
|
+
* [`inetd_conf`](https://www.inspec.io/docs/reference/resources/inetd_conf/)
|
77
|
+
* [`ini`](https://www.inspec.io/docs/reference/resources/ini/)
|
78
|
+
* [`json`](https://www.inspec.io/docs/reference/resources/json/)
|
79
|
+
* [`npm`](https://www.inspec.io/docs/reference/resources/npm/)
|
80
|
+
* [`ntp_conf`](https://www.inspec.io/docs/reference/resources/ntp_conf/)
|
81
|
+
* [`oneget`](https://www.inspec.io/docs/reference/resources/oneget/)
|
82
|
+
* [`pip`](https://www.inspec.io/docs/reference/resources/pip/)
|
83
|
+
* [`powershell`](https://www.inspec.io/docs/reference/resources/powershell/)
|
84
|
+
* [`security_policy`](https://www.inspec.io/docs/reference/resources/security_policy/)
|
85
|
+
* [`ssh_config`](https://www.inspec.io/docs/reference/resources/ssh_config/)
|
86
|
+
* [`sshd_config`](https://www.inspec.io/docs/reference/resources/sshd_config/)
|
87
|
+
* [`sys_info`](https://www.inspec.io/docs/reference/resources/sys_info/)
|
88
|
+
|
89
|
+
## How do I migrate my Serverspec tests to InSpec
|
90
|
+
|
91
|
+
For most cases, the migration to InSpec is pretty straight forward. First, replace the current verifier in `kitchen.yml` configuration with:
|
92
|
+
|
93
|
+
```
|
94
|
+
verifier:
|
95
|
+
name: inspec
|
96
|
+
```
|
97
|
+
|
98
|
+
Second, rename the directory `test/integration/default/serverspec` to
|
99
|
+
`test/integration/default/inspec`
|
100
|
+
|
101
|
+
Third, remove the Serverspec-specific code from the test files.
|
102
|
+
|
103
|
+
```
|
104
|
+
require 'serverspec'
|
105
|
+
|
106
|
+
# Required by serverspec
|
107
|
+
set :backend, :exec
|
108
|
+
```
|
109
|
+
|
110
|
+
InSpec is now configured with Test-Kitchen:
|
111
|
+
|
112
|
+
```
|
113
|
+
kitchen verify package-install-centos-72
|
114
|
+
-----> Starting Kitchen (v1.14.2)
|
115
|
+
-----> Verifying <package-install-centos-72>...
|
116
|
+
Detected alternative framework tests for `inspec`
|
117
|
+
Loaded
|
118
|
+
|
119
|
+
Target: ssh://vagrant@127.0.0.1:2200
|
120
|
+
|
121
|
+
|
122
|
+
PHP has
|
123
|
+
✔ php
|
124
|
+
✔ the pear.php.net channel
|
125
|
+
✔ the pecl.php.net channel
|
126
|
+
|
127
|
+
Test Summary: 3 successful, 0 failures, 0 skipped
|
128
|
+
Finished verifying <package-install-centos-72> (0m0.40s).
|
129
|
+
-----> Kitchen is finished. (0m3.31s)
|
130
|
+
```
|
131
|
+
|
132
|
+
Some real-world migrations are available:
|
133
|
+
|
134
|
+
* [docker](https://github.com/chef-cookbooks/docker)
|
135
|
+
* [nginx](https://github.com/chef-cookbooks/chef_nginx/pull/5/files)
|
136
|
+
* [mysql](https://github.com/chef-cookbooks/mysql/pull/430/files)
|
137
|
+
* [php](https://github.com/chef-cookbooks/php/pull/189/files)
|
138
|
+
|
139
|
+
Some general recommendations:
|
140
|
+
|
141
|
+
* use test-kitchen 1.14+
|
142
|
+
* in case of errors, increase the log level `kitchen verify package-install-centos-72 -l debug`
|
143
|
+
|
144
|
+
## Do I still need the backend configuration?
|
145
|
+
|
146
|
+
InSpec does not attach backend information to test files. All tests are defined independently of any backend. Therefore a Serverspec test file:
|
147
|
+
|
148
|
+
```
|
149
|
+
require 'serverspec'
|
150
|
+
|
151
|
+
# Required by serverspec
|
152
|
+
set :backend, :exec
|
153
|
+
|
154
|
+
describe 'PHP' do
|
155
|
+
it 'has php' do
|
156
|
+
expect(command('php -v').exit_status).to eq(0)
|
157
|
+
end
|
158
|
+
|
159
|
+
it 'has the pear.php.net channel' do
|
160
|
+
expect(command('pear list-channels').stdout).to include('pear.php.net')
|
161
|
+
end
|
162
|
+
|
163
|
+
it 'has the pecl.php.net channel' do
|
164
|
+
expect(command('pear list-channels').stdout).to include('pecl.php.net')
|
165
|
+
end
|
166
|
+
end
|
167
|
+
```
|
168
|
+
|
169
|
+
will become the following InSpec test file:
|
170
|
+
|
171
|
+
```
|
172
|
+
describe 'PHP' do
|
173
|
+
it 'has php' do
|
174
|
+
expect(command('php -v').exit_status).to eq(0)
|
175
|
+
end
|
176
|
+
|
177
|
+
it 'has the pear.php.net channel' do
|
178
|
+
expect(command('pear list-channels').stdout).to include('pear.php.net')
|
179
|
+
end
|
180
|
+
|
181
|
+
it 'has the pecl.php.net channel' do
|
182
|
+
expect(command('pear list-channels').stdout).to include('pecl.php.net')
|
183
|
+
end
|
184
|
+
end
|
185
|
+
```
|
186
|
+
|
187
|
+
As you can see, the InSpec test files just focuses on tests and tries to avoid all clutter.
|
188
|
+
|
189
|
+
## Nested describe blocks
|
190
|
+
|
191
|
+
Serverspec and RSpec allow you to define nested describe blocks. We did a survey and found out that most users use nested describe blocks only to improve their output report. We believe the code structure should not change to improve the output of a report. Nevertheless we understand that nested describe blocks help you to structure test code. A sample code block looks like:
|
192
|
+
|
193
|
+
```
|
194
|
+
describe 'chef-server-directories' do
|
195
|
+
describe file('/etc/opscode') do
|
196
|
+
it { should be_directory }
|
197
|
+
it { should be_owned_by 'root' }
|
198
|
+
end
|
199
|
+
|
200
|
+
describe file('/etc/opscode-analytics') do
|
201
|
+
it { should be_directory }
|
202
|
+
it { should be_owned_by 'opscode' }
|
203
|
+
it { should be_grouped_into 'opscode' }
|
204
|
+
end
|
205
|
+
|
206
|
+
describe file('/var/log/opscode') do
|
207
|
+
it { should be_directory }
|
208
|
+
it { should be_owned_by 'opscode' }
|
209
|
+
it { should be_grouped_into 'opscode' }
|
210
|
+
end
|
211
|
+
|
212
|
+
describe file('/var/opt/opscode') do
|
213
|
+
it { should be_directory }
|
214
|
+
it { should be_owned_by 'root' }
|
215
|
+
end
|
216
|
+
end
|
217
|
+
```
|
218
|
+
|
219
|
+
In InSpec you would split up groups into files.
|
220
|
+
|
221
|
+
```
|
222
|
+
tests
|
223
|
+
├── server-directories.rb
|
224
|
+
├── other-tests.rb
|
225
|
+
└── further-tests.rb
|
226
|
+
```
|
227
|
+
|
228
|
+
Each file can have a top-level description of its content:
|
229
|
+
|
230
|
+
```
|
231
|
+
title "Chef Server Directories"
|
232
|
+
|
233
|
+
describe file('/etc/opscode') do
|
234
|
+
it { should be_directory }
|
235
|
+
it { should be_owned_by 'root' }
|
236
|
+
end
|
237
|
+
|
238
|
+
describe file('/etc/opscode-analytics') do
|
239
|
+
it { should be_directory }
|
240
|
+
it { should be_owned_by 'opscode' }
|
241
|
+
it { should be_grouped_into 'opscode' }
|
242
|
+
end
|
243
|
+
|
244
|
+
describe file('/var/log/opscode') do
|
245
|
+
it { should be_directory }
|
246
|
+
it { should be_owned_by 'opscode' }
|
247
|
+
it { should be_grouped_into 'opscode' }
|
248
|
+
end
|
249
|
+
|
250
|
+
describe file('/var/opt/opscode') do
|
251
|
+
it { should be_directory }
|
252
|
+
it { should be_owned_by 'root' }
|
253
|
+
end
|
254
|
+
|
255
|
+
```
|
256
|
+
|
257
|
+
## Are you supporting the `expect` syntax?
|
258
|
+
|
259
|
+
Of course. We still prefer the `should` syntax for UX reasons. We did surveys with various types of customers like devops engineers, auditors, managers. All participants who preferred the `expect` syntax have been Ruby experts. All non-Ruby developers found it easier to understand the `should` syntax.
|
260
|
+
|
261
|
+
### `should` syntax with InSpec
|
262
|
+
|
263
|
+
```
|
264
|
+
describe command('php -v') do
|
265
|
+
its('exit_status') { should eq 0 }
|
266
|
+
end
|
267
|
+
|
268
|
+
describe command('pear list-channels') do
|
269
|
+
its('stdout') { should include('pear.php.net')}
|
270
|
+
end
|
271
|
+
|
272
|
+
describe command('pear list-channels') do
|
273
|
+
its('stdout') { should include('pecl.php.net')}
|
274
|
+
end
|
275
|
+
```
|
276
|
+
|
277
|
+
### `expect` syntax with InSpec
|
278
|
+
|
279
|
+
```
|
280
|
+
describe 'PHP' do
|
281
|
+
it 'has php' do
|
282
|
+
expect(command('php -v').exit_status).to eq(0)
|
283
|
+
end
|
284
|
+
|
285
|
+
it 'has the pear.php.net channel' do
|
286
|
+
expect(command('pear list-channels').stdout).to include('pear.php.net')
|
287
|
+
end
|
288
|
+
|
289
|
+
it 'has the pecl.php.net channel' do
|
290
|
+
expect(command('pear list-channels').stdout).to include('pecl.php.net')
|
291
|
+
end
|
292
|
+
end
|
293
|
+
```
|
data/docs/platforms.md
ADDED
@@ -0,0 +1,119 @@
|
|
1
|
+
# Using InSpec 2.0 on Cloud Platforms
|
2
|
+
|
3
|
+
We are pleased to announce that with this release of InSpec 2.0, we have expanded our platform support beyond individual machines and now include support for select AWS and Azure resources.
|
4
|
+
|
5
|
+
With InSpec 2.0, you may now use several InSpec resources to audit properties of your cloud infrastructure - for example, an Amazon Web Services S3 bucket.
|
6
|
+
|
7
|
+
<br>
|
8
|
+
|
9
|
+
## AWS Platform Support in InSpec 2.0
|
10
|
+
|
11
|
+
### Setting up AWS credentials for InSpec
|
12
|
+
|
13
|
+
InSpec uses the standard AWS authentication mechanisms. Typically, you will create an IAM user specifically for auditing activities.
|
14
|
+
|
15
|
+
* 1 Create an IAM user in the AWS console, with your choice of username. Check the box marked "Programmatic Access."
|
16
|
+
* 2 On the Permissions screen, choose Direct Attach. Select the AWS-managed IAM Profile named "ReadOnlyAccess." If you wish to restrict the user further, you may do so; see individual InSpec resources to identify which permissions are required.
|
17
|
+
* 3 After generating the key, record the Access Key ID and Secret Key.
|
18
|
+
|
19
|
+
#### Using Environment Variables to provide credentials
|
20
|
+
|
21
|
+
You may provide the credentials to InSpec by setting the following environment variables: `AWS_REGION`, `AWS_ACCESS_KEY_ID`, and `AWS_SECRET_KEY_ID`. You may also use `AWS_PROFILE`, or if you are using MFA, `AWS_SESSION_TOKEN`. See the [AWS Command Line Interface Docs](https://docs.aws.amazon.com/cli/latest/userguide/cli-chap-getting-started.html) for details.
|
22
|
+
|
23
|
+
Once you have your environment variables set, you can verify your credentials by running:
|
24
|
+
|
25
|
+
```bash
|
26
|
+
you$ inspec detect -t aws://
|
27
|
+
|
28
|
+
== Platform Details
|
29
|
+
Name: aws
|
30
|
+
Families: cloud, api
|
31
|
+
Release: aws-sdk-v2.10.125
|
32
|
+
```
|
33
|
+
|
34
|
+
#### Using the InSpec target option to provide credentials on AWS
|
35
|
+
|
36
|
+
Look for a file in your home directory named `~/.aws/credentials`. If it does not exist, create it. Choose a name for your profile; here, we're using the name 'auditing'. Add your credentials as a new profile, in INI format:
|
37
|
+
|
38
|
+
```bash
|
39
|
+
[auditing]
|
40
|
+
aws_access_key_id = AKIA....
|
41
|
+
aws_secret_access_key = 1234....abcd
|
42
|
+
```
|
43
|
+
|
44
|
+
You may now run InSpec using the `--target` / `-t` option, using the format `-t aws://region/profile`. For example, to connect to the Ohio region using a profile named 'auditing', use `-t aws://us-east-2/auditing`.
|
45
|
+
|
46
|
+
To verify your credentials,
|
47
|
+
|
48
|
+
```bash
|
49
|
+
you$ inspec detect -t aws://
|
50
|
+
|
51
|
+
== Platform Details
|
52
|
+
Name: aws
|
53
|
+
Families: cloud, api
|
54
|
+
Release: aws-sdk-v2.10.125
|
55
|
+
```
|
56
|
+
|
57
|
+
<br>
|
58
|
+
|
59
|
+
## Azure Platform Support in InSpec 2.0
|
60
|
+
|
61
|
+
### Setting up Azure credentials for InSpec
|
62
|
+
|
63
|
+
To use InSpec Azure resources, you will need to create a Service Principal Name (SPN) for auditing an Azure subscription.
|
64
|
+
|
65
|
+
This can be done on the command line or from the Azure Portal:
|
66
|
+
|
67
|
+
* [Azure CLI](https://docs.microsoft.com/en-us/azure/azure-resource-manager/resource-group-authenticate-service-principal-cli)
|
68
|
+
* [PowerShell](https://docs.microsoft.com/en-us/azure/azure-resource-manager/resource-group-authenticate-service-principal)
|
69
|
+
* [Azure Portal](https://docs.microsoft.com/en-us/azure/azure-resource-manager/resource-group-create-service-principal-portal)
|
70
|
+
|
71
|
+
The information from the SPN can be specified either in the file `~/.azure/credentials`, as environment variables, or by using InSpec target URIs.
|
72
|
+
|
73
|
+
#### Setting up the Azure Credentials File
|
74
|
+
|
75
|
+
By default InSpec is configured to look at ~/.azure/credentials, and it should contain:
|
76
|
+
|
77
|
+
```powershell
|
78
|
+
[<SUBSCRIPTION_ID>]
|
79
|
+
client_id = "<CLIENT_ID>"
|
80
|
+
client_secret = "<CLIENT_SECRET>"
|
81
|
+
tenant_id = "<TENANT_ID>"
|
82
|
+
```
|
83
|
+
|
84
|
+
NOTE: In the Azure web portal, these values are labeled differently:
|
85
|
+
* The client_id is referred to as the 'Application ID'
|
86
|
+
* The client_secret is referred to as the 'Key (Password Type)'
|
87
|
+
* The tenant_id is referred to as the 'Directory ID'
|
88
|
+
|
89
|
+
With the credentials are in place you may now execute InSpec:
|
90
|
+
|
91
|
+
```bash
|
92
|
+
inspec exec my-inspec-profile -t azure://
|
93
|
+
```
|
94
|
+
|
95
|
+
#### Using Environment variables to provide credentials
|
96
|
+
|
97
|
+
You may also set the Azure credentials via environment variables:
|
98
|
+
|
99
|
+
* `AZURE_SUBSCRIPTION_ID`
|
100
|
+
* `AZURE_CLIENT_ID`
|
101
|
+
* `AZURE_CLIENT_SECRET`
|
102
|
+
* `AZURE_TENANT_ID`
|
103
|
+
|
104
|
+
For example:
|
105
|
+
|
106
|
+
```bash
|
107
|
+
AZURE_SUBSCRIPTION_ID="2fbdbb02-df2e-11e6-bf01-fe55135034f3" \
|
108
|
+
AZURE_CLIENT_ID="58dc4f6c-df2e-11e6-bf01-fe55135034f3" \
|
109
|
+
AZURE_CLIENT_SECRET="Jibr4iwwaaZwBb6W" \
|
110
|
+
AZURE_TENANT_ID="6ad89b58-df2e-11e6-bf01-fe55135034f3" inspec exec my-profile -t azure://
|
111
|
+
```
|
112
|
+
|
113
|
+
#### Using the InSpec target option to provide credentials on Azure
|
114
|
+
|
115
|
+
If you have created a `~/.azure/credentials` file as above, you may also use the InSpec command line `--target` / `-t` option to select a subscription ID. For example:
|
116
|
+
|
117
|
+
```bash
|
118
|
+
inspec exec my-profile -t azure://2fbdbb02-df2e-11e6-bf01-fe55135034f3
|
119
|
+
```
|
@@ -0,0 +1,50 @@
|
|
1
|
+
---
|
2
|
+
title: About kitchen-inspec
|
3
|
+
---
|
4
|
+
|
5
|
+
# kitchen-inspec
|
6
|
+
|
7
|
+
Use InSpec as a Kitchen verifier with `kitchen-inspec`.
|
8
|
+
|
9
|
+
Add the InSpec verifier to the `.kitchen.yml` file:
|
10
|
+
|
11
|
+
verifier:
|
12
|
+
name: inspec
|
13
|
+
|
14
|
+
Use a compliance profile from the Chef Compliance server:
|
15
|
+
|
16
|
+
suites:
|
17
|
+
- name: compliance
|
18
|
+
run_list:
|
19
|
+
- recipe[ssh-hardening::default]
|
20
|
+
verifier:
|
21
|
+
inspec_tests:
|
22
|
+
- compliance://base/ssh
|
23
|
+
|
24
|
+
and then run the following command:
|
25
|
+
|
26
|
+
$ inspec compliance login https://compliance.test --user admin --insecure --token ''
|
27
|
+
|
28
|
+
where `--insecure` is required when using self-signed certificates.
|
29
|
+
|
30
|
+
Use a compliance profile from the Chef Supermarket:
|
31
|
+
|
32
|
+
suites:
|
33
|
+
- name: supermarket
|
34
|
+
run_list:
|
35
|
+
- recipe[ssh-hardening::default]
|
36
|
+
verifier:
|
37
|
+
inspec_tests:
|
38
|
+
- supermarket://dev-sec/ssh-baseline
|
39
|
+
|
40
|
+
Use InSpec tests from the local file system:
|
41
|
+
|
42
|
+
suites:
|
43
|
+
- name: local
|
44
|
+
run_list:
|
45
|
+
- recipe[my_cookbook::default]
|
46
|
+
verifier:
|
47
|
+
inspec_tests:
|
48
|
+
- test/integration/default
|
49
|
+
|
50
|
+
Check out [Detect and correct with Test Kitchen](https://learn.chef.io/modules/detect-correct-kitchen#/) on Learn Chef Rally for a hands-on look at how to use Test Kitchen to run InSpec profiles.
|