
Current puppet-ceph CI is broken for all functional jobs. I would like to restart from scratch the way we test the module. 1) centos7: deploy Jewel using buildlogs.centos.org repo CentOS SIG does not provide packaging to deploy the Jewel repository, let's install it by hand. 2) Remove RGW tests for now. We'll re-add them later, in a puppet-openstack-integration scenario. 3) Reset spec files to match with other Puppet OpenStack modules. 4) On CentOS, use systemd resource and not sysvinit. 5) Fix keyring idempotency with SElinux. Change-Id: Ie9ba521cdb4ac6823746d37bb5d1697e274e4119
89 lines
2.3 KiB
Ruby
89 lines
2.3 KiB
Ruby
#
|
|
# Copyright (C) 2014 Catalyst IT Limited.
|
|
#
|
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
# you may not use this file except in compliance with the License.
|
|
# You may obtain a copy of the License at
|
|
#
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
#
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
# See the License for the specific language governing permissions and
|
|
# limitations under the License.
|
|
#
|
|
# Author: Ricardo Rocha <ricardo@catalyst.net.nz>
|
|
#
|
|
|
|
require 'spec_helper'
|
|
|
|
describe 'ceph::key' do
|
|
|
|
shared_examples_for 'ceph key' do
|
|
|
|
describe "with custom params" do
|
|
|
|
let :title do
|
|
'client.admin'
|
|
end
|
|
|
|
let :params do
|
|
{
|
|
:secret => 'supersecret',
|
|
:user => 'nobody',
|
|
:group => 'nogroup',
|
|
:cap_mon => 'allow *',
|
|
:cap_osd => 'allow rw',
|
|
:inject => true,
|
|
}
|
|
end
|
|
|
|
it {
|
|
is_expected.to contain_exec('ceph-key-client.admin').with(
|
|
'command' => "/bin/true # comment to satisfy puppet syntax requirements\nset -ex\nceph-authtool /etc/ceph/ceph.client.admin.keyring --name 'client.admin' --add-key 'supersecret' --cap mon 'allow *' --cap osd 'allow rw' "
|
|
)
|
|
is_expected.to contain_file('/etc/ceph/ceph.client.admin.keyring').with(
|
|
'owner' => 'nobody',
|
|
'group' => 'nogroup',
|
|
'mode' => '0600',
|
|
'selinux_ignore_defaults' => true,
|
|
)
|
|
is_expected.to contain_exec('ceph-injectkey-client.admin').with(
|
|
'command' => "/bin/true # comment to satisfy puppet syntax requirements\nset -ex\nceph auth add client.admin --in-file=/etc/ceph/ceph.client.admin.keyring"
|
|
)
|
|
}
|
|
|
|
end
|
|
end
|
|
|
|
describe 'Debian Family' do
|
|
|
|
let :facts do
|
|
{
|
|
:osfamily => 'Debian',
|
|
}
|
|
end
|
|
|
|
it_configures 'ceph key'
|
|
end
|
|
|
|
describe 'RedHat Family' do
|
|
|
|
let :facts do
|
|
{
|
|
:osfamily => 'RedHat',
|
|
}
|
|
end
|
|
|
|
it_configures 'ceph key'
|
|
end
|
|
end
|
|
|
|
# Local Variables:
|
|
# compile-command: "cd ../.. ;
|
|
# bundle install ;
|
|
# bundle exec rake spec
|
|
# "
|
|
# End:
|