From: Emilien Macchi Date: Mon, 11 May 2015 19:38:43 +0000 (-0400) Subject: Bring Redhat support to acceptance tests X-Git-Tag: 6.0.0~23 X-Git-Url: https://review.fuel-infra.org/gitweb?a=commitdiff_plain;h=c2e9179394077e838b50fbe501f181fe04729010;p=puppet-modules%2Fpuppet-ceilometer.git Bring Redhat support to acceptance tests OpenStack Infra has jobs to run this on both Ubuntu Trusty and CentOS7. * Add minitest to Gemfile (dependency to run beaker on centos - see http://projects.theforeman.org/issues/2650 for details) * separate nodepool files to have trusty & centos7 support in OS infra * basic_keystone_spec: add case for repo configuration and support RH systems. * rabbitmq: install module from source and on RH, install erlang before rabbitmq-server. Change-Id: Ie6c823c7906afb37dd9e49fa434fefc3e26b5569 Closes-bug: #1444736 --- diff --git a/Gemfile b/Gemfile index 571fd65..4c65317 100644 --- a/Gemfile +++ b/Gemfile @@ -3,6 +3,7 @@ source 'https://rubygems.org' group :development, :test do gem 'puppetlabs_spec_helper', :require => false gem 'rspec-puppet', '~> 2.1.0', :require => false + gem 'minitest', '~> 4.7', :require => 'minitest/unit' gem 'metadata-json-lint' gem 'puppet-lint-param-docs' diff --git a/spec/acceptance/ceilometer_with_mysql_spec.rb b/spec/acceptance/ceilometer_with_mysql_spec.rb index 7d69982..6a98d1e 100644 --- a/spec/acceptance/ceilometer_with_mysql_spec.rb +++ b/spec/acceptance/ceilometer_with_mysql_spec.rb @@ -9,10 +9,33 @@ describe 'ceilometer with mysql' do Exec { logoutput => 'on_failure' } # Common resources - include ::apt - class { '::openstack_extras::repo::debian::ubuntu': - release => 'kilo', - package_require => true, + case $::osfamily { + 'Debian': { + include ::apt + class { '::openstack_extras::repo::debian::ubuntu': + release => 'kilo', + package_require => true, + } + } + 'RedHat': { + class { '::openstack_extras::repo::redhat::redhat': + # Kilo is not GA yet, so let's use the testing repo + manage_rdo => false, + repo_hash => { + 'rdo-kilo-testing' => { + 'baseurl' => 'https://repos.fedorapeople.org/repos/openstack/openstack-kilo/testing/el7/', + # packages are not GA so not signed + 'gpgcheck' => '0', + 'priority' => 97, + }, + }, + } + include ::erlang + Class['erlang'] -> Class['rabbitmq'] + } + default: { + fail("Unsupported osfamily (${::osfamily})") + } } class { '::mysql::server': } diff --git a/spec/acceptance/nodesets/nodepool-centos7.yml b/spec/acceptance/nodesets/nodepool-centos7.yml new file mode 100644 index 0000000..aed4f0b --- /dev/null +++ b/spec/acceptance/nodesets/nodepool-centos7.yml @@ -0,0 +1,9 @@ +HOSTS: + centos-70-x64: + roles: + - master + platform: el-7-x86_64 + hypervisor : none + ip: 127.0.0.1 +CONFIG: + type: foss diff --git a/spec/acceptance/nodesets/nodepool.yml b/spec/acceptance/nodesets/nodepool-trusty.yml similarity index 100% rename from spec/acceptance/nodesets/nodepool.yml rename to spec/acceptance/nodesets/nodepool-trusty.yml diff --git a/spec/spec_helper_acceptance.rb b/spec/spec_helper_acceptance.rb index 5e33401..2d49992 100644 --- a/spec/spec_helper_acceptance.rb +++ b/spec/spec_helper_acceptance.rb @@ -31,12 +31,15 @@ RSpec.configure do |c| on host, puppet('module','install','puppetlabs-mysql'), { :acceptable_exit_codes => 0 } on host, puppet('module','install','dprince/qpid'), { :acceptable_exit_codes => 0 } on host, puppet('module','install','stahnma-epel'), { :acceptable_exit_codes => 0 } - on host, puppet('module','install','puppetlabs-rabbitmq'), { :acceptable_exit_codes => 0 } + on host, puppet('module','install','garethr-erlang'), { :acceptable_exit_codes => 0 } # install puppet modules from git, use master shell('git clone https://git.openstack.org/stackforge/puppet-openstacklib /etc/puppet/modules/openstacklib') shell('git clone https://git.openstack.org/stackforge/puppet-openstack_extras /etc/puppet/modules/openstack_extras') shell('git clone https://git.openstack.org/stackforge/puppet-keystone /etc/puppet/modules/keystone') + # TODO(EmilienM) Cloning RabbitMQ module for now because we wait for a release including + # https://github.com/enovance/puppetlabs-rabbitmq/commit/0227f762070ffbbea3c28d6a60174de98fa4cc1c + shell('git clone https://github.com/puppetlabs/puppetlabs-rabbitmq/ /etc/puppet/modules/rabbitmq') # Install the module being tested puppet_module_install(:source => proj_root, :module_name => 'ceilometer')