abd313ac8d
* Update metadata versions * Updates for icehouse specific attributes * Removing Strainer file * Updating Gems * chef (11.12.0) * chefspec (4.0.0) * rspec (3.0.0) * Cleanup specs for 4.x Change-Id: I9a495cdb90feaf7508a5b861557856dd19340272 Partial-Bug: 1349865
150 lines
5.0 KiB
Ruby
Executable File
150 lines
5.0 KiB
Ruby
Executable File
# encoding: UTF-8
|
|
require_relative 'spec_helper'
|
|
require ::File.join ::File.dirname(__FILE__), '..', 'libraries', 'cli'
|
|
|
|
describe 'openstack-common::default' do
|
|
describe 'Openstack CLI' do
|
|
let(:runner) { ChefSpec::Runner.new(CHEFSPEC_OPTS) }
|
|
let(:node) { runner.node }
|
|
let(:chef_run) do
|
|
runner.converge(described_recipe)
|
|
end
|
|
let(:subject) { Object.new.extend(Openstack) }
|
|
|
|
include_context 'library-stubs'
|
|
|
|
describe 'openstack_command_env' do
|
|
it 'returns cli enviroment' do
|
|
allow(subject).to receive(:get_password)
|
|
.with('user', 'name')
|
|
.and_return('pass')
|
|
|
|
expect(
|
|
subject.openstack_command_env('name', 'tenant')
|
|
).to eq(
|
|
'OS_USERNAME' => 'name',
|
|
'OS_PASSWORD' => 'pass',
|
|
'OS_TENANT_NAME' => 'tenant',
|
|
'OS_AUTH_URL' => 'http://127.0.0.1:35357/v2.0'
|
|
)
|
|
end
|
|
end
|
|
|
|
describe 'openstack_command' do
|
|
it 'runs openstack command' do
|
|
env =
|
|
{
|
|
'OS_USERNAME' => 'name',
|
|
'OS_PASSWORD' => 'pass',
|
|
'OS_TENANT_NAME' => 'tenant',
|
|
'OS_AUTH_URL' => 'http://127.0.0.1:35357/v2.0'
|
|
}
|
|
allow(subject).to receive(:shell_out).with(
|
|
['keystone', 'user-list'],
|
|
env: env
|
|
).and_return double('shell_out', exitstatus: 0, stdout: 'good', stderr: '')
|
|
|
|
result = subject.openstack_command('keystone', 'user-list', env)
|
|
expect(result).to eq('good')
|
|
end
|
|
|
|
it 'runs openstack command with args' do
|
|
env =
|
|
{
|
|
'OS_USERNAME' => 'name',
|
|
'OS_PASSWORD' => 'pass',
|
|
'OS_TENANT_NAME' => 'tenant',
|
|
'OS_AUTH_URL' => 'http://127.0.0.1:35357/v2.0'
|
|
}
|
|
allow(subject).to receive(:shell_out).with(
|
|
%w(keystone user-list --key1 value1 --key2 value2),
|
|
env: env
|
|
).and_return double('shell_out', exitstatus: 0, stdout: 'good', stderr: '')
|
|
|
|
result = subject.openstack_command('keystone', 'user-list', env, 'key1' => 'value1', 'key2' => 'value2')
|
|
expect(result).to eq('good')
|
|
end
|
|
|
|
it 'runs openstack command with failure' do
|
|
env =
|
|
{
|
|
'OS_USERNAME' => 'name',
|
|
'OS_PASSWORD' => 'pass',
|
|
'OS_TENANT_NAME' => 'tenant',
|
|
'OS_AUTH_URL' => 'http://127.0.0.1:35357/v2.0'
|
|
}
|
|
allow(subject).to receive(:shell_out).with(
|
|
['keystone', 'user-list'],
|
|
env: env
|
|
).and_return double('shell_out', exitstatus: 123, stdout: 'fail', stderr: '')
|
|
|
|
# TODO: need to figure out why this won't work.
|
|
# expect(subject.openstack_command('keystone', 'user-list', env)).to fail
|
|
end
|
|
end
|
|
|
|
describe 'identity_uuid' do
|
|
it 'runs identity command to query uuid' do
|
|
env =
|
|
{
|
|
'OS_USERNAME' => 'name',
|
|
'OS_PASSWORD' => 'pass',
|
|
'OS_TENANT_NAME' => 'tenant',
|
|
'OS_AUTH_URL' => 'http://127.0.0.1:35357/v2.0'
|
|
}
|
|
allow(subject).to receive(:openstack_command).with('keystone', 'user-list', env, {})
|
|
allow(subject).to receive(:prettytable_to_array)
|
|
.and_return([{ 'name' => 'user1', 'id' => '1234567890ABCDEFGH' }])
|
|
|
|
result = subject.identity_uuid('user', 'name', 'user1', env)
|
|
expect(result).to eq('1234567890ABCDEFGH')
|
|
end
|
|
end
|
|
|
|
describe 'image_id' do
|
|
let(:env) do
|
|
{
|
|
'OS_USERNAME' => 'name',
|
|
'OS_PASSWORD' => 'pass',
|
|
'OS_TENANT_NAME' => 'tenant',
|
|
'OS_AUTH_URL' => 'http://127.0.0.1:35357/v2.0'
|
|
}
|
|
end
|
|
|
|
it 'runs glance command to query valid id' do
|
|
allow(subject).to receive(:openstack_command).with('glance', 'image-list', :env, {})
|
|
allow(subject).to receive(:prettytable_to_array)
|
|
.and_return([{ 'ID' => '87f38e15-9737-46cc-a612-7c67ee29a24f', 'Name' => 'cirros' }])
|
|
|
|
result = subject.image_id('cirros', :env)
|
|
expect(result).to eq('87f38e15-9737-46cc-a612-7c67ee29a24f')
|
|
end
|
|
|
|
it 'runs glance command to query invalid id' do
|
|
allow(subject).to receive(:openstack_command).with('glance', 'image-list', :env, {})
|
|
.and_raise("No image with a name or ID of 'test' exists. (1)")
|
|
|
|
expect { subject.image_id('test', :env) }.to raise_error
|
|
end
|
|
end
|
|
|
|
describe 'network_uuid' do
|
|
it 'runs network command to query uuid' do
|
|
env =
|
|
{
|
|
'OS_USERNAME' => 'name',
|
|
'OS_PASSWORD' => 'pass',
|
|
'OS_TENANT_NAME' => 'tenant',
|
|
'OS_AUTH_URL' => 'http://127.0.0.1:35357/v2.0'
|
|
}
|
|
allow(subject).to receive(:openstack_command).with('neutron', 'net-list', env, {})
|
|
allow(subject).to receive(:prettytable_to_array)
|
|
.and_return([{ 'name' => 'net1', 'id' => '1234567890ABCDEFGH' }])
|
|
|
|
result = subject.network_uuid('net', 'name', 'net1', env)
|
|
expect(result).to eq('1234567890ABCDEFGH')
|
|
end
|
|
end
|
|
end
|
|
end
|