test(audit_info): refactor cloudfront (#3110)

This commit is contained in:
Pepe Fagoaga
2023-12-05 10:04:07 +01:00
committed by GitHub
parent ba244c887f
commit 247cd6fc44

View File

@@ -1,20 +1,18 @@
from unittest.mock import patch from unittest.mock import patch
import botocore import botocore
from boto3 import client, session from boto3 import client
from moto import mock_cloudfront from moto import mock_cloudfront
from moto.core import DEFAULT_ACCOUNT_ID
from prowler.providers.aws.lib.audit_info.models import AWS_Audit_Info
from prowler.providers.aws.services.cloudfront.cloudfront_service import ( from prowler.providers.aws.services.cloudfront.cloudfront_service import (
CloudFront, CloudFront,
GeoRestrictionType, GeoRestrictionType,
ViewerProtocolPolicy, ViewerProtocolPolicy,
) )
from prowler.providers.common.models import Audit_Metadata from tests.providers.aws.audit_info_utils import (
AWS_REGION_US_EAST_1,
# Mock Test Region set_mocked_aws_audit_info,
AWS_REGION = "eu-west-1" )
def example_distribution_config(ref): def example_distribution_config(ref):
@@ -149,65 +147,30 @@ def mock_make_api_call(self, operation_name, kwarg):
return make_api_call(self, operation_name, kwarg) return make_api_call(self, operation_name, kwarg)
# PENDING PR TO GET THE PARAMETERS USING MOTO
# Patch every AWS call using Boto3 # Patch every AWS call using Boto3
@patch("botocore.client.BaseClient._make_api_call", new=mock_make_api_call) @patch("botocore.client.BaseClient._make_api_call", new=mock_make_api_call)
class Test_CloudFront_Service: class Test_CloudFront_Service:
# Mocked Audit Info
def set_mocked_audit_info(self):
audit_info = AWS_Audit_Info(
session_config=None,
original_session=None,
audit_session=session.Session(
profile_name=None,
botocore_session=None,
region_name=AWS_REGION,
),
audited_account=DEFAULT_ACCOUNT_ID,
audited_account_arn=f"arn:aws:iam::{DEFAULT_ACCOUNT_ID}:root",
audited_user_id=None,
audited_partition="aws",
audited_identity_arn=None,
profile=None,
profile_region=AWS_REGION,
credentials=None,
assumed_role_info=None,
audited_regions=None,
organizations_metadata=None,
audit_resources=None,
mfa_enabled=False,
audit_metadata=Audit_Metadata(
services_scanned=0,
expected_checks=[],
completed_checks=0,
audit_progress=0,
),
)
return audit_info
# Test CloudFront Client # Test CloudFront Client
@mock_cloudfront @mock_cloudfront
def test__get_client__(self): def test__get_client__(self):
cloudfront = CloudFront(self.set_mocked_audit_info()) cloudfront = CloudFront(set_mocked_aws_audit_info())
assert cloudfront.client.__class__.__name__ == "CloudFront" assert cloudfront.client.__class__.__name__ == "CloudFront"
# Test CloudFront Session # Test CloudFront Session
@mock_cloudfront @mock_cloudfront
def test__get_session__(self): def test__get_session__(self):
cloudfront = CloudFront(self.set_mocked_audit_info()) cloudfront = CloudFront(set_mocked_aws_audit_info())
assert cloudfront.session.__class__.__name__ == "Session" assert cloudfront.session.__class__.__name__ == "Session"
# Test CloudFront Service # Test CloudFront Service
@mock_cloudfront @mock_cloudfront
def test__get_service__(self): def test__get_service__(self):
cloudfront = CloudFront(self.set_mocked_audit_info()) cloudfront = CloudFront(set_mocked_aws_audit_info())
assert cloudfront.service == "cloudfront" assert cloudfront.service == "cloudfront"
@mock_cloudfront @mock_cloudfront
def test__list_distributions__zero(self): def test__list_distributions__zero(self):
cloudfront = CloudFront(self.set_mocked_audit_info()) cloudfront = CloudFront(set_mocked_aws_audit_info())
assert len(cloudfront.distributions) == 0 assert len(cloudfront.distributions) == 0
@@ -218,7 +181,7 @@ class Test_CloudFront_Service:
response = cloudfront_client.create_distribution(DistributionConfig=config) response = cloudfront_client.create_distribution(DistributionConfig=config)
cloudfront_distribution_id = response["Distribution"]["Id"] cloudfront_distribution_id = response["Distribution"]["Id"]
cloudfront_distribution_arn = response["Distribution"]["ARN"] cloudfront_distribution_arn = response["Distribution"]["ARN"]
cloudfront = CloudFront(self.set_mocked_audit_info()) cloudfront = CloudFront(set_mocked_aws_audit_info())
assert len(cloudfront.distributions) == 1 assert len(cloudfront.distributions) == 1
assert ( assert (
@@ -231,7 +194,7 @@ class Test_CloudFront_Service:
) )
assert ( assert (
cloudfront.distributions[cloudfront_distribution_id].region cloudfront.distributions[cloudfront_distribution_id].region
== self.set_mocked_audit_info().audit_session.region_name == AWS_REGION_US_EAST_1
) )
assert ( assert (
cloudfront.distributions[cloudfront_distribution_id].logging_enabled is True cloudfront.distributions[cloudfront_distribution_id].logging_enabled is True