Rewrite Request expectations as macros for readability
This commit is contained in:
@@ -38,22 +38,44 @@ class Aviator::Test
|
||||
end
|
||||
|
||||
|
||||
it 'has the correct endpoint type' do
|
||||
validate :anonymous? do
|
||||
klass.anonymous?.must_equal false
|
||||
end
|
||||
|
||||
|
||||
validate :api_version do
|
||||
klass.api_version.must_equal :v2
|
||||
end
|
||||
|
||||
|
||||
validate :body do
|
||||
klass.body?.must_equal false
|
||||
create_request.body?.must_equal false
|
||||
end
|
||||
|
||||
|
||||
validate :endpoint_type do
|
||||
klass.endpoint_type.must_equal :public
|
||||
end
|
||||
|
||||
|
||||
it 'has the correct api version' do
|
||||
klass.api_version.must_equal :v2
|
||||
validate :headers do
|
||||
session_data = new_session_data
|
||||
|
||||
headers = { 'X-Auth-Token' => session_data[:access][:token][:id] }
|
||||
|
||||
request = create_request(session_data)
|
||||
|
||||
request.headers.must_equal headers
|
||||
end
|
||||
|
||||
|
||||
it 'has the correct http method' do
|
||||
validate :http_method do
|
||||
klass.http_method.must_equal :get
|
||||
end
|
||||
|
||||
|
||||
it 'has the correct list of optional parameters' do
|
||||
validate :optional_params do
|
||||
klass.optional_params.must_equal [
|
||||
:details,
|
||||
:server,
|
||||
@@ -67,12 +89,12 @@ class Aviator::Test
|
||||
end
|
||||
|
||||
|
||||
it 'has the correct list of required parameters' do
|
||||
validate :required_params do
|
||||
klass.required_params.must_equal []
|
||||
end
|
||||
|
||||
|
||||
it 'has the correct url' do
|
||||
validate :url do
|
||||
session_data = new_session_data
|
||||
service_spec = session_data[:access][:serviceCatalog].find{|s| s[:type] == 'compute' }
|
||||
url = "#{ service_spec[:endpoints][0][:publicURL] }/images"
|
||||
@@ -101,24 +123,7 @@ class Aviator::Test
|
||||
end
|
||||
|
||||
|
||||
it 'has the correct headers' do
|
||||
session_data = new_session_data
|
||||
|
||||
headers = { 'X-Auth-Token' => session_data[:access][:token][:id] }
|
||||
|
||||
request = create_request(session_data)
|
||||
|
||||
request.headers.must_equal headers
|
||||
end
|
||||
|
||||
|
||||
it 'has the correct body' do
|
||||
klass.body?.must_equal false
|
||||
create_request.body?.must_equal false
|
||||
end
|
||||
|
||||
|
||||
it 'leads to a valid response when no parameters are provided' do
|
||||
validate_response 'no parameters are provided' do
|
||||
service = Aviator::Service.new(
|
||||
provider: 'openstack',
|
||||
service: 'compute',
|
||||
@@ -133,7 +138,25 @@ class Aviator::Test
|
||||
end
|
||||
|
||||
|
||||
it 'leads to a valid response when parameters are provided' do
|
||||
validate_response 'parameters are invalid' do
|
||||
service = Aviator::Service.new(
|
||||
provider: 'openstack',
|
||||
service: 'compute',
|
||||
default_session_data: new_session_data
|
||||
)
|
||||
|
||||
response = service.request :list_images do |params|
|
||||
params[:name] = "nonexistentimagenameherpderp"
|
||||
end
|
||||
|
||||
response.status.must_equal 200
|
||||
response.body.wont_be_nil
|
||||
response.body[:images].length.must_equal 0
|
||||
response.headers.wont_be_nil
|
||||
end
|
||||
|
||||
|
||||
validate_response 'parameters are valid' do
|
||||
service = Aviator::Service.new(
|
||||
provider: 'openstack',
|
||||
service: 'compute',
|
||||
@@ -151,24 +174,6 @@ class Aviator::Test
|
||||
response.headers.wont_be_nil
|
||||
end
|
||||
|
||||
|
||||
it 'leads to a valid response when provided with invalid params' do
|
||||
service = Aviator::Service.new(
|
||||
provider: 'openstack',
|
||||
service: 'compute',
|
||||
default_session_data: new_session_data
|
||||
)
|
||||
|
||||
response = service.request :list_images do |params|
|
||||
params[:name] = "nonexistentimagenameherpderp"
|
||||
end
|
||||
|
||||
response.status.must_equal 200
|
||||
response.body.wont_be_nil
|
||||
response.body[:images].length.must_equal 0
|
||||
response.headers.wont_be_nil
|
||||
end
|
||||
|
||||
end
|
||||
|
||||
end
|
||||
@@ -42,47 +42,17 @@ class Aviator::Test
|
||||
end
|
||||
|
||||
|
||||
it 'has the correct endpoint type' do
|
||||
klass.endpoint_type.must_equal :admin
|
||||
validate :api_version do
|
||||
klass.api_version.must_equal :v2
|
||||
end
|
||||
|
||||
|
||||
it 'has the correct api version' do
|
||||
klass.api_version.must_equal :v2
|
||||
validate :anonymous? do
|
||||
klass.anonymous?.must_equal false
|
||||
end
|
||||
|
||||
|
||||
it 'has the correct http method' do
|
||||
klass.http_method.must_equal :post
|
||||
end
|
||||
|
||||
|
||||
it 'has the correct list of required parameters' do
|
||||
klass.required_params.must_equal [:name, :description, :enabled]
|
||||
end
|
||||
|
||||
|
||||
it 'has the correct url' do
|
||||
session_data = helper.admin_session_data
|
||||
service_spec = session_data[:access][:serviceCatalog].find{|s| s[:type] == 'identity' }
|
||||
url = "#{ service_spec[:endpoints][0][:adminURL] }/tenants"
|
||||
|
||||
request = create_request
|
||||
|
||||
request.url.must_equal url
|
||||
end
|
||||
|
||||
|
||||
it 'has the correct headers' do
|
||||
headers = { 'X-Auth-Token' => helper.admin_session_data[:access][:token][:id] }
|
||||
|
||||
request = create_request
|
||||
|
||||
request.headers.must_equal headers
|
||||
end
|
||||
|
||||
|
||||
it 'has the correct body' do
|
||||
validate :body do
|
||||
params = {
|
||||
name: 'Project',
|
||||
description: 'My Project',
|
||||
@@ -103,7 +73,61 @@ class Aviator::Test
|
||||
end
|
||||
|
||||
|
||||
it 'leads to a valid response when provided with valid params' do
|
||||
validate :endpoint_type do
|
||||
klass.endpoint_type.must_equal :admin
|
||||
end
|
||||
|
||||
|
||||
validate :headers do
|
||||
headers = { 'X-Auth-Token' => helper.admin_session_data[:access][:token][:id] }
|
||||
|
||||
request = create_request
|
||||
|
||||
request.headers.must_equal headers
|
||||
end
|
||||
|
||||
|
||||
validate :http_method do
|
||||
klass.http_method.must_equal :post
|
||||
end
|
||||
|
||||
|
||||
validate :required_params do
|
||||
klass.required_params.must_equal [:name, :description, :enabled]
|
||||
end
|
||||
|
||||
|
||||
validate :url do
|
||||
session_data = helper.admin_session_data
|
||||
service_spec = session_data[:access][:serviceCatalog].find{|s| s[:type] == 'identity' }
|
||||
url = "#{ service_spec[:endpoints][0][:adminURL] }/tenants"
|
||||
|
||||
request = create_request
|
||||
|
||||
request.url.must_equal url
|
||||
end
|
||||
|
||||
|
||||
validate_response 'params are invalid' do
|
||||
service = Aviator::Service.new(
|
||||
provider: 'openstack',
|
||||
service: 'identity',
|
||||
default_session_data: new_session_data
|
||||
)
|
||||
|
||||
response = service.request :create_tenant do |params|
|
||||
params[:name] = ""
|
||||
params[:description] = ""
|
||||
params[:enabled] = true
|
||||
end
|
||||
|
||||
response.status.must_equal 400
|
||||
response.body.wont_be_nil
|
||||
response.headers.wont_be_nil
|
||||
end
|
||||
|
||||
|
||||
validate_response 'params are valid' do
|
||||
service = Aviator::Service.new(
|
||||
provider: 'openstack',
|
||||
service: 'identity',
|
||||
@@ -122,24 +146,6 @@ class Aviator::Test
|
||||
end
|
||||
|
||||
|
||||
it 'leads to a valid response when provided with invalid params' do
|
||||
service = Aviator::Service.new(
|
||||
provider: 'openstack',
|
||||
service: 'identity',
|
||||
default_session_data: new_session_data
|
||||
)
|
||||
|
||||
response = service.request :create_tenant do |params|
|
||||
params[:name] = ""
|
||||
params[:description] = ""
|
||||
params[:enabled] = true
|
||||
end
|
||||
|
||||
response.status.must_equal 400
|
||||
response.body.wont_be_nil
|
||||
response.headers.wont_be_nil
|
||||
end
|
||||
|
||||
end
|
||||
|
||||
end
|
||||
@@ -24,45 +24,17 @@ class Aviator::Test
|
||||
end
|
||||
|
||||
|
||||
it 'has the correct endpoint type' do
|
||||
klass.endpoint_type.must_equal :public
|
||||
validate :anonymous? do
|
||||
klass.anonymous?.must_equal true
|
||||
end
|
||||
|
||||
|
||||
it 'has the correct api version' do
|
||||
klass.api_version.must_equal :v2
|
||||
validate :api_version do
|
||||
klass.api_version.must_equal :v2
|
||||
end
|
||||
|
||||
|
||||
it 'has the correct http method' do
|
||||
klass.http_method.must_equal :post
|
||||
end
|
||||
|
||||
|
||||
it 'has the correct list of required parameters' do
|
||||
klass.required_params.must_equal []
|
||||
end
|
||||
|
||||
|
||||
it 'has the correct list of optional parameters' do
|
||||
klass.optional_params.must_equal [:username, :password, :tokenId, :tenantName, :tenantId]
|
||||
end
|
||||
|
||||
|
||||
it 'has the correct url' do
|
||||
session_data = helper.admin_bootstrap_session_data
|
||||
url = "#{ session_data[:auth_service][:host_uri] }/v2.0/tokens"
|
||||
|
||||
create_request.url.must_equal url
|
||||
end
|
||||
|
||||
|
||||
it 'has the correct headers' do
|
||||
create_request.headers?.must_equal false
|
||||
end
|
||||
|
||||
|
||||
it 'has the correct body' do
|
||||
validate :body do
|
||||
p = {
|
||||
auth: {
|
||||
passwordCredentials: {
|
||||
@@ -76,7 +48,59 @@ class Aviator::Test
|
||||
end
|
||||
|
||||
|
||||
it 'leads to a valid response when provided with valid params' do
|
||||
validate :endpoint_type do
|
||||
klass.endpoint_type.must_equal :public
|
||||
end
|
||||
|
||||
|
||||
validate :headers do
|
||||
create_request.headers?.must_equal false
|
||||
end
|
||||
|
||||
|
||||
validate :http_method do
|
||||
klass.http_method.must_equal :post
|
||||
end
|
||||
|
||||
|
||||
|
||||
validate :optional_params do
|
||||
klass.optional_params.must_equal [:username, :password, :tokenId, :tenantName, :tenantId]
|
||||
end
|
||||
|
||||
|
||||
validate :required_params do
|
||||
klass.required_params.must_equal []
|
||||
end
|
||||
|
||||
|
||||
validate :url do
|
||||
session_data = helper.admin_bootstrap_session_data
|
||||
url = "#{ session_data[:auth_service][:host_uri] }/v2.0/tokens"
|
||||
|
||||
create_request.url.must_equal url
|
||||
end
|
||||
|
||||
|
||||
validate_response 'parameters are invalid' do
|
||||
service = Aviator::Service.new(
|
||||
provider: 'openstack',
|
||||
service: 'identity',
|
||||
default_session_data: RequestHelper.admin_bootstrap_session_data
|
||||
)
|
||||
|
||||
response = service.request :create_token do |params|
|
||||
params[:username] = 'somebogususer'
|
||||
params[:password] = 'doesitreallymatter?'
|
||||
end
|
||||
|
||||
response.status.must_equal 401
|
||||
response.body.wont_be_nil
|
||||
response.headers.wont_be_nil
|
||||
end
|
||||
|
||||
|
||||
validate_response 'parameters are valid' do
|
||||
service = Aviator::Service.new(
|
||||
provider: 'openstack',
|
||||
service: 'identity',
|
||||
@@ -94,7 +118,7 @@ class Aviator::Test
|
||||
end
|
||||
|
||||
|
||||
it 'leads to a valid response when provided with a token' do
|
||||
validate_response 'provided with a token' do
|
||||
service = Aviator::Service.new(
|
||||
provider: 'openstack',
|
||||
service: 'identity',
|
||||
@@ -118,24 +142,6 @@ class Aviator::Test
|
||||
response.headers.wont_be_nil
|
||||
end
|
||||
|
||||
|
||||
it 'leads to a valid response when provided with invalid params' do
|
||||
service = Aviator::Service.new(
|
||||
provider: 'openstack',
|
||||
service: 'identity',
|
||||
default_session_data: RequestHelper.admin_bootstrap_session_data
|
||||
)
|
||||
|
||||
response = service.request :create_token do |params|
|
||||
params[:username] = 'somebogususer'
|
||||
params[:password] = 'doesitreallymatter?'
|
||||
end
|
||||
|
||||
response.status.must_equal 401
|
||||
response.body.wont_be_nil
|
||||
response.headers.wont_be_nil
|
||||
end
|
||||
|
||||
end
|
||||
|
||||
end
|
||||
@@ -1,27 +1,39 @@
|
||||
module Aviator
|
||||
class Test < MiniTest::Spec
|
||||
|
||||
def cassette_name
|
||||
path = self.class.to_s
|
||||
.gsub(/^aviator\//, '')
|
||||
.gsub(/^Aviator::Test::/, '')
|
||||
.gsub(/::#/, '/i_')
|
||||
.gsub(/::::/, '/c_')
|
||||
.gsub(/::/, '/')
|
||||
.underscore
|
||||
def self.validate(name, &block)
|
||||
it "returns the correct value for #{ name.to_s }", &block
|
||||
end
|
||||
|
||||
basename = __name__.gsub(/test_\d+_/, '')
|
||||
|
||||
"#{ path }/#{ basename }"
|
||||
end
|
||||
def self.validate_response(scenario, &block)
|
||||
it "leads to a valid response when #{ scenario.to_s }", &block
|
||||
end
|
||||
|
||||
before do
|
||||
::VCR.insert_cassette cassette_name
|
||||
end
|
||||
|
||||
after do
|
||||
::VCR.eject_cassette
|
||||
end
|
||||
def cassette_name
|
||||
path = self.class.to_s
|
||||
.gsub(/^aviator\//, '')
|
||||
.gsub(/^Aviator::Test::/, '')
|
||||
.gsub(/::#/, '/i_')
|
||||
.gsub(/::::/, '/c_')
|
||||
.gsub(/::/, '/')
|
||||
.underscore
|
||||
|
||||
basename = __name__.gsub(/test_\d+_/, '')
|
||||
|
||||
"#{ path }/#{ basename }"
|
||||
end
|
||||
|
||||
|
||||
before do
|
||||
::VCR.insert_cassette cassette_name
|
||||
end
|
||||
|
||||
|
||||
after do
|
||||
::VCR.eject_cassette
|
||||
end
|
||||
|
||||
end
|
||||
end
|
||||
Reference in New Issue
Block a user