mirror of
https://github.com/ghndrx/prowler.git
synced 2026-02-10 14:55:00 +00:00
fix(iam_user_two_active_access_key_test): fix tests (#1418)
This commit is contained in:
@@ -1,11 +1,9 @@
|
|||||||
|
from re import search
|
||||||
from unittest import mock
|
from unittest import mock
|
||||||
|
|
||||||
from boto3 import client
|
from boto3 import client
|
||||||
from moto import mock_iam
|
from moto import mock_iam
|
||||||
|
|
||||||
from providers.aws.lib.audit_info.audit_info import current_audit_info
|
|
||||||
from providers.aws.services.iam.iam_service import IAM
|
|
||||||
|
|
||||||
|
|
||||||
class Test_iam_user_two_active_access_key:
|
class Test_iam_user_two_active_access_key:
|
||||||
@mock_iam
|
@mock_iam
|
||||||
@@ -13,12 +11,15 @@ class Test_iam_user_two_active_access_key:
|
|||||||
# Create IAM Mocked Resources
|
# Create IAM Mocked Resources
|
||||||
iam_client = client("iam")
|
iam_client = client("iam")
|
||||||
user = "test1"
|
user = "test1"
|
||||||
iam_client.create_user(UserName=user)
|
user_arn = iam_client.create_user(UserName=user)["User"]["Arn"]
|
||||||
# Create Access Key 1
|
# Create Access Key 1
|
||||||
iam_client.create_access_key(UserName=user)
|
iam_client.create_access_key(UserName=user)
|
||||||
# Create Access Key 2
|
# Create Access Key 2
|
||||||
iam_client.create_access_key(UserName=user)
|
iam_client.create_access_key(UserName=user)
|
||||||
|
|
||||||
|
from providers.aws.lib.audit_info.audit_info import current_audit_info
|
||||||
|
from providers.aws.services.iam.iam_service import IAM
|
||||||
|
|
||||||
with mock.patch(
|
with mock.patch(
|
||||||
"providers.aws.services.iam.iam_user_two_active_access_key.iam_user_two_active_access_key.iam_client",
|
"providers.aws.services.iam.iam_user_two_active_access_key.iam_user_two_active_access_key.iam_client",
|
||||||
new=IAM(current_audit_info),
|
new=IAM(current_audit_info),
|
||||||
@@ -33,15 +34,24 @@ class Test_iam_user_two_active_access_key:
|
|||||||
|
|
||||||
assert len(result) == 1
|
assert len(result) == 1
|
||||||
assert result[0].status == "FAIL"
|
assert result[0].status == "FAIL"
|
||||||
|
assert result[0].resource_id == user
|
||||||
|
assert result[0].resource_arn == user_arn
|
||||||
|
assert search(
|
||||||
|
f"User {user} has 2 active access keys.", result[0].status_extended
|
||||||
|
)
|
||||||
|
|
||||||
@mock_iam
|
@mock_iam
|
||||||
def test_iam_user_one_active_access_key(self):
|
def test_iam_user_one_active_access_key(self):
|
||||||
# Create IAM User
|
# Create IAM User
|
||||||
iam_client = client("iam")
|
iam_client = client("iam")
|
||||||
user = "test1"
|
user = "test1"
|
||||||
iam_client.create_user(UserName=user)
|
user_arn = iam_client.create_user(UserName=user)["User"]["Arn"]
|
||||||
# Create Access Key 1
|
# Create Access Key 1
|
||||||
iam_client.create_access_key(UserName=user)
|
iam_client.create_access_key(UserName=user)
|
||||||
|
|
||||||
|
from providers.aws.lib.audit_info.audit_info import current_audit_info
|
||||||
|
from providers.aws.services.iam.iam_service import IAM
|
||||||
|
|
||||||
with mock.patch(
|
with mock.patch(
|
||||||
"providers.aws.services.iam.iam_user_two_active_access_key.iam_user_two_active_access_key.iam_client",
|
"providers.aws.services.iam.iam_user_two_active_access_key.iam_user_two_active_access_key.iam_client",
|
||||||
new=IAM(current_audit_info),
|
new=IAM(current_audit_info),
|
||||||
@@ -56,13 +66,22 @@ class Test_iam_user_two_active_access_key:
|
|||||||
|
|
||||||
assert len(result) == 1
|
assert len(result) == 1
|
||||||
assert result[0].status == "PASS"
|
assert result[0].status == "PASS"
|
||||||
|
assert result[0].resource_id == user
|
||||||
|
assert result[0].resource_arn == user_arn
|
||||||
|
assert search(
|
||||||
|
f"User {user} has not 2 active access keys.", result[0].status_extended
|
||||||
|
)
|
||||||
|
|
||||||
@mock_iam
|
@mock_iam
|
||||||
def test_iam_user_without_active_access_key(self):
|
def test_iam_user_without_active_access_key(self):
|
||||||
# Create IAM User
|
# Create IAM User
|
||||||
iam_client = client("iam")
|
iam_client = client("iam")
|
||||||
user = "test1"
|
user = "test1"
|
||||||
iam_client.create_user(UserName=user)
|
user_arn = iam_client.create_user(UserName=user)["User"]["Arn"]
|
||||||
|
|
||||||
|
from providers.aws.lib.audit_info.audit_info import current_audit_info
|
||||||
|
from providers.aws.services.iam.iam_service import IAM
|
||||||
|
|
||||||
with mock.patch(
|
with mock.patch(
|
||||||
"providers.aws.services.iam.iam_user_two_active_access_key.iam_user_two_active_access_key.iam_client",
|
"providers.aws.services.iam.iam_user_two_active_access_key.iam_user_two_active_access_key.iam_client",
|
||||||
new=IAM(current_audit_info),
|
new=IAM(current_audit_info),
|
||||||
@@ -77,9 +96,17 @@ class Test_iam_user_two_active_access_key:
|
|||||||
|
|
||||||
assert len(result) == 1
|
assert len(result) == 1
|
||||||
assert result[0].status == "PASS"
|
assert result[0].status == "PASS"
|
||||||
|
assert result[0].resource_id == user
|
||||||
|
assert result[0].resource_arn == user_arn
|
||||||
|
assert search(
|
||||||
|
f"User {user} has not 2 active access keys.", result[0].status_extended
|
||||||
|
)
|
||||||
|
|
||||||
@mock_iam
|
@mock_iam
|
||||||
def test_iam_no_users(self):
|
def test_iam_no_users(self):
|
||||||
|
from providers.aws.lib.audit_info.audit_info import current_audit_info
|
||||||
|
from providers.aws.services.iam.iam_service import IAM
|
||||||
|
|
||||||
with mock.patch(
|
with mock.patch(
|
||||||
"providers.aws.services.iam.iam_user_two_active_access_key.iam_user_two_active_access_key.iam_client",
|
"providers.aws.services.iam.iam_user_two_active_access_key.iam_user_two_active_access_key.iam_client",
|
||||||
new=IAM(current_audit_info),
|
new=IAM(current_audit_info),
|
||||||
@@ -93,21 +120,3 @@ class Test_iam_user_two_active_access_key:
|
|||||||
result = check.execute()
|
result = check.execute()
|
||||||
|
|
||||||
assert len(result) == 0
|
assert len(result) == 0
|
||||||
|
|
||||||
@mock_iam
|
|
||||||
def test_bad_response(self):
|
|
||||||
mock_client = mock.MagicMock()
|
|
||||||
mock_client.credential_report = None
|
|
||||||
with mock.patch(
|
|
||||||
"providers.aws.services.iam.iam_user_two_active_access_key.iam_user_two_active_access_key.iam_client",
|
|
||||||
new=mock_client,
|
|
||||||
):
|
|
||||||
# Test Check
|
|
||||||
from providers.aws.services.iam.iam_user_two_active_access_key.iam_user_two_active_access_key import (
|
|
||||||
iam_user_two_active_access_key,
|
|
||||||
)
|
|
||||||
|
|
||||||
check = iam_user_two_active_access_key()
|
|
||||||
result = check.execute()
|
|
||||||
|
|
||||||
assert len(result) == 0
|
|
||||||
|
|||||||
Reference in New Issue
Block a user