From 8d47cc9499b95845cee6b6d812e6c7a1b58a9ab7 Mon Sep 17 00:00:00 2001 From: Helen Griffiths Date: Wed, 6 Nov 2019 18:04:07 +0000 Subject: [PATCH] Document "on_supported_os(arg)" with modern Ruby hashes and an example. --- README.md | 73 +++++++++++++++++++++++++++++++++++++++++++++++++++++-- 1 file changed, 71 insertions(+), 2 deletions(-) diff --git a/README.md b/README.md index 5f4b9273..ce9567d7 100644 --- a/README.md +++ b/README.md @@ -64,8 +64,27 @@ describe 'myclass::debian' do ], } - on_supported_os(test_on).each do |os, facts| - let (:facts) { facts } + on_supported_os(test_on).each do |os, os_facts| + let (:facts) { os_facts } + it { is_expected.to compile.with_all_deps } + end +end +``` +Ruby 1.9 and later: +```ruby +require 'spec_helper' + +describe 'myclass::raspbian' do + test_on = { + supported_os: [ + { + 'operatingsystem' => 'Debian', + 'operatingsystemrelease' => ['10', '9', '8'], + }, + ], + } + on_supported_os(test_on).each do |os, os_facts| + let(:facts) { os_facts } it { is_expected.to compile.with_all_deps } end end @@ -160,6 +179,56 @@ describe 'myclass' do end ``` +When using roles and profiles to manage a heterogeneous IT estate, you can test a profile that supports several OSes with many `let(:facts)` as long as each is in its own context: +```ruby +require 'spec_helper' + +describe 'profiles::packagerepos' do + context 'Raspbian tests' do # We manage hundreds of desk-mounted Pis + raspbian = { + hardwaremodels: ['armv7l'], + supported_os: [ + { + 'operatingsystem' => 'Debian', + 'operatingsystemrelease' => ['10', '9', '8'], + }, + ], + } + on_supported_os(raspbian).each do |os, os_facts| + let(:facts) do + os_facts + end + + context "#{os} with defaults" do + it { is_expected.to compile } + # more tests ... + end + end + end + context 'Ubuntu tests' do # And also a fleet of Ubuntu desktops + ubuntu = { + supported_os: [ + { + 'operatingsystem' => 'Ubuntu', + 'operatingsystemrelease' => ['18.04', '16.04'], + }, + ], + } + + on_supported_os(ubuntu).each do |os, os_facts| + let(:facts) do + os_facts + end + + context "#{os} with defaults" do + it { is_expected.to compile } + # more tests ... + end + end + end +end +``` + ### Testing a type or provider Use `on_supported_os` in the same way for your type and provider unit tests.