diff options
Diffstat (limited to 'puppet/modules/ntp/spec')
| -rw-r--r-- | puppet/modules/ntp/spec/classes/ntp_spec.rb | 261 | ||||
| -rw-r--r-- | puppet/modules/ntp/spec/fixtures/modules/my_ntp/templates/ntp.conf.erb | 4 | ||||
| -rw-r--r-- | puppet/modules/ntp/spec/spec.opts | 6 | ||||
| -rw-r--r-- | puppet/modules/ntp/spec/spec_helper.rb | 1 | ||||
| -rw-r--r-- | puppet/modules/ntp/spec/spec_helper_system.rb | 26 | ||||
| -rw-r--r-- | puppet/modules/ntp/spec/system/basic_spec.rb | 13 | ||||
| -rw-r--r-- | puppet/modules/ntp/spec/system/class_spec.rb | 39 | ||||
| -rw-r--r-- | puppet/modules/ntp/spec/system/ntp_config_spec.rb | 35 | ||||
| -rw-r--r-- | puppet/modules/ntp/spec/system/ntp_install_spec.rb | 31 | ||||
| -rw-r--r-- | puppet/modules/ntp/spec/system/ntp_service_spec.rb | 25 | ||||
| -rw-r--r-- | puppet/modules/ntp/spec/system/preferred_servers_spec.rb | 20 | ||||
| -rw-r--r-- | puppet/modules/ntp/spec/system/restrict_spec.rb | 20 | ||||
| -rw-r--r-- | puppet/modules/ntp/spec/unit/puppet/provider/README.markdown | 4 | ||||
| -rw-r--r-- | puppet/modules/ntp/spec/unit/puppet/type/README.markdown | 4 | 
14 files changed, 489 insertions, 0 deletions
| diff --git a/puppet/modules/ntp/spec/classes/ntp_spec.rb b/puppet/modules/ntp/spec/classes/ntp_spec.rb new file mode 100644 index 00000000..6c636f40 --- /dev/null +++ b/puppet/modules/ntp/spec/classes/ntp_spec.rb @@ -0,0 +1,261 @@ +require 'spec_helper' + +describe 'ntp' do + +  ['Debian', 'RedHat','SuSE', 'FreeBSD', 'Archlinux', 'Gentoo'].each do |system| +    if system == 'Gentoo' +      let(:facts) {{ :osfamily => 'Linux', :operatingsystem => system }} +    else +      let(:facts) {{ :osfamily => system }} +    end + +    it { should include_class('ntp::install') } +    it { should include_class('ntp::config') } +    it { should include_class('ntp::service') } + +    describe 'ntp::config on #{system}' do +      it { should contain_file('/etc/ntp.conf').with_owner('0') } +      it { should contain_file('/etc/ntp.conf').with_group('0') } +      it { should contain_file('/etc/ntp.conf').with_mode('0644') } + +      describe 'allows template to be overridden' do +        let(:params) {{ :config_template => 'my_ntp/ntp.conf.erb' }} +        it { should contain_file('/etc/ntp.conf').with({ +          'content' => /server foobar/}) +        } +      end + +      describe "keys for osfamily #{system}" do +        context "when enabled" do +          let(:params) {{ +            :keys_enable     => true, +            :keys_file       => '/etc/ntp/ntp.keys', +            :keys_trusted    => ['1', '2', '3'], +            :keys_controlkey => '2', +            :keys_requestkey => '3', +          }} + +          it { should contain_file('/etc/ntp').with({ +            'ensure'  => 'directory'}) +          } +          it { should contain_file('/etc/ntp.conf').with({ +            'content' => /trustedkey 1 2 3/}) +          } +          it { should contain_file('/etc/ntp.conf').with({ +            'content' => /controlkey 2/}) +          } +          it { should contain_file('/etc/ntp.conf').with({ +            'content' => /requestkey 3/}) +          } +        end +      end + +      context "when disabled" do +        let(:params) {{ +          :keys_enable     => false, +          :keys_file       => '/etc/ntp/ntp.keys', +          :keys_trusted    => ['1', '2', '3'], +          :keys_controlkey => '2', +          :keys_requestkey => '3', +        }} + +        it { should_not contain_file('/etc/ntp').with({ +          'ensure'  => 'directory'}) +        } +        it { should_not contain_file('/etc/ntp.conf').with({ +          'content' => /trustedkey 1 2 3/}) +        } +        it { should_not contain_file('/etc/ntp.conf').with({ +          'content' => /controlkey 2/}) +        } +        it { should_not contain_file('/etc/ntp.conf').with({ +          'content' => /requestkey 3/}) +        } +      end + +      describe 'preferred servers' do +        context "when set" do +          let(:params) {{ +            :servers           => ['a', 'b', 'c', 'd'], +            :preferred_servers => ['a', 'b'] +          }} + +          it { should contain_file('/etc/ntp.conf').with({ +            'content' => /server a prefer\nserver b prefer\nserver c\nserver d/}) +          } +        end +        context "when not set" do +          let(:params) {{ +            :servers           => ['a', 'b', 'c', 'd'], +            :preferred_servers => [] +          }} + +          it { should_not contain_file('/etc/ntp.conf').with({ +            'content' => /server a prefer/}) +          } +        end +      end + +      describe 'ntp::install on #{system}' do +        let(:params) {{ :package_ensure => 'present', :package_name => ['ntp'], }} + +        it { should contain_package('ntp').with( +          :ensure => 'present', +          :name   => 'ntp' +        )} + +        describe 'should allow package ensure to be overridden' do +          let(:params) {{ :package_ensure => 'latest', :package_name => ['ntp'] }} +          it { should contain_package('ntp').with_ensure('latest') } +        end + +        describe 'should allow the package name to be overridden' do +          let(:params) {{ :package_ensure => 'present', :package_name => ['hambaby'] }} +          it { should contain_package('ntp').with_name('hambaby') } +        end +      end + +      describe 'ntp::service' do +        let(:params) {{ +          :service_manage => true, +          :service_enable => true, +          :service_ensure => 'running', +          :service_name   => 'ntp' +        }} + +        describe 'with defaults' do +          it { should contain_service('ntp').with( +            :enable => true, +            :ensure => 'running', +            :name   => 'ntp' +          )} +        end + +        describe 'service_ensure' do +          describe 'when overridden' do +            let(:params) {{ :service_name => 'ntp', :service_ensure => 'stopped' }} +            it { should contain_service('ntp').with_ensure('stopped') } +          end +        end + +        describe 'service_manage' do +          let(:params) {{ +            :service_manage => false, +            :service_enable => true, +            :service_ensure => 'running', +            :service_name   => 'ntpd', +          }} + +          it 'when set to false' do +            should_not contain_service('ntp').with({ +              'enable' => true, +              'ensure' => 'running', +              'name'   => 'ntpd' +            }) +          end +        end +      end +    end + +    context 'ntp::config' do +      describe "for operating system Gentoo" do +        let(:facts) {{ :operatingsystem => 'Gentoo', +                       :osfamily        => 'Linux' }} + +        it 'uses the NTP pool servers by default' do +          should contain_file('/etc/ntp.conf').with({ +            'content' => /server \d.gentoo.pool.ntp.org/, +          }) +        end +      end +      describe "on osfamily Debian" do +        let(:facts) {{ :osfamily => 'debian' }} + +        it 'uses the debian ntp servers by default' do +          should contain_file('/etc/ntp.conf').with({ +            'content' => /server \d.debian.pool.ntp.org iburst/, +          }) +        end +      end + +      describe "on osfamily RedHat" do +        let(:facts) {{ :osfamily => 'RedHat' }} + +        it 'uses the redhat ntp servers by default' do +          should contain_file('/etc/ntp.conf').with({ +            'content' => /server \d.centos.pool.ntp.org/, +          }) +        end +      end + +      describe "on osfamily SuSE" do +        let(:facts) {{ :osfamily => 'SuSE' }} + +        it 'uses the opensuse ntp servers by default' do +          should contain_file('/etc/ntp.conf').with({ +            'content' => /server \d.opensuse.pool.ntp.org/, +          }) +        end +      end + +      describe "on osfamily FreeBSD" do +        let(:facts) {{ :osfamily => 'FreeBSD' }} + +        it 'uses the freebsd ntp servers by default' do +          should contain_file('/etc/ntp.conf').with({ +            'content' => /server \d.freebsd.pool.ntp.org iburst maxpoll 9/, +          }) +        end +      end + +      describe "on osfamily ArchLinux" do +        let(:facts) {{ :osfamily => 'ArchLinux' }} + +        it 'uses the NTP pool servers by default' do +          should contain_file('/etc/ntp.conf').with({ +            'content' => /server \d.pool.ntp.org/, +          }) +        end +      end + +      describe "for operating system family unsupported" do +        let(:facts) {{ +          :osfamily  => 'unsupported', +        }} + +        it { expect{ subject }.to raise_error( +          /^The ntp module is not supported on an unsupported based system./ +        )} +      end +    end + +    describe 'for virtual machines' do +      let(:facts) {{ :osfamily        => 'Archlinux', +                     :is_virtual      => 'true' }} + +      it 'should not use local clock as a time source' do +        should_not contain_file('/etc/ntp.conf').with({ +          'content' => /server.*127.127.1.0.*fudge.*127.127.1.0 stratum 10/, +        }) +      end + +      it 'allows large clock skews' do +        should contain_file('/etc/ntp.conf').with({ +          'content' => /tinker panic 0/, +        }) +      end +    end + +    describe 'for physical machines' do +      let(:facts) {{ :osfamily        => 'Archlinux', +                     :is_virtual      => 'false' }} + +      it 'disallows large clock skews' do +        should_not contain_file('/etc/ntp.conf').with({ +          'content' => /tinker panic 0/, +        }) +      end +    end +  end + +end diff --git a/puppet/modules/ntp/spec/fixtures/modules/my_ntp/templates/ntp.conf.erb b/puppet/modules/ntp/spec/fixtures/modules/my_ntp/templates/ntp.conf.erb new file mode 100644 index 00000000..40cf67c6 --- /dev/null +++ b/puppet/modules/ntp/spec/fixtures/modules/my_ntp/templates/ntp.conf.erb @@ -0,0 +1,4 @@ +#my uber ntp config +# + +server foobar diff --git a/puppet/modules/ntp/spec/spec.opts b/puppet/modules/ntp/spec/spec.opts new file mode 100644 index 00000000..91cd6427 --- /dev/null +++ b/puppet/modules/ntp/spec/spec.opts @@ -0,0 +1,6 @@ +--format +s +--colour +--loadby +mtime +--backtrace diff --git a/puppet/modules/ntp/spec/spec_helper.rb b/puppet/modules/ntp/spec/spec_helper.rb new file mode 100644 index 00000000..2c6f5664 --- /dev/null +++ b/puppet/modules/ntp/spec/spec_helper.rb @@ -0,0 +1 @@ +require 'puppetlabs_spec_helper/module_spec_helper' diff --git a/puppet/modules/ntp/spec/spec_helper_system.rb b/puppet/modules/ntp/spec/spec_helper_system.rb new file mode 100644 index 00000000..d5208463 --- /dev/null +++ b/puppet/modules/ntp/spec/spec_helper_system.rb @@ -0,0 +1,26 @@ +require 'rspec-system/spec_helper' +require 'rspec-system-puppet/helpers' +require 'rspec-system-serverspec/helpers' +include Serverspec::Helper::RSpecSystem +include Serverspec::Helper::DetectOS +include RSpecSystemPuppet::Helpers + +RSpec.configure do |c| +  # Project root +  proj_root = File.expand_path(File.join(File.dirname(__FILE__), '..')) + +  # Enable colour +  c.tty = true + +  c.include RSpecSystemPuppet::Helpers + +  # This is where we 'setup' the nodes before running our tests +  c.before :suite do +    # Install puppet +    puppet_install + +    # Install modules and dependencies +    puppet_module_install(:source => proj_root, :module_name => 'ntp') +    shell('puppet module install puppetlabs-stdlib') +  end +end diff --git a/puppet/modules/ntp/spec/system/basic_spec.rb b/puppet/modules/ntp/spec/system/basic_spec.rb new file mode 100644 index 00000000..7b717a04 --- /dev/null +++ b/puppet/modules/ntp/spec/system/basic_spec.rb @@ -0,0 +1,13 @@ +require 'spec_helper_system' + +# Here we put the more basic fundamental tests, ultra obvious stuff. +describe "basic tests:" do +  context 'make sure we have copied the module across' do +    # No point diagnosing any more if the module wasn't copied properly +    context shell 'ls /etc/puppet/modules/ntp' do +      its(:stdout) { should =~ /Modulefile/ } +      its(:stderr) { should be_empty } +      its(:exit_code) { should be_zero } +    end +  end +end diff --git a/puppet/modules/ntp/spec/system/class_spec.rb b/puppet/modules/ntp/spec/system/class_spec.rb new file mode 100644 index 00000000..49dfc641 --- /dev/null +++ b/puppet/modules/ntp/spec/system/class_spec.rb @@ -0,0 +1,39 @@ +require 'spec_helper_system' + +describe "ntp class:" do +  context 'should run successfully' do +    pp = "class { 'ntp': }" + +    context puppet_apply(pp) do +      its(:stderr) { should be_empty } +      its(:exit_code) { should_not == 1 } +      its(:refresh) { should be_nil } +      its(:stderr) { should be_empty } +      its(:exit_code) { should be_zero } +    end +  end + +  context 'service_ensure => stopped:' do +    pp = "class { 'ntp': service_ensure => stopped }" + +    context puppet_apply(pp) do +      its(:stderr) { should be_empty } +      its(:exit_code) { should_not == 1 } +      its(:refresh) { should be_nil } +      its(:stderr) { should be_empty } +      its(:exit_code) { should be_zero } +    end +  end + +  context 'service_ensure => running:' do +    pp = "class { 'ntp': service_ensure => running }" + +    context puppet_apply(pp) do |r| +      its(:stderr) { should be_empty } +      its(:exit_code) { should_not == 1 } +      its(:refresh) { should be_nil } +      its(:stderr) { should be_empty } +      its(:exit_code) { should be_zero } +    end +  end +end diff --git a/puppet/modules/ntp/spec/system/ntp_config_spec.rb b/puppet/modules/ntp/spec/system/ntp_config_spec.rb new file mode 100644 index 00000000..194cdf10 --- /dev/null +++ b/puppet/modules/ntp/spec/system/ntp_config_spec.rb @@ -0,0 +1,35 @@ +require 'spec_helper_system' + +describe 'ntp::config class' do +  let(:os) { +    node.facts['osfamily'] +  } + +  puppet_apply(%{ +    class { 'ntp': } +  }) + +  case node.facts['osfamily'] +  when 'FreeBSD' +    line = '0.freebsd.pool.ntp.org iburst maxpoll 9' +  when 'Debian' +    line = '0.debian.pool.ntp.org iburst' +  when 'RedHat' +    line = '0.centos.pool.ntp.org' +  when 'SuSE' +    line = '0.opensuse.pool.ntp.org' +  when 'Linux' +    case node.facts['operatingsystem'] +    when 'ArchLinux' +      line = '0.pool.ntp.org' +    when 'Gentoo' +      line = '0.gentoo.pool.ntp.org' +    end +  end + +  describe file('/etc/ntp.conf') do +    it { should be_file } +    it { should contain line } +  end + +end diff --git a/puppet/modules/ntp/spec/system/ntp_install_spec.rb b/puppet/modules/ntp/spec/system/ntp_install_spec.rb new file mode 100644 index 00000000..39759c5e --- /dev/null +++ b/puppet/modules/ntp/spec/system/ntp_install_spec.rb @@ -0,0 +1,31 @@ +require 'spec_helper_system' + + +describe 'ntp::install class' do +  let(:os) { +    node.facts['osfamily'] +  } + +  case node.facts['osfamily'] +  when 'FreeBSD' +    packagename = 'net/ntp' +  when 'Linux' +    case node.facts['operatingsystem'] +    when 'ArchLinux' +      packagename = 'ntp' +    when 'Gentoo' +      packagename = 'net-misc/ntp' +    end +  else +    packagename = 'ntp' +  end + +  puppet_apply(%{ +    class { 'ntp': } +  }) + +  describe package(packagename) do +    it { should be_installed } +  end + +end diff --git a/puppet/modules/ntp/spec/system/ntp_service_spec.rb b/puppet/modules/ntp/spec/system/ntp_service_spec.rb new file mode 100644 index 00000000..b97e2a4e --- /dev/null +++ b/puppet/modules/ntp/spec/system/ntp_service_spec.rb @@ -0,0 +1,25 @@ +require 'spec_helper_system' + + +describe 'ntp::service class' do +  let(:os) { +    node.facts['osfamily'] +  } + +  case node.facts['osfamily'] +  when 'RedHat', 'FreeBSD', 'Linux' +    servicename = 'ntpd' +  else +    servicename = 'ntp' +  end + +  puppet_apply(%{ +    class { 'ntp': } +  }) + +  describe service(servicename) do +    it { should be_enabled } +    it { should be_running } +  end + +end diff --git a/puppet/modules/ntp/spec/system/preferred_servers_spec.rb b/puppet/modules/ntp/spec/system/preferred_servers_spec.rb new file mode 100644 index 00000000..686861bc --- /dev/null +++ b/puppet/modules/ntp/spec/system/preferred_servers_spec.rb @@ -0,0 +1,20 @@ +require 'spec_helper_system' + +describe 'preferred servers' do +  it 'applies cleanly' do +    puppet_apply(%{ +      class { '::ntp': +        servers           => ['a', 'b', 'c', 'd'], +        preferred_servers => ['c', 'd'], +      } +    }) +  end + +  describe file('/etc/ntp.conf') do +    it { should be_file } +    it { should contain 'server a' } +    it { should contain 'server b' } +    it { should contain 'server c prefer' } +    it { should contain 'server d prefer' } +  end +end diff --git a/puppet/modules/ntp/spec/system/restrict_spec.rb b/puppet/modules/ntp/spec/system/restrict_spec.rb new file mode 100644 index 00000000..ae23bc01 --- /dev/null +++ b/puppet/modules/ntp/spec/system/restrict_spec.rb @@ -0,0 +1,20 @@ +require 'spec_helper_system' + +describe "ntp class with restrict:" do +  context 'should run successfully' do +    pp = "class { 'ntp': restrict => ['test restrict']}" + +    context puppet_apply(pp) do +      its(:stderr) { should be_empty } +      its(:exit_code) { should_not == 1 } +      its(:refresh) { should be_nil } +      its(:stderr) { should be_empty } +      its(:exit_code) { should be_zero } +    end +  end + +  describe file('/etc/ntp.conf') do +    it { should contain('test restrict') } +  end + +end diff --git a/puppet/modules/ntp/spec/unit/puppet/provider/README.markdown b/puppet/modules/ntp/spec/unit/puppet/provider/README.markdown new file mode 100644 index 00000000..70258502 --- /dev/null +++ b/puppet/modules/ntp/spec/unit/puppet/provider/README.markdown @@ -0,0 +1,4 @@ +Provider Specs +============== + +Define specs for your providers under this directory. diff --git a/puppet/modules/ntp/spec/unit/puppet/type/README.markdown b/puppet/modules/ntp/spec/unit/puppet/type/README.markdown new file mode 100644 index 00000000..1ee19ac8 --- /dev/null +++ b/puppet/modules/ntp/spec/unit/puppet/type/README.markdown @@ -0,0 +1,4 @@ +Resource Type Specs +=================== + +Define specs for your resource types in this directory. | 
