Chef-ChefSpec

Test Driven Development (TDD)실제 레시피 코드를 작성하기 전에 단위 테스트를 작성하는 방법입니다. 테스트는 실제 여야하며 레시피가 수행하는 작업을 검증해야합니다. 개발 된 레시피가 없기 때문에 실제로 실패해야합니다. 레시피가 개발되면 테스트를 통과해야합니다.

ChefSpec은 널리 사용되는 RSpec 프레임 워크를 기반으로하며 Chef 레시피 테스트를위한 맞춤형 구문을 제공합니다.

ChefSpec 생성

Step 1 − chefSpec gem을 포함하는 gem 파일을 생성합니다.

vipin@laptop:~/chef-repo $ subl Gemfile 
source 'https://rubygems.org' 
gem 'chefspec'

Step 2 − gem을 설치합니다.

vipin@laptop:~/chef-repo $ bundler install 
Fetching gem metadata from https://rubygems.org/ 
...TRUNCATED OUTPUT... 
Installing chefspec (1.3.1) 
Using bundler (1.3.5) 
Your bundle is complete!

Step 3 − 사양 디렉토리를 생성합니다.

vipin@laptop:~/chef-repo $ mkdir cookbooks/<Cookbook Name>/spec

Step 4 − 사양 생성

vipin@laptop:~/chef-repo $ subl  
cookbooks/my_cookbook/spec/default_spec.rb  
require 'chefspec'  
describe 'my_cookbook::default' do  
   let(:chef_run) {  
      ChefSpec::ChefRunner.new(  
         platform:'ubuntu', version:'12.04'  
      ).converge(described_recipe)  
   }  

   it 'creates a greetings file, containing the platform  
   name' do  
      expect(chef_run).to  
      create_file_with_content('/tmp/greeting.txt','Hello! ubuntu!')  
   end  
end

Step 5 − ChefSpec을 확인합니다.

vipin@laptop:~/chef-repo $ rspec cookbooks/<Cookbook Name>/spec/default_spec.rb 
F 
Failures: 
1) <CookBook Name> ::default creates a greetings file, containing the platform name 
Failure/Error: expect(chef_run.converge(described_recipe)).to 
create_file_with_content('/tmp/greeting.txt','Hello! ubuntu!') 
File content: 
does not match expected: 
Hello! ubuntu! 
# ./cookbooks/my_cookbook/spec/default_spec.rb:11:in `block 
(2 levels) in <top (required)>' 
Finished in 0.11152 seconds 
1 example, 1 failure  

Failed examples: 
rspec ./cookbooks/my_cookbook/spec/default_spec.rb:10 # my_ 
cookbook::default creates a greetings file, containing the 
platform name

Step 6 − 요리 책 기본 레시피를 편집합니다.

vipin@laptop:~/chef-repo $ subl cookbooks/<Cookbook Name>/recipes/default.rb 
template '/tmp/greeting.txt' do 
   variables greeting: 'Hello!' 
end

Step 7 − 템플릿 파일을 생성합니다.

vipin@laptop:~/chef-repo $ subl cookbooks/< Cookbook Name>/recipes/default.rb 
<%= @greeting %> <%= node['platform'] %>!

Step 8 − rspec을 다시 실행하십시오.

vipin@laptop:~/chef-repo $ rspec cookbooks/<Cookbook Name>/spec/default_spec.rb 
. 
Finished in 0.10142 seconds 
1 example, 0 failures

작동 원리

제대로 작동하려면 먼저 Chef와 함께 RSpec을 사용하기위한 기본 인프라를 설정해야합니다. 그런 다음 ChefSpec Ruby gem이 필요하고 쿡북에는 모든 테스트가 저장 될 spec이라는 디렉토리가 필요합니다.