Files
prowler/tests/providers/gcp/services/compute/compute_service_test.py
2025-12-30 12:40:47 +01:00

261 lines
13 KiB
Python

from unittest.mock import patch
from prowler.providers.gcp.services.compute.compute_service import Compute
from tests.providers.gcp.gcp_fixtures import (
GCP_PROJECT_ID,
mock_api_client,
mock_is_api_active,
set_mocked_gcp_provider,
)
class TestComputeService:
def test_service(self):
with (
patch(
"prowler.providers.gcp.lib.service.service.GCPService.__is_api_active__",
new=mock_is_api_active,
),
patch(
"prowler.providers.gcp.lib.service.service.GCPService.__generate_client__",
new=mock_api_client,
),
):
compute_client = Compute(set_mocked_gcp_provider([GCP_PROJECT_ID]))
assert compute_client.service == "compute"
assert compute_client.project_ids == [GCP_PROJECT_ID]
assert len(compute_client.regions) == 1
assert "europe-west1-b" in compute_client.regions
assert len(compute_client.zones) == 1
assert "zone1" in compute_client.zones
assert len(compute_client.compute_projects) == 1
assert compute_client.compute_projects[0].id == GCP_PROJECT_ID
assert compute_client.compute_projects[0].enable_oslogin
assert len(compute_client.instances) == 2
assert compute_client.instances[0].name == "instance1"
assert compute_client.instances[0].id.__class__.__name__ == "str"
assert compute_client.instances[0].zone == "zone1"
assert compute_client.instances[0].region == "zone1"
assert compute_client.instances[0].public_ip
assert compute_client.instances[0].project_id == GCP_PROJECT_ID
assert compute_client.instances[0].metadata == {}
assert compute_client.instances[0].shielded_enabled_vtpm
assert compute_client.instances[0].shielded_enabled_integrity_monitoring
assert compute_client.instances[0].confidential_computing
assert len(compute_client.instances[0].service_accounts) == 1
assert (
compute_client.instances[0].service_accounts[0]["email"]
== "test@test.es"
)
assert compute_client.instances[0].service_accounts[0]["scopes"] == [
"scope1",
"scope2",
]
assert compute_client.instances[0].ip_forward
assert compute_client.instances[0].disks_encryption == [("disk1", True)]
assert not compute_client.instances[0].automatic_restart
assert not compute_client.instances[0].preemptible
assert compute_client.instances[0].provisioning_model == "STANDARD"
assert compute_client.instances[1].name == "instance2"
assert compute_client.instances[1].id.__class__.__name__ == "str"
assert compute_client.instances[1].zone == "zone1"
assert compute_client.instances[1].region == "zone1"
assert not compute_client.instances[1].public_ip
assert compute_client.instances[1].project_id == GCP_PROJECT_ID
assert compute_client.instances[1].metadata == {}
assert not compute_client.instances[1].shielded_enabled_vtpm
assert not compute_client.instances[1].shielded_enabled_integrity_monitoring
assert not compute_client.instances[1].confidential_computing
assert len(compute_client.instances[1].service_accounts) == 1
assert (
compute_client.instances[1].service_accounts[0]["email"]
== "test2@test.es"
)
assert compute_client.instances[1].service_accounts[0]["scopes"] == [
"scope3"
]
assert not compute_client.instances[1].ip_forward
assert compute_client.instances[1].disks_encryption == [("disk2", False)]
assert not compute_client.instances[1].automatic_restart
assert not compute_client.instances[1].preemptible
assert compute_client.instances[1].provisioning_model == "STANDARD"
assert len(compute_client.networks) == 3
assert compute_client.networks[0].name == "network1"
assert compute_client.networks[0].id.__class__.__name__ == "str"
assert compute_client.networks[0].subnet_mode == "auto"
assert compute_client.networks[0].project_id == GCP_PROJECT_ID
assert compute_client.networks[1].name == "network2"
assert compute_client.networks[1].id.__class__.__name__ == "str"
assert compute_client.networks[1].subnet_mode == "custom"
assert compute_client.networks[1].project_id == GCP_PROJECT_ID
assert compute_client.networks[2].name == "network3"
assert compute_client.networks[2].id.__class__.__name__ == "str"
assert compute_client.networks[2].subnet_mode == "legacy"
assert compute_client.networks[2].project_id == GCP_PROJECT_ID
assert len(compute_client.subnets) == 3
assert compute_client.subnets[0].name == "subnetwork1"
assert compute_client.subnets[0].id.__class__.__name__ == "str"
assert compute_client.subnets[0].flow_logs
assert compute_client.subnets[0].network == "network1"
assert compute_client.subnets[0].project_id == GCP_PROJECT_ID
assert compute_client.subnets[1].name == "subnetwork2"
assert compute_client.subnets[1].id.__class__.__name__ == "str"
assert not compute_client.subnets[1].flow_logs
assert compute_client.subnets[1].network == "network1"
assert compute_client.subnets[1].project_id == GCP_PROJECT_ID
assert compute_client.subnets[2].name == "subnetwork3"
assert compute_client.subnets[2].id.__class__.__name__ == "str"
assert not compute_client.subnets[2].flow_logs
assert compute_client.subnets[2].network == "network3"
assert compute_client.subnets[2].project_id == GCP_PROJECT_ID
assert len(compute_client.addresses) == 3
assert compute_client.addresses[0].name == "address1"
assert compute_client.addresses[0].id.__class__.__name__ == "str"
assert compute_client.addresses[0].ip == "10.0.0.1"
assert compute_client.addresses[0].type == "INTERNAL"
assert compute_client.addresses[0].region == "europe-west1-b"
assert compute_client.addresses[0].project_id == GCP_PROJECT_ID
assert compute_client.addresses[1].name == "address2"
assert compute_client.addresses[1].id.__class__.__name__ == "str"
assert compute_client.addresses[1].ip == "10.0.0.2"
assert compute_client.addresses[1].type == "INTERNAL"
assert compute_client.addresses[1].region == "europe-west1-b"
assert compute_client.addresses[1].project_id == GCP_PROJECT_ID
assert compute_client.addresses[2].name == "address3"
assert compute_client.addresses[2].id.__class__.__name__ == "str"
assert compute_client.addresses[2].ip == "20.34.105.200"
assert compute_client.addresses[2].type == "EXTERNAL"
assert compute_client.addresses[2].region == "europe-west1-b"
assert compute_client.addresses[2].project_id == GCP_PROJECT_ID
assert len(compute_client.firewalls) == 3
assert compute_client.firewalls[0].name == "firewall1"
assert compute_client.firewalls[0].id.__class__.__name__ == "str"
assert compute_client.firewalls[0].allowed_rules == [{"IPProtocol": "UDP"}]
assert compute_client.firewalls[0].source_ranges == ["30.0.0.0/16"]
assert compute_client.firewalls[0].direction == "INGRESS"
assert compute_client.firewalls[0].project_id == GCP_PROJECT_ID
assert compute_client.firewalls[1].name == "firewall2"
assert compute_client.firewalls[1].id.__class__.__name__ == "str"
assert compute_client.firewalls[1].allowed_rules == [{"IPProtocol": "TCP"}]
assert compute_client.firewalls[1].source_ranges == ["0.0.0.0/0"]
assert compute_client.firewalls[1].direction == "EGRESS"
assert compute_client.firewalls[1].project_id == GCP_PROJECT_ID
assert compute_client.firewalls[2].name == "firewall3"
assert compute_client.firewalls[2].id.__class__.__name__ == "str"
assert compute_client.firewalls[2].allowed_rules == [{"IPProtocol": "TCP"}]
assert compute_client.firewalls[2].source_ranges == ["10.0.15.0/24"]
assert compute_client.firewalls[2].direction == "INGRESS"
assert compute_client.firewalls[2].project_id == GCP_PROJECT_ID
assert len(compute_client.load_balancers) == 4
assert compute_client.load_balancers[0].name == "url_map1"
assert compute_client.load_balancers[0].id.__class__.__name__ == "str"
assert compute_client.load_balancers[0].service == "service1"
assert compute_client.load_balancers[0].project_id == GCP_PROJECT_ID
assert compute_client.load_balancers[0].logging
assert compute_client.load_balancers[1].name == "url_map2"
assert compute_client.load_balancers[1].id.__class__.__name__ == "str"
assert compute_client.load_balancers[1].service == "service2"
assert compute_client.load_balancers[1].project_id == GCP_PROJECT_ID
assert not compute_client.load_balancers[1].logging
assert compute_client.load_balancers[2].name == "regional_url_map1"
assert compute_client.load_balancers[2].id.__class__.__name__ == "str"
assert compute_client.load_balancers[2].service == "regional_service1"
assert compute_client.load_balancers[2].project_id == GCP_PROJECT_ID
assert not compute_client.load_balancers[2].logging
assert compute_client.load_balancers[3].name == "regional_url_map2"
assert compute_client.load_balancers[3].id.__class__.__name__ == "str"
assert compute_client.load_balancers[3].service == "regional_service2"
assert compute_client.load_balancers[3].project_id == GCP_PROJECT_ID
assert not compute_client.load_balancers[3].logging
# Test Managed Instance Groups
# We expect 3 MIGs: 2 regional (from region europe-west1-b) and 1 zonal (from zone1)
assert len(compute_client.instance_groups) == 3
regional_mig_1 = next(
(
mig
for mig in compute_client.instance_groups
if mig.name == "regional-mig-1"
),
None,
)
assert regional_mig_1 is not None
assert regional_mig_1.id.__class__.__name__ == "str"
assert regional_mig_1.region == "europe-west1-b"
assert regional_mig_1.zone is None # Regional MIGs don't have a single zone
assert len(regional_mig_1.zones) == 3
assert "europe-west1-b" in regional_mig_1.zones
assert "europe-west1-c" in regional_mig_1.zones
assert "europe-west1-d" in regional_mig_1.zones
assert regional_mig_1.is_regional
assert regional_mig_1.target_size == 3
assert regional_mig_1.project_id == GCP_PROJECT_ID
assert len(regional_mig_1.auto_healing_policies) == 1
assert (
regional_mig_1.auto_healing_policies[0].health_check
== "http-health-check"
)
assert regional_mig_1.auto_healing_policies[0].initial_delay_sec == 300
regional_mig_2 = next(
(
mig
for mig in compute_client.instance_groups
if mig.name == "regional-mig-single-zone"
),
None,
)
assert regional_mig_2 is not None
assert regional_mig_2.id.__class__.__name__ == "str"
assert regional_mig_2.region == "europe-west1-b"
assert regional_mig_2.zone is None
assert len(regional_mig_2.zones) == 1
assert "europe-west1-b" in regional_mig_2.zones
assert regional_mig_2.is_regional
assert regional_mig_2.target_size == 1
assert regional_mig_2.project_id == GCP_PROJECT_ID
assert len(regional_mig_2.auto_healing_policies) == 0
zonal_mig = next(
(
mig
for mig in compute_client.instance_groups
if mig.name == "zonal-mig-1"
),
None,
)
assert zonal_mig is not None
assert zonal_mig.id.__class__.__name__ == "str"
assert (
zonal_mig.region == "zone1"
) # zone1 has no hyphen so region is "zone1"
assert zonal_mig.zone == "zone1"
assert len(zonal_mig.zones) == 1
assert "zone1" in zonal_mig.zones
assert not zonal_mig.is_regional
assert zonal_mig.target_size == 2
assert zonal_mig.project_id == GCP_PROJECT_ID
assert len(zonal_mig.auto_healing_policies) == 1
assert zonal_mig.auto_healing_policies[0].health_check == "tcp-health-check"
assert zonal_mig.auto_healing_policies[0].initial_delay_sec == 120