summaryrefslogtreecommitdiff
path: root/tests/unit/iam/test_connection.py
diff options
context:
space:
mode:
Diffstat (limited to 'tests/unit/iam/test_connection.py')
-rw-r--r--tests/unit/iam/test_connection.py84
1 files changed, 66 insertions, 18 deletions
diff --git a/tests/unit/iam/test_connection.py b/tests/unit/iam/test_connection.py
index fd568556..d94c20a8 100644
--- a/tests/unit/iam/test_connection.py
+++ b/tests/unit/iam/test_connection.py
@@ -21,7 +21,7 @@
# IN THE SOFTWARE.
#
-from tests.unit import unittest
+from base64 import b64decode
from boto.compat import json
from boto.iam.connection import IAMConnection
from tests.unit import AWSMockServiceTestCase
@@ -52,8 +52,8 @@ class TestCreateSamlProvider(AWSMockServiceTestCase):
'Name': 'name'},
ignore_params_values=['Version'])
- self.assertEqual(response['create_saml_provider_response']\
- ['create_saml_provider_result']\
+ self.assertEqual(response['create_saml_provider_response']
+ ['create_saml_provider_result']
['saml_provider_arn'], 'arn')
@@ -91,12 +91,12 @@ class TestListSamlProviders(AWSMockServiceTestCase):
{'Action': 'ListSAMLProviders'},
ignore_params_values=['Version'])
self.assertEqual(response.saml_provider_list, [
- {'arn':'arn:aws:iam::123456789012:instance-profile/application_abc/component_xyz/Database',
- 'valid_until':'2032-05-09T16:27:11Z',
- 'create_date':'2012-05-09T16:27:03Z'},
- {'arn':'arn:aws:iam::123456789012:instance-profile/application_abc/component_xyz/Webserver',
- 'valid_until':'2015-03-11T13:11:02Z',
- 'create_date':'2012-05-09T16:27:11Z'}])
+ {'arn': 'arn:aws:iam::123456789012:instance-profile/application_abc/component_xyz/Database',
+ 'valid_until': '2032-05-09T16:27:11Z',
+ 'create_date': '2012-05-09T16:27:03Z'},
+ {'arn': 'arn:aws:iam::123456789012:instance-profile/application_abc/component_xyz/Webserver',
+ 'valid_until': '2015-03-11T13:11:02Z',
+ 'create_date': '2012-05-09T16:27:11Z'}])
class TestGetSamlProvider(AWSMockServiceTestCase):
@@ -118,7 +118,7 @@ class TestGetSamlProvider(AWSMockServiceTestCase):
def test_get_saml_provider(self):
self.set_http_response(status_code=200)
- response = self.service_connection.get_saml_provider('arn')
+ self.service_connection.get_saml_provider('arn')
self.assert_request_parameters(
{
@@ -145,7 +145,7 @@ class TestUpdateSamlProvider(AWSMockServiceTestCase):
def test_update_saml_provider(self):
self.set_http_response(status_code=200)
- response = self.service_connection.update_saml_provider('arn', 'doc')
+ self.service_connection.update_saml_provider('arn', 'doc')
self.assert_request_parameters(
{
@@ -164,7 +164,7 @@ class TestDeleteSamlProvider(AWSMockServiceTestCase):
def test_delete_saml_provider(self):
self.set_http_response(status_code=200)
- response = self.service_connection.delete_saml_provider('arn')
+ self.service_connection.delete_saml_provider('arn')
self.assert_request_parameters(
{
@@ -198,7 +198,7 @@ class TestCreateRole(AWSMockServiceTestCase):
def test_create_role_default(self):
self.set_http_response(status_code=200)
- response = self.service_connection.create_role('a_name')
+ self.service_connection.create_role('a_name')
self.assert_request_parameters(
{'Action': 'CreateRole',
@@ -209,7 +209,7 @@ class TestCreateRole(AWSMockServiceTestCase):
def test_create_role_default_cn_north(self):
self.set_http_response(status_code=200)
self.service_connection.host = 'iam.cn-north-1.amazonaws.com.cn'
- response = self.service_connection.create_role('a_name')
+ self.service_connection.create_role('a_name')
self.assert_request_parameters(
{'Action': 'CreateRole',
@@ -219,7 +219,7 @@ class TestCreateRole(AWSMockServiceTestCase):
def test_create_role_string_policy(self):
self.set_http_response(status_code=200)
- response = self.service_connection.create_role(
+ self.service_connection.create_role(
'a_name',
# Historical usage.
assume_role_policy_document='{"hello": "policy"}'
@@ -233,7 +233,7 @@ class TestCreateRole(AWSMockServiceTestCase):
def test_create_role_data_policy(self):
self.set_http_response(status_code=200)
- response = self.service_connection.create_role(
+ self.service_connection.create_role(
'a_name',
# With plain data, we should dump it for them.
assume_role_policy_document={"hello": "policy"}
@@ -287,11 +287,11 @@ class TestGetSigninURL(AWSMockServiceTestCase):
url = self.service_connection.get_signin_url()
self.assertEqual(
url,
- 'https://foocorporation.signin.aws.amazon.com/console/ec2'
+ 'https://foocorporation.signin.amazonaws.cn/console/ec2'
)
-class TestGetSigninURL(AWSMockServiceTestCase):
+class TestGetSigninURLNoAliases(AWSMockServiceTestCase):
connection_class = IAMConnection
def default_body(self):
@@ -312,3 +312,51 @@ class TestGetSigninURL(AWSMockServiceTestCase):
with self.assertRaises(Exception):
self.service_connection.get_signin_url()
+
+
+class TestGenerateCredentialReport(AWSMockServiceTestCase):
+ connection_class = IAMConnection
+
+ def default_body(self):
+ return b"""
+ <GenerateCredentialReportResponse>
+ <GenerateCredentialReportResult>
+ <State>COMPLETE</State>
+ </GenerateCredentialReportResult>
+ <ResponseMetadata>
+ <RequestId>b62e22a3-0da1-11e4-ba55-0990EXAMPLE</RequestId>
+ </ResponseMetadata>
+ </GenerateCredentialReportResponse>
+ """
+
+ def test_generate_credential_report(self):
+ self.set_http_response(status_code=200)
+ response = self.service_connection.generate_credential_report()
+ self.assertEquals(response['generate_credential_report_response']
+ ['generate_credential_report_result']
+ ['state'], 'COMPLETE')
+
+
+class TestGetCredentialReport(AWSMockServiceTestCase):
+ connection_class = IAMConnection
+
+ def default_body(self):
+ return b"""
+ <GetCredentialReportResponse>
+ <ResponseMetadata>
+ <RequestId>99e60e9a-0db5-11e4-94d4-b764EXAMPLE</RequestId>
+ </ResponseMetadata>
+ <GetCredentialReportResult>
+ <Content>RXhhbXBsZQ==</Content>
+ <ReportFormat>text/csv</ReportFormat>
+ <GeneratedTime>2014-07-17T11:09:11Z</GeneratedTime>
+ </GetCredentialReportResult>
+ </GetCredentialReportResponse>
+ """
+
+ def test_get_credential_report(self):
+ self.set_http_response(status_code=200)
+ response = self.service_connection.get_credential_report()
+ b64decode(response['get_credential_report_response']
+ ['get_credential_report_result']
+ ['content'])