1
0
Fork 0
mirror of https://github.com/fog/fog.git synced 2022-11-09 13:51:43 -05:00

shindo tests for IAM models: users, policies and access_keys. Mock implementation for get_user_policy

This commit is contained in:
Rodrigo Estebanez 2012-06-05 15:03:14 +02:00
parent d258e36c98
commit 5e55a151ee
4 changed files with 129 additions and 10 deletions

View file

@ -31,6 +31,22 @@ module Fog
end end
end end
class Mock
def get_user_policy(policy_name, user_name)
raise Fog::AWS::IAM::NotFound.new("The user with name #{user} cannot be found.") unless self.data[:users].key?(user_name)
raise Fog::AWS::IAM::NotFound.new("The policy with name #{policy_name} cannot be found.") unless self.data[:users][user_name][:policies].key?(policy_name)
Excon::Response.new.tap do |response|
response.body = {
'PolicyName' => policy_name,
'UserName' => user_name,
'PolicyDocument' => data[:users][user_name][:policies][policy_name],
'IsTruncated' => false,
'RequestId' => Fog::AWS::Mock.request_id
}
response.status = 200
end
end
end
end end
end end
end end

View file

@ -0,0 +1,52 @@
Shindo.tests("Fog::Compute[:iam] | access_keys", ['aws','iam']) do
Fog.mock!
iam = Fog::AWS[:iam]
@username = 'fake_user'
@users = iam.users.create(:id => @username)
tests('#all', 'there are no access keys for a new user').succeeds do
@users.access_keys.empty?
end
tests('#create','an access key').succeeds do
access_key = @users.access_keys.create
access_key.id =~ /[A-Z0-9]{20}/
access_key.secret_access_key =~ /[\S]{40}/
access_key.status == "Active"
access_key.username == @username
@access_key_id = access_key.id
end
@users.access_keys.create
tests('#all','there are two access keys').succeeds do
@users.access_keys.size == 2
end
tests('#get') do
tests('a valid access key id').succeeds do
access_key = @users.access_keys.get(@access_key_id)
access_key.id == @access_key_id
access_key.secret_access_key == nil
access_key.status == "Active"
access_key.username == @username
end
tests('an invalid access key').succeeds do
@users.access_keys.get('non-existing') == nil
end
end
tests('#destroy', decrease by one the number of access keys).succeeds do
size = @users.access_keys.size
@users.access_keys.get(@access_key_id).destroy
@users.access_keys.size == ( size - 1 )
end
end

View file

@ -0,0 +1,48 @@
Shindo.tests("Fog::Compute[:iam] | policies", ['aws','iam']) do
Fog.mock!
iam = Fog::AWS[:iam]
@username = 'fake_user'
@users = iam.users.create(:id => @username)
@policy_document = {"Statement"=>[{"Action"=>["sqs:*"], "Effect"=>"Allow", "Resource"=>"*"}]}
@policy_name = 'fake-sqs-policy'
tests('#all', 'there is no policies').succeeds do
@users.policies.empty?
end
tests('#create','a policy').succeeds do
policy = @users.policies.create(id: @policy_name, document: @policy_document)
policy.id == @policy_name
policy.username == @username
#policy.document == @policy_document # FIXME, the format isn't right
end
@users.policies.create(id: 'another-policy', document: {})
tests('#all','there are two policies').succeeds do
@users.policies.size == 2
end
tests('#get') do
tests('a valid policy').succeeds do
policy = @users.policies.get(@policy_name)
policy.id == @policy_name
policy.username == @username
#policy.document == @policy_document # FIXME, the format isn't right
end
tests('an invalid policy').succeeds do
@users.policies.get('non-existing') == nil
end
end
tests('#destroy').succeeds do
@users.policies.get(@policy_name).destroy
end
end

View file

@ -1,4 +1,4 @@
Shindo.tests("Fog::Compute[:iam] | user", ['aws','iam']) do Shindo.tests("Fog::Compute[:iam] | users", ['aws','iam']) do
Fog.mock! Fog.mock!
@iam = Fog::AWS[:iam] @iam = Fog::AWS[:iam]
@ -9,13 +9,12 @@ Shindo.tests("Fog::Compute[:iam] | user", ['aws','iam']) do
@user_one = @iam.users.create(:id => @user_one_name) @user_one = @iam.users.create(:id => @user_one_name)
@user_one.id == @user_one_name @user_one.id == @user_one_name
end end
#@user_two = @iam.users.create(:id => 'fake_user_two')
tests('#users','there is only one user').succeeds do tests('#all','there is only one user').succeeds do
@iam.users.size == 1 @iam.users.size == 1
end end
tests('#users','the only user should match').succeeds do tests('#all','the only user should match').succeeds do
@iam.users.first.id == @user_one_name @iam.users.first.id == @user_one_name
end end
@ -24,7 +23,7 @@ Shindo.tests("Fog::Compute[:iam] | user", ['aws','iam']) do
@user_two.id == @user_two_name @user_two.id == @user_two_name
end end
tests('#users','there are two users').succeeds do tests('#all','there are two users').succeeds do
@iam.users.size == 2 @iam.users.size == 2
end end
@ -32,20 +31,24 @@ Shindo.tests("Fog::Compute[:iam] | user", ['aws','iam']) do
@iam.users.get(@user_one_name).id == @user_one_name @iam.users.get(@user_one_name).id == @user_one_name
end end
tests('#get','nil if the user doesnt exists').succeeds do tests('#get',"returns nil if the user doesn't exists").succeeds do
@iam.users.get('non-exists') == nil @iam.users.get('non-exists') == nil
end end
tests('#policies').succeeds do tests('#policies','it has no policies').succeeds do
@iam.users.get(@user_one_name).policies.empty?
end end
tests('#access_keys').succeeds do tests('#access_keys','it has no keys').succeeds do
@iam.users.get(@user_one_name).access_keys.empty?
end end
tests('#destroy','an existing user').succeeds do tests('#destroy','an existing user').succeeds do
@iam.users.get(@user_one_name).destroy @iam.users.get(@user_one_name).destroy
end end
tests('#destroy','clean up remaining user').succeeds do
@iam.users.get(@user_two_name).destroy
end
end end