|
| 1 | +require 'spec_helper' |
| 2 | + |
| 3 | +describe 'apache::mod::md', type: :class do |
| 4 | + on_supported_os.each do |os, facts| |
| 5 | + context "on #{os}" do |
| 6 | + let :facts do |
| 7 | + facts |
| 8 | + end |
| 9 | + |
| 10 | + if facts[:os]['family'] == 'Debian' |
| 11 | + context 'validating all md params - using Debian' do |
| 12 | + md_options = { |
| 13 | + 'md_activation_delay' => { type: 'Duration', pass_opt: 'MDActivationDelay' }, |
| 14 | + 'md_base_server' => { type: 'OnOff', pass_opt: 'MDBaseServer' }, |
| 15 | + 'md_ca_challenges' => { type: 'CAChallenges', pass_opt: 'MDCAChallenges' }, |
| 16 | + 'md_certificate_agreement' => { type: 'MDCertificateAgreement', pass_opt: 'MDCertificateAgreement' }, |
| 17 | + 'md_certificate_authority' => { type: 'URL', pass_opt: 'MDCertificateAuthority' }, |
| 18 | + 'md_certificate_check' => { type: 'String', pass_opt: 'MDCertificateCheck' }, |
| 19 | + 'md_certificate_monitor' => { type: 'URL', pass_opt: 'MDCertificateMonitor' }, |
| 20 | + 'md_certificate_protocol' => { type: 'MDCertificateProtocol', pass_opt: 'MDCertificateProtocol' }, |
| 21 | + 'md_certificate_status' => { type: 'OnOff', pass_opt: 'MDCertificateStatus' }, |
| 22 | + 'md_challenge_dns01' => { type: 'Path', pass_opt: 'MDChallengeDns01' }, |
| 23 | + 'md_contact_email' => { type: 'EMail', pass_opt: 'MDContactEmail' }, |
| 24 | + 'md_http_proxy' => { type: 'URL', pass_opt: 'MDHttpProxy' }, |
| 25 | + 'md_members' => { type: 'MDMembers', pass_opt: 'MDMembers' }, |
| 26 | + 'md_message_cmd' => { type: 'Path', pass_opt: 'MDMessageCmd' }, |
| 27 | + 'md_must_staple' => { type: 'OnOff', pass_opt: 'MDMustStaple' }, |
| 28 | + 'md_notify_cmd' => { type: 'Path', pass_opt: 'MDNotifyCmd' }, |
| 29 | + 'md_port_map' => { type: 'String', pass_opt: 'MDPortMap' }, |
| 30 | + 'md_private_keys' => { type: 'String', pass_opt: 'MDPrivateKeys' }, |
| 31 | + 'md_renew_mode' => { type: 'MDRenewMode', pass_opt: 'MDRenewMode' }, |
| 32 | + 'md_renew_window' => { type: 'Duration', pass_opt: 'MDRenewWindow' }, |
| 33 | + 'md_require_https' => { type: 'MDRequireHttps', pass_opt: 'MDRequireHttps' }, |
| 34 | + 'md_server_status' => { type: 'OnOff', pass_opt: 'MDServerStatus' }, |
| 35 | + 'md_staple_others' => { type: 'OnOff', pass_opt: 'MDStapleOthers' }, |
| 36 | + 'md_stapling' => { type: 'OnOff', pass_opt: 'MDStapling' }, |
| 37 | + 'md_stapling_keep_response' => { type: 'Duration', pass_opt: 'MDStaplingKeepResponse' }, |
| 38 | + 'md_stapling_renew_window' => { type: 'Duration', pass_opt: 'MDStaplingRenewWindow' }, |
| 39 | + 'md_store_dir' => { type: 'Path', pass_opt: 'MDStoreDir' }, |
| 40 | + 'md_warn_window' => { type: 'Duration', pass_opt: 'MDWarnWindow' }, |
| 41 | + } |
| 42 | + |
| 43 | + md_options.each do |config_option, config_hash| |
| 44 | + puppetized_config_option = config_option |
| 45 | + case config_hash[:type] |
| 46 | + when 'CAChallenges' |
| 47 | + valid_config_values = [['dns-01'], ['tls-alpn-01', 'http-01']] |
| 48 | + valid_config_values.each do |valid_value| |
| 49 | + describe "with #{puppetized_config_option} => #{valid_value}" do |
| 50 | + let :params do |
| 51 | + { puppetized_config_option.to_sym => valid_value } |
| 52 | + end |
| 53 | + |
| 54 | + it { is_expected.to contain_file('md.conf').with_content(%r{^#{config_hash[:pass_opt]} #{valid_value.join(' ')}}) } |
| 55 | + end |
| 56 | + end |
| 57 | + when 'EMail' |
| 58 | + valid_config_values = ['root@example.com'] |
| 59 | + valid_config_values.each do |valid_value| |
| 60 | + describe "with #{puppetized_config_option} => #{valid_value}" do |
| 61 | + let :params do |
| 62 | + { puppetized_config_option.to_sym => valid_value } |
| 63 | + end |
| 64 | + |
| 65 | + it { is_expected.to contain_file('md.conf').with_content(%r{^#{config_hash[:pass_opt]} #{valid_value}$}) } |
| 66 | + end |
| 67 | + end |
| 68 | + when 'Duration' |
| 69 | + valid_config_values = ['7d', '33%'] |
| 70 | + valid_config_values.each do |valid_value| |
| 71 | + describe "with #{puppetized_config_option} => '#{valid_value}'" do |
| 72 | + let :params do |
| 73 | + { puppetized_config_option.to_sym => valid_value } |
| 74 | + end |
| 75 | + |
| 76 | + it { is_expected.to contain_file('md.conf').with_content(%r{^#{config_hash[:pass_opt]} #{valid_value}$}) } |
| 77 | + end |
| 78 | + end |
| 79 | + when 'MDCertificateAgreement' |
| 80 | + valid_config_values = ['accepted'] |
| 81 | + valid_config_values.each do |valid_value| |
| 82 | + describe "with #{puppetized_config_option} => '#{valid_value}'" do |
| 83 | + let :params do |
| 84 | + { puppetized_config_option.to_sym => valid_value } |
| 85 | + end |
| 86 | + |
| 87 | + it { is_expected.to contain_file('md.conf').with_content(%r{^#{config_hash[:pass_opt]} #{valid_value}$}) } |
| 88 | + end |
| 89 | + end |
| 90 | + when 'MDCertificateProtocol' |
| 91 | + valid_config_values = ['ACME'] |
| 92 | + valid_config_values.each do |valid_value| |
| 93 | + describe "with #{puppetized_config_option} => '#{valid_value}'" do |
| 94 | + let :params do |
| 95 | + { puppetized_config_option.to_sym => valid_value } |
| 96 | + end |
| 97 | + |
| 98 | + it { is_expected.to contain_file('md.conf').with_content(%r{^#{config_hash[:pass_opt]} #{valid_value}$}) } |
| 99 | + end |
| 100 | + end |
| 101 | + when 'MDMembers' |
| 102 | + valid_config_values = ['auto', 'manual'] |
| 103 | + valid_config_values.each do |valid_value| |
| 104 | + describe "with #{puppetized_config_option} => '#{valid_value}'" do |
| 105 | + let :params do |
| 106 | + { puppetized_config_option.to_sym => valid_value } |
| 107 | + end |
| 108 | + |
| 109 | + it { is_expected.to contain_file('md.conf').with_content(%r{^#{config_hash[:pass_opt]} #{valid_value}$}) } |
| 110 | + end |
| 111 | + end |
| 112 | + when 'MDRenewMode' |
| 113 | + valid_config_values = ['always', 'auto', 'manual'] |
| 114 | + valid_config_values.each do |valid_value| |
| 115 | + describe "with #{puppetized_config_option} => '#{valid_value}'" do |
| 116 | + let :params do |
| 117 | + { puppetized_config_option.to_sym => valid_value } |
| 118 | + end |
| 119 | + |
| 120 | + it { is_expected.to contain_file('md.conf').with_content(%r{^#{config_hash[:pass_opt]} #{valid_value}$}) } |
| 121 | + end |
| 122 | + end |
| 123 | + when 'MDRequireHttps' |
| 124 | + valid_config_values = ['off', 'temporary', 'permanent'] |
| 125 | + valid_config_values.each do |valid_value| |
| 126 | + describe "with #{puppetized_config_option} => '#{valid_value}'" do |
| 127 | + let :params do |
| 128 | + { puppetized_config_option.to_sym => valid_value } |
| 129 | + end |
| 130 | + |
| 131 | + it { is_expected.to contain_file('md.conf').with_content(%r{^#{config_hash[:pass_opt]} #{valid_value}$}) } |
| 132 | + end |
| 133 | + end |
| 134 | + when 'OnOff' |
| 135 | + valid_config_values = ['on', 'off'] |
| 136 | + valid_config_values.each do |valid_value| |
| 137 | + describe "with #{puppetized_config_option} => '#{valid_value}'" do |
| 138 | + let :params do |
| 139 | + { puppetized_config_option.to_sym => valid_value } |
| 140 | + end |
| 141 | + |
| 142 | + it { is_expected.to contain_file('md.conf').with_content(%r{^#{config_hash[:pass_opt]} #{valid_value}$}) } |
| 143 | + end |
| 144 | + end |
| 145 | + when 'Path' |
| 146 | + valid_config_values = ['/some/path/to/somewhere'] |
| 147 | + valid_config_values.each do |valid_value| |
| 148 | + describe "with #{puppetized_config_option} => #{valid_value}" do |
| 149 | + let :params do |
| 150 | + { puppetized_config_option.to_sym => valid_value } |
| 151 | + end |
| 152 | + |
| 153 | + it { is_expected.to contain_file('md.conf').with_content(%r{^#{config_hash[:pass_opt]} "#{valid_value}"$}) } |
| 154 | + end |
| 155 | + end |
| 156 | + when 'String' |
| 157 | + valid_config_values = ['a random string'] |
| 158 | + valid_config_values.each do |valid_value| |
| 159 | + describe "with #{puppetized_config_option} => '#{valid_value}'" do |
| 160 | + let :params do |
| 161 | + { puppetized_config_option.to_sym => valid_value } |
| 162 | + end |
| 163 | + |
| 164 | + it { is_expected.to contain_file('md.conf').with_content(%r{^#{config_hash[:pass_opt]} #{valid_value}$}) } |
| 165 | + end |
| 166 | + end |
| 167 | + when 'URL' |
| 168 | + valid_config_values = ['https://example.com/example'] |
| 169 | + valid_config_values.each do |valid_value| |
| 170 | + describe "with #{puppetized_config_option} => '#{valid_value}'" do |
| 171 | + let :params do |
| 172 | + { puppetized_config_option.to_sym => valid_value } |
| 173 | + end |
| 174 | + |
| 175 | + it { is_expected.to contain_file('md.conf').with_content(%r{^#{config_hash[:pass_opt]} #{valid_value}$}) } |
| 176 | + end |
| 177 | + end |
| 178 | + else |
| 179 | + valid_config_values = config_hash[:type] |
| 180 | + valid_config_values.each do |valid_value| |
| 181 | + describe "with #{puppetized_config_option} => '#{valid_value}'" do |
| 182 | + let :params do |
| 183 | + { puppetized_config_option.to_sym => valid_value } |
| 184 | + end |
| 185 | + |
| 186 | + it { is_expected.to contain_file('md.conf').with_content(%r{^#{config_hash[:pass_opt]} #{valid_value}$}) } |
| 187 | + end |
| 188 | + end |
| 189 | + end |
| 190 | + end |
| 191 | + end |
| 192 | + end |
| 193 | + |
| 194 | + it { is_expected.to contain_class('apache::mod::watchdog') } |
| 195 | + it { is_expected.to contain_apache__mod('md') } |
| 196 | + it { is_expected.to contain_file('md.conf') } |
| 197 | + end |
| 198 | + end |
| 199 | +end |
0 commit comments