Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(149)

Unified Diff: third_party/gsutil/third_party/boto/tests/integration/iam/test_password_policy.py

Issue 1377933002: [catapult] - Copy Telemetry's gsutilz over to third_party. (Closed) Base URL: https://github.com/catapult-project/catapult.git@master
Patch Set: Rename to gsutil. Created 5 years, 3 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: third_party/gsutil/third_party/boto/tests/integration/iam/test_password_policy.py
diff --git a/third_party/gsutil/third_party/boto/tests/integration/iam/test_password_policy.py b/third_party/gsutil/third_party/boto/tests/integration/iam/test_password_policy.py
new file mode 100644
index 0000000000000000000000000000000000000000..aa86fc57bb9cbcb72431760a235d1040fbb44bbf
--- /dev/null
+++ b/third_party/gsutil/third_party/boto/tests/integration/iam/test_password_policy.py
@@ -0,0 +1,80 @@
+# Copyright (c) 2014 Rocket Internet AG.
+# Luca Bruno <luca.bruno@rocket-internet.de>
+# All rights reserved.
+#
+# Permission is hereby granted, free of charge, to any person obtaining a
+# copy of this software and associated documentation files (the
+# "Software"), to deal in the Software without restriction, including
+# without limitation the rights to use, copy, modify, merge, publish, dis-
+# tribute, sublicense, and/or sell copies of the Software, and to permit
+# persons to whom the Software is furnished to do so, subject to the fol-
+# lowing conditions:
+#
+# The above copyright notice and this permission notice shall be included
+# in all copies or substantial portions of the Software.
+#
+# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
+# OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABIL-
+# ITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT
+# SHALL THE AUTHOR BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
+# WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
+# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
+# IN THE SOFTWARE.
+
+import boto
+import time
+
+from tests.compat import unittest
+
+class IAMAccountPasswordPolicy(unittest.TestCase):
+ iam = True
+
+ def test_password_policy(self):
+ # A series of tests to check the password policy API
+ iam = boto.connect_iam()
+
+ # First preserve what is the current password policy
+ try:
+ initial_policy_result = iam.get_account_password_policy()
+ except boto.exception.BotoServerError as srv_error:
+ initial_policy = None
+ if srv_error.status != 404:
+ raise srv_error
+
+ # Update the policy and check it back
+ test_min_length = 88
+ iam.update_account_password_policy(minimum_password_length=test_min_length)
+ new_policy = iam.get_account_password_policy()
+ new_min_length = new_policy['get_account_password_policy_response']\
+ ['get_account_password_policy_result']['password_policy']\
+ ['minimum_password_length']
+
+ if test_min_length != int(new_min_length):
+ raise Exception("Failed to update account password policy")
+
+ # Delete the policy and check the correct deletion
+ test_policy = ''
+ iam.delete_account_password_policy()
+ try:
+ test_policy = iam.get_account_password_policy()
+ except boto.exception.BotoServerError as srv_error:
+ test_policy = None
+ if srv_error.status != 404:
+ raise srv_error
+
+ if test_policy is not None:
+ raise Exception("Failed to delete account password policy")
+
+ # Restore initial account password policy
+ if initial_policy:
+ p = initial_policy['get_account_password_policy_response']\
+ ['get_account_password_policy_result']['password_policy']
+ iam.update_account_password_policy(minimum_password_length=int(p['minimum_password_length']),
+ allow_users_to_change_password=bool(p['allow_users_to_change_password']),
+ hard_expiry=bool(p['hard_expiry']),
+ max_password_age=int(p['max_password_age']),
+ password_reuse_prevention=int(p['password_reuse_prevention']),
+ require_lowercase_characters=bool(p['require_lowercase_characters']),
+ require_numbers=bool(p['require_numbers']),
+ require_symbols=bool(p['require_symbols']),
+ require_uppercase_characters=bool(p['require_uppercase_characters']))

Powered by Google App Engine
This is Rietveld 408576698