Szef kuchni - ChefSpec
Test Driven Development (TDD)jest sposobem na napisanie testu jednostkowego przed napisaniem dowolnego kodu receptury. Test powinien być prawdziwy i potwierdzać działanie przepisu. Właściwie to powinno zawieść, ponieważ nie opracowano żadnego przepisu. Po opracowaniu przepisu test powinien przejść pomyślnie.
ChefSpec jest oparty na popularnym frameworku RSpec i oferuje dostosowaną składnię do testowania receptury Chefa.
Tworzenie specyfikacji ChefSpec
Step 1 - Utwórz plik klejnotów zawierający klejnot chefSpec.
vipin@laptop:~/chef-repo $ subl Gemfile 
source 'https://rubygems.org' 
gem 'chefspec' 
    Step 2 - Zainstaluj klejnot.
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 - Utwórz katalog specyfikacji.
vipin@laptop:~/chef-repo $ mkdir cookbooks/<Cookbook Name>/spec 
    Step 4 - Utwórz specyfikację
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 - Sprawdź poprawność 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 - Edytuj domyślny przepis książek kucharskich.
vipin@laptop:~/chef-repo $ subl cookbooks/<Cookbook Name>/recipes/default.rb 
template '/tmp/greeting.txt' do 
   variables greeting: 'Hello!' 
end 
    Step 7 - Utwórz plik szablonu.
vipin@laptop:~/chef-repo $ subl cookbooks/< Cookbook Name>/recipes/default.rb 
<%= @greeting %> <%= node['platform'] %>! 
    Step 8 - Uruchom ponownie rspec.
vipin@laptop:~/chef-repo $ rspec cookbooks/<Cookbook Name>/spec/default_spec.rb 
. 
Finished in 0.10142 seconds 
1 example, 0 failures 
    Jak to działa
Aby to działało, musimy najpierw skonfigurować podstawową infrastrukturę do używania RSpec z Chef. Następnie potrzebujemy klejnotu ChefSpec Ruby, a książka kucharska potrzebuje katalogu o nazwie spec, w którym zostaną zapisane wszystkie testy.