try again, with puppetforge modules, correctly included now
[mirror/dsa-puppet.git] / 3rdparty / modules / cinder / spec / classes / cinder_spec.rb
1 require 'spec_helper'
2 describe 'cinder' do
3   let :req_params do
4     {:rabbit_password => 'guest', :database_connection => 'mysql://user:password@host/database'}
5   end
6
7   let :facts do
8     {:osfamily => 'Debian'}
9   end
10
11   describe 'with only required params' do
12     let :params do
13       req_params
14     end
15
16     it { should contain_class('cinder::params') }
17     it { should contain_class('mysql::bindings::python') }
18
19     it 'should contain default config' do
20       should contain_cinder_config('DEFAULT/rpc_backend').with(
21         :value => 'cinder.openstack.common.rpc.impl_kombu'
22       )
23       should contain_cinder_config('DEFAULT/control_exchange').with(
24         :value => 'openstack'
25       )
26       should contain_cinder_config('DEFAULT/rabbit_password').with(
27         :value => 'guest',
28         :secret => true
29       )
30       should contain_cinder_config('DEFAULT/rabbit_host').with(
31         :value => '127.0.0.1'
32       )
33       should contain_cinder_config('DEFAULT/rabbit_port').with(
34         :value => '5672'
35       )
36       should contain_cinder_config('DEFAULT/rabbit_hosts').with(
37         :value => '127.0.0.1:5672'
38       )
39       should contain_cinder_config('DEFAULT/rabbit_ha_queues').with(
40         :value => false
41       )
42       should contain_cinder_config('DEFAULT/rabbit_virtual_host').with(
43         :value => '/'
44       )
45       should contain_cinder_config('DEFAULT/rabbit_userid').with(
46         :value => 'guest'
47       )
48       should contain_cinder_config('database/connection').with(
49         :value  => 'mysql://user:password@host/database',
50         :secret => true
51       )
52       should contain_cinder_config('database/idle_timeout').with(
53         :value => '3600'
54       )
55       should contain_cinder_config('database/min_pool_size').with(
56         :value => '1'
57       )
58       should contain_cinder_config('database/max_pool_size').with_ensure('absent')
59       should contain_cinder_config('database/max_retries').with(
60         :value => '10'
61       )
62       should contain_cinder_config('database/retry_interval').with(
63         :value => '10'
64       )
65       should contain_cinder_config('database/max_overflow').with_ensure('absent')
66       should contain_cinder_config('DEFAULT/verbose').with(
67         :value => false
68       )
69       should contain_cinder_config('DEFAULT/debug').with(
70         :value => false
71       )
72       should contain_cinder_config('DEFAULT/storage_availability_zone').with(
73         :value => 'nova'
74       )
75       should contain_cinder_config('DEFAULT/default_availability_zone').with(
76         :value => 'nova'
77       )
78       should contain_cinder_config('DEFAULT/api_paste_config').with(
79         :value => '/etc/cinder/api-paste.ini'
80       )
81       should contain_cinder_config('DEFAULT/log_dir').with(:value => '/var/log/cinder')
82     end
83
84     it { should contain_file('/etc/cinder/cinder.conf').with(
85       :owner   => 'cinder',
86       :group   => 'cinder',
87       :mode    => '0600',
88       :require => 'Package[cinder]'
89     ) }
90
91     it { should contain_file('/etc/cinder/api-paste.ini').with(
92       :owner   => 'cinder',
93       :group   => 'cinder',
94       :mode    => '0600',
95       :require => 'Package[cinder]'
96     ) }
97
98   end
99   describe 'with modified rabbit_hosts' do
100     let :params do
101       req_params.merge({'rabbit_hosts' => ['rabbit1:5672', 'rabbit2:5672']})
102     end
103
104     it 'should contain many' do
105       should contain_cinder_config('DEFAULT/rabbit_host').with(
106         :value => nil
107       )
108       should contain_cinder_config('DEFAULT/rabbit_port').with(
109         :value => nil
110       )
111       should contain_cinder_config('DEFAULT/rabbit_hosts').with(
112         :value => 'rabbit1:5672,rabbit2:5672'
113       )
114       should contain_cinder_config('DEFAULT/rabbit_ha_queues').with(
115         :value => true
116       )
117     end
118   end
119
120   describe 'with a single rabbit_hosts entry' do
121     let :params do
122       req_params.merge({'rabbit_hosts' => ['rabbit1:5672']})
123     end
124
125     it 'should contain many' do
126       should contain_cinder_config('DEFAULT/rabbit_host').with(
127         :value => nil
128       )
129       should contain_cinder_config('DEFAULT/rabbit_port').with(
130         :value => nil
131       )
132       should contain_cinder_config('DEFAULT/rabbit_hosts').with(
133         :value => 'rabbit1:5672'
134       )
135       should contain_cinder_config('DEFAULT/rabbit_ha_queues').with(
136         :value => true
137       )
138     end
139   end
140
141   describe 'with qpid rpc supplied' do
142
143     let :params do
144       {
145         :database_connection => 'mysql://user:password@host/database',
146         :qpid_password       => 'guest',
147         :rpc_backend         => 'cinder.openstack.common.rpc.impl_qpid'
148       }
149     end
150
151     it { should contain_cinder_config('database/connection').with_value('mysql://user:password@host/database') }
152     it { should contain_cinder_config('DEFAULT/rpc_backend').with_value('cinder.openstack.common.rpc.impl_qpid') }
153     it { should contain_cinder_config('DEFAULT/qpid_hostname').with_value('localhost') }
154     it { should contain_cinder_config('DEFAULT/qpid_port').with_value('5672') }
155     it { should contain_cinder_config('DEFAULT/qpid_username').with_value('guest') }
156     it { should contain_cinder_config('DEFAULT/qpid_password').with_value('guest').with_secret(true) }
157     it { should contain_cinder_config('DEFAULT/qpid_reconnect').with_value(true) }
158     it { should contain_cinder_config('DEFAULT/qpid_reconnect_timeout').with_value('0') }
159     it { should contain_cinder_config('DEFAULT/qpid_reconnect_limit').with_value('0') }
160     it { should contain_cinder_config('DEFAULT/qpid_reconnect_interval_min').with_value('0') }
161     it { should contain_cinder_config('DEFAULT/qpid_reconnect_interval_max').with_value('0') }
162     it { should contain_cinder_config('DEFAULT/qpid_reconnect_interval').with_value('0') }
163     it { should contain_cinder_config('DEFAULT/qpid_heartbeat').with_value('60') }
164     it { should contain_cinder_config('DEFAULT/qpid_protocol').with_value('tcp') }
165     it { should contain_cinder_config('DEFAULT/qpid_tcp_nodelay').with_value(true) }
166   end
167
168   describe 'with qpid rpc and no qpid_sasl_mechanisms' do
169     let :params do
170       {
171         :database_connection  => 'mysql://user:password@host/database',
172         :qpid_password        => 'guest',
173         :rpc_backend          => 'cinder.openstack.common.rpc.impl_qpid'
174       }
175     end
176
177     it { should contain_cinder_config('DEFAULT/qpid_sasl_mechanisms').with_ensure('absent') }
178   end
179
180   describe 'with qpid rpc and qpid_sasl_mechanisms string' do
181     let :params do
182       {
183         :database_connection  => 'mysql://user:password@host/database',
184         :qpid_password        => 'guest',
185         :qpid_sasl_mechanisms => 'PLAIN',
186         :rpc_backend          => 'cinder.openstack.common.rpc.impl_qpid'
187       }
188     end
189
190     it { should contain_cinder_config('DEFAULT/qpid_sasl_mechanisms').with_value('PLAIN') }
191   end
192
193   describe 'with qpid rpc and qpid_sasl_mechanisms array' do
194     let :params do
195       {
196         :database_connection  => 'mysql://user:password@host/database',
197         :qpid_password        => 'guest',
198         :qpid_sasl_mechanisms => [ 'DIGEST-MD5', 'GSSAPI', 'PLAIN' ],
199         :rpc_backend          => 'cinder.openstack.common.rpc.impl_qpid'
200       }
201     end
202
203     it { should contain_cinder_config('DEFAULT/qpid_sasl_mechanisms').with_value('DIGEST-MD5 GSSAPI PLAIN') }
204   end
205
206   describe 'with SSL enabled with kombu' do
207     let :params do
208       req_params.merge!({
209         :rabbit_use_ssl     => true,
210         :kombu_ssl_ca_certs => '/path/to/ssl/ca/certs',
211         :kombu_ssl_certfile => '/path/to/ssl/cert/file',
212         :kombu_ssl_keyfile  => '/path/to/ssl/keyfile',
213         :kombu_ssl_version  => 'TLSv1'
214       })
215     end
216
217     it do
218       should contain_cinder_config('DEFAULT/rabbit_use_ssl').with_value('true')
219       should contain_cinder_config('DEFAULT/kombu_ssl_ca_certs').with_value('/path/to/ssl/ca/certs')
220       should contain_cinder_config('DEFAULT/kombu_ssl_certfile').with_value('/path/to/ssl/cert/file')
221       should contain_cinder_config('DEFAULT/kombu_ssl_keyfile').with_value('/path/to/ssl/keyfile')
222       should contain_cinder_config('DEFAULT/kombu_ssl_version').with_value('TLSv1')
223     end
224   end
225
226   describe 'with SSL enabled without kombu' do
227     let :params do
228       req_params.merge!({
229         :rabbit_use_ssl     => true,
230       })
231     end
232
233     it do
234       should contain_cinder_config('DEFAULT/rabbit_use_ssl').with_value('true')
235       should contain_cinder_config('DEFAULT/kombu_ssl_ca_certs').with_ensure('absent')
236       should contain_cinder_config('DEFAULT/kombu_ssl_certfile').with_ensure('absent')
237       should contain_cinder_config('DEFAULT/kombu_ssl_keyfile').with_ensure('absent')
238       should contain_cinder_config('DEFAULT/kombu_ssl_version').with_value('TLSv1')
239     end
240   end
241
242   describe 'with SSL disabled' do
243     let :params do
244       req_params.merge!({
245         :rabbit_use_ssl     => false,
246         :kombu_ssl_ca_certs => 'undef',
247         :kombu_ssl_certfile => 'undef',
248         :kombu_ssl_keyfile  => 'undef',
249         :kombu_ssl_version  => 'TLSv1'
250       })
251     end
252
253     it do
254       should contain_cinder_config('DEFAULT/rabbit_use_ssl').with_value('false')
255       should contain_cinder_config('DEFAULT/kombu_ssl_ca_certs').with_ensure('absent')
256       should contain_cinder_config('DEFAULT/kombu_ssl_certfile').with_ensure('absent')
257       should contain_cinder_config('DEFAULT/kombu_ssl_keyfile').with_ensure('absent')
258       should contain_cinder_config('DEFAULT/kombu_ssl_version').with_ensure('absent')
259     end
260   end
261
262   describe 'with syslog disabled' do
263     let :params do
264       req_params
265     end
266
267     it { should contain_cinder_config('DEFAULT/use_syslog').with_value(false) }
268   end
269
270   describe 'with syslog enabled' do
271     let :params do
272       req_params.merge({
273         :use_syslog   => 'true',
274       })
275     end
276
277     it { should contain_cinder_config('DEFAULT/use_syslog').with_value(true) }
278     it { should contain_cinder_config('DEFAULT/syslog_log_facility').with_value('LOG_USER') }
279   end
280
281   describe 'with syslog enabled and custom settings' do
282     let :params do
283       req_params.merge({
284         :use_syslog   => 'true',
285         :log_facility => 'LOG_LOCAL0'
286      })
287     end
288
289     it { should contain_cinder_config('DEFAULT/use_syslog').with_value(true) }
290     it { should contain_cinder_config('DEFAULT/syslog_log_facility').with_value('LOG_LOCAL0') }
291   end
292
293   describe 'with log_dir disabled' do
294     let(:params) { req_params.merge!({:log_dir => false}) }
295     it { should contain_cinder_config('DEFAULT/log_dir').with_ensure('absent') }
296   end
297
298   describe 'with amqp_durable_queues disabled' do
299     let :params do
300       req_params
301     end
302
303     it { should contain_cinder_config('DEFAULT/amqp_durable_queues').with_value(false) }
304   end
305
306   describe 'with amqp_durable_queues enabled' do
307     let :params do
308       req_params.merge({
309         :amqp_durable_queues => true,
310       })
311     end
312
313     it { should contain_cinder_config('DEFAULT/amqp_durable_queues').with_value(true) }
314   end
315
316   describe 'with postgresql' do
317     let :params do
318       {
319         :database_connection      => 'postgresql://user:drowssap@host/database',
320         :rabbit_password       => 'guest',
321       }
322     end
323
324     it { should contain_cinder_config('database/connection').with(
325       :value  => 'postgresql://user:drowssap@host/database',
326       :secret => true
327     ) }
328     it { should_not contain_class('mysql::python') }
329     it { should_not contain_class('mysql::bindings') }
330     it { should_not contain_class('mysql::bindings::python') }
331   end
332
333   describe 'with SSL socket options set' do
334     let :params do
335       {
336         :use_ssl         => true,
337         :cert_file       => '/path/to/cert',
338         :ca_file         => '/path/to/ca',
339         :key_file        => '/path/to/key',
340         :rabbit_password => 'guest',
341       }
342     end
343
344     it { should contain_cinder_config('DEFAULT/ssl_ca_file').with_value('/path/to/ca') }
345     it { should contain_cinder_config('DEFAULT/ssl_cert_file').with_value('/path/to/cert') }
346     it { should contain_cinder_config('DEFAULT/ssl_key_file').with_value('/path/to/key') }
347   end
348
349   describe 'with SSL socket options set to false' do
350     let :params do
351       {
352         :use_ssl         => false,
353         :cert_file       => false,
354         :ca_file         => false,
355         :key_file        => false,
356         :rabbit_password => 'guest',
357       }
358     end
359
360     it { should contain_cinder_config('DEFAULT/ssl_ca_file').with_ensure('absent') }
361     it { should contain_cinder_config('DEFAULT/ssl_cert_file').with_ensure('absent') }
362     it { should contain_cinder_config('DEFAULT/ssl_key_file').with_ensure('absent') }
363   end
364
365   describe 'with SSL socket options set wrongly configured' do
366     let :params do
367       {
368         :use_ssl         => true,
369         :ca_file         => '/path/to/ca',
370         :key_file        => '/path/to/key',
371         :rabbit_password => 'guest',
372       }
373     end
374
375     it 'should raise an error' do
376       expect {
377         should compile
378       }.to raise_error Puppet::Error, /The cert_file parameter is required when use_ssl is set to true/
379     end
380   end
381
382 end