3 require 'puppet/provider/keystone_role/openstack'
5 provider_class = Puppet::Type.type(:keystone_role).provider(:openstack)
7 describe provider_class do
9 shared_examples 'authenticated with environment variables' do
10 ENV['OS_USERNAME'] = 'test'
11 ENV['OS_PASSWORD'] = 'abc123'
12 ENV['OS_PROJECT_NAME'] = 'test'
13 ENV['OS_AUTH_URL'] = 'http://127.0.0.1:5000'
16 describe 'when creating a role' do
17 it_behaves_like 'authenticated with environment variables' do
26 Puppet::Type::Keystone_role.new(role_attrs)
30 provider_class.new(resource)
34 it 'creates a role' do
35 provider.class.expects(:openstack)
36 .with('role', 'create', '--format', 'shell', 'foo')
37 .returns('name="foo"')
39 expect(provider.exists?).to be_truthy
43 describe '#destroy' do
44 it 'destroys a role' do
45 provider.class.expects(:openstack)
46 .with('role', 'delete', [])
48 expect(provider.exists?).to be_falsey
54 context 'when role does not exist' do
56 response = provider.exists?
58 it { is_expected.to be_falsey }
62 describe '#instances' do
63 it 'finds every role' do
64 provider.class.expects(:openstack)
65 .with('role', 'list', '--quiet', '--format', 'csv', [])
67 "1cb05cfed7c24279be884ba4f6520262","foo"
69 instances = Puppet::Type::Keystone_role::ProviderOpenstack.instances
70 expect(instances.count).to eq(1)