 0566bf9578
			
		
	
	0566bf9578
	
	
	
		
			
			This uses edit_resource to add a notification in the block storage apache configuration when it gets updated. This is a workaround due to the fact we are using a version of the apache2 cookbook that is still using definitions and cannot add notifications with definitions. This will be removed in the Stein release when we migrate to the newer apache2 cookbook which uses proper resources. Change-Id: I7efddef83333ca0794ee3c298ca1a2488defe941 Signed-off-by: Lance Albertson <lance@osuosl.org>
		
			
				
	
	
		
			76 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			Ruby
		
	
	
	
	
	
			
		
		
	
	
			76 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			Ruby
		
	
	
	
	
	
| # encoding: UTF-8
 | |
| #
 | |
| # Cookbook Name:: openstack-block-storage
 | |
| 
 | |
| require_relative 'spec_helper'
 | |
| 
 | |
| describe 'openstack-block-storage::api' do
 | |
|   describe 'ubuntu' do
 | |
|     let(:runner) { ChefSpec::SoloRunner.new(UBUNTU_OPTS) }
 | |
|     let(:node) { runner.node }
 | |
|     let(:chef_run) { runner.converge(described_recipe) }
 | |
| 
 | |
|     include_context 'block-storage-stubs'
 | |
|     include_examples 'common-logging'
 | |
|     include_examples 'creates_cinder_conf', 'execute[Clear cinder-api apache restart]', 'cinder', 'cinder', 'run'
 | |
| 
 | |
|     it do
 | |
|       expect(chef_run).to nothing_execute('Clear cinder-api apache restart')
 | |
|         .with(
 | |
|           command: 'rm -f /var/chef/cache/cinder-api-apache-restarted'
 | |
|         )
 | |
|     end
 | |
| 
 | |
|     %w(
 | |
|       /etc/cinder/cinder.conf
 | |
|       /etc/apache2/sites-available/cinder-api.conf
 | |
|     ).each do |f|
 | |
|       it "#{f} notifies execute[Clear cinder-api apache restart]" do
 | |
|         expect(chef_run.template(f)).to notify('execute[Clear cinder-api apache restart]').to(:run).immediately
 | |
|       end
 | |
|     end
 | |
| 
 | |
|     it do
 | |
|       expect(chef_run).to run_execute('cinder-api apache restart')
 | |
|         .with(
 | |
|           command: 'touch /var/chef/cache/cinder-api-apache-restarted',
 | |
|           creates: '/var/chef/cache/cinder-api-apache-restarted'
 | |
|         )
 | |
|     end
 | |
| 
 | |
|     it do
 | |
|       expect(chef_run.execute('cinder-api apache restart')).to notify('service[apache2]').to(:restart).immediately
 | |
|     end
 | |
| 
 | |
|     it 'upgrades cinder api packages' do
 | |
|       expect(chef_run).to upgrade_package('cinder-api')
 | |
|     end
 | |
| 
 | |
|     it 'upgrades mysql python package' do
 | |
|       expect(chef_run).to upgrade_package('python-mysqldb')
 | |
|     end
 | |
| 
 | |
|     it 'runs db migrations' do
 | |
|       expect(chef_run).to run_execute('cinder-manage db sync').with(user: 'cinder', group: 'cinder')
 | |
|     end
 | |
| 
 | |
|     describe 'policy file' do
 | |
|       it 'does not manage policy file unless specified' do
 | |
|         expect(chef_run).not_to create_remote_file('/etc/cinder/policy.json')
 | |
|       end
 | |
|       describe 'policy file specified' do
 | |
|         before { node.override['openstack']['block-storage']['policyfile_url'] = 'http://server/mypolicy.json' }
 | |
|         let(:remote_policy) { chef_run.remote_file('/etc/cinder/policy.json') }
 | |
| 
 | |
|         it 'manages policy file when remote file is specified' do
 | |
|           expect(chef_run).to create_remote_file('/etc/cinder/policy.json').with(
 | |
|             user: 'cinder',
 | |
|             group: 'cinder',
 | |
|             mode: 0o0644
 | |
|           )
 | |
|         end
 | |
|       end
 | |
|     end
 | |
|   end
 | |
| end
 |