|
| 1 | +require 'spec_helper_acceptance' |
| 2 | + |
| 3 | +describe 'Puppetserver config options', unless: ENV['BEAKER_PUPPET_COLLECTION'] == 'pc1' && fact('lsbdistcodename') == 'stretch' do |
| 4 | + before(:context) do |
| 5 | + if fact('lsbdistcodename') == 'jessie' && ENV['BEAKER_PUPPET_COLLECTION'] != 'pc1' |
| 6 | + on default, "echo 'deb http://deb.debian.org/debian jessie-backports main' >/etc/apt/sources.list.d/backports.list" |
| 7 | + on default, 'apt update' |
| 8 | + on default, 'apt -y -t jessie-backports install openjdk-8-jdk-headless' |
| 9 | + end |
| 10 | + if check_for_package(default, 'puppetserver') |
| 11 | + on default, puppet('resource package puppetserver ensure=purged') |
| 12 | + on default, 'rm -rf /etc/sysconfig/puppetserver /etc/puppetlabs/puppetserver' |
| 13 | + on default, 'find /etc/puppetlabs/puppet/ssl/ -type f -delete' |
| 14 | + end |
| 15 | + |
| 16 | + # puppetserver won't start with lower than 2GB memory |
| 17 | + memoryfree_mb = fact('memoryfree_mb').to_i |
| 18 | + raise 'At least 2048MB free memory required' if memoryfree_mb < 256 |
| 19 | + end |
| 20 | + |
| 21 | + describe 'server_max_open_files' do |
| 22 | + let(:pp) do |
| 23 | + <<-MANIFEST |
| 24 | + class { '::puppet': |
| 25 | + server => true, |
| 26 | + server_foreman => false, |
| 27 | + server_reports => 'store', |
| 28 | + server_external_nodes => '', |
| 29 | + # only for install test - don't think to use this in production! |
| 30 | + # https://docs.puppet.com/puppetserver/latest/tuning_guide.html |
| 31 | + server_jvm_max_heap_size => '256m', |
| 32 | + server_jvm_min_heap_size => '256m', |
| 33 | + server_max_open_files => 32143, |
| 34 | + } |
| 35 | + MANIFEST |
| 36 | + end |
| 37 | + |
| 38 | + it_behaves_like 'a idempotent resource' |
| 39 | + |
| 40 | + # pgrep -f java.*puppetserver would be better. But i cannot get it to work. Shellwords.escape() seems to break something |
| 41 | + describe command("grep '^Max open files' /proc/`cat /var/run/puppetlabs/puppetserver/puppetserver.pid`/limits"), :sudo => true do |
| 42 | + its(:exit_status) { is_expected.to eq 0 } |
| 43 | + its(:stdout) { is_expected.to match %r{^Max open files\s+32143\s+32143\s+files\s*$} } |
| 44 | + end |
| 45 | + end |
| 46 | +end |
0 commit comments