aboutsummaryrefslogtreecommitdiffstats
path: root/tests/test_aai_tenant.py
diff options
context:
space:
mode:
Diffstat (limited to 'tests/test_aai_tenant.py')
-rw-r--r--tests/test_aai_tenant.py130
1 files changed, 130 insertions, 0 deletions
diff --git a/tests/test_aai_tenant.py b/tests/test_aai_tenant.py
new file mode 100644
index 0000000..a8e2a91
--- /dev/null
+++ b/tests/test_aai_tenant.py
@@ -0,0 +1,130 @@
+# Copyright 2022 Orange, Deutsche Telekom AG
+#
+# Licensed under the Apache License, Version 2.0 (the "License");
+# you may not use this file except in compliance with the License.
+# You may obtain a copy of the License at
+#
+# http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS,
+# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+# See the License for the specific language governing permissions and
+# limitations under the License.
+from unittest import mock
+
+from onapsdk.aai.business.project import Project
+from onapsdk.aai.cloud_infrastructure import CloudRegion
+from onapsdk.aai.business import OwningEntity
+from onapsdk.aai.cloud_infrastructure import Tenant
+
+from onapsdk.exceptions import APIError
+
+TENANTS = {
+ "tenant": [
+ {
+ "name": "test-name",
+ "resource-version": "1234"
+ },
+ {
+ "name": "test-name2",
+ "resource-version": "4321"
+ }
+ ]
+}
+
+COUNT = {
+ "results": [
+ {
+ "tenant": 1
+ }
+ ]
+}
+
+
+@mock.patch.object(OwningEntity, "add_relationship")
+def test_owning_entity_link_to_tenant(mock_add_rel):
+ """Test OwningEntity linking with Tenant.
+
+ Test Relationship object creation
+ """
+ owning_entity = OwningEntity(name="test_owning_entity",
+ owning_entity_id="test_owning_id",
+ resource_version="12345")
+ cloud_regin = CloudRegion(cloud_owner="test_cloud_owner",
+ cloud_region_id="test_cloud_region",
+ orchestration_disabled=True,
+ in_maint=False)
+ tenant = Tenant(cloud_region=cloud_regin, tenant_id="test_tenant_id", tenant_name="test_tenant_name")
+
+ owning_entity.link_to_tenant(tenant)
+ mock_add_rel.assert_called_once()
+ relationship = mock_add_rel.call_args[0][0]
+ assert relationship.related_to == "tenant"
+ assert relationship.related_link == (f"https://aai.api.sparky.simpledemo.onap.org:30233/aai/"
+ f"v27/cloud-infrastructure/cloud-regions/cloud-region/"
+ f"test_cloud_owner/test_cloud_region/"
+ f"tenants/tenant/test_tenant_id?resource-version=None")
+ assert len(relationship.relationship_data) == 1
+
+
+@mock.patch.object(OwningEntity, "delete_relationship")
+def test_owning_entity_delete_tenant(mock_add_rel):
+ """Test delete OwningEntity's Tenant.
+
+ Test Relationship object deletion
+ """
+ owning_entity = OwningEntity(name="test_owning_entity",
+ owning_entity_id="test_owning_id",
+ resource_version="12345")
+ cloud_regin = CloudRegion(cloud_owner="test_cloud_owner",
+ cloud_region_id="test_cloud_region",
+ orchestration_disabled=True,
+ in_maint=False)
+ tenant = Tenant(cloud_region=cloud_regin, tenant_id="test_tenant_id", tenant_name="test_tenant_name")
+
+ owning_entity.delete_relationship_with_tenant(tenant)
+ mock_add_rel.assert_called_once()
+ relationship = mock_add_rel.call_args[0][0]
+ assert relationship.related_to == "tenant"
+ assert relationship.related_link == (f"https://aai.api.sparky.simpledemo.onap.org:30233/aai/"
+ f"v27/cloud-infrastructure/cloud-regions/cloud-region/"
+ f"test_cloud_owner/test_cloud_region/"
+ f"tenants/tenant/test_tenant_id?resource-version=None")
+ assert len(relationship.relationship_data) == 1
+
+
+def test_tenant_url():
+ cloud_regin = CloudRegion(cloud_owner="test_cloud_owner",
+ cloud_region_id="test_cloud_region",
+ orchestration_disabled=True,
+ in_maint=False)
+ tenant = Tenant(cloud_region=cloud_regin, tenant_id="test_tenant_id", tenant_name="test_tenant_name")
+ assert tenant.url == (f"https://aai.api.sparky.simpledemo.onap.org:30233/aai/v27/cloud-infrastructure/"
+ f"cloud-regions/cloud-region/test_cloud_owner/test_cloud_region/tenants/tenant/"
+ f"test_tenant_id?resource-version=None")
+
+
+def test_tenant_getall_url():
+ cloud_regin = CloudRegion(cloud_owner="test_cloud_owner",
+ cloud_region_id="test_cloud_region",
+ orchestration_disabled=True,
+ in_maint=False)
+ tenant = Tenant(cloud_region=cloud_regin, tenant_id="test_tenant_id", tenant_name="test_tenant_name")
+ assert tenant.get_all_url(cloud_regin) == (
+ f"https://aai.api.sparky.simpledemo.onap.org:30233/aai/v27/cloud-infrastructure/"
+ f"cloud-regions/cloud-region/test_cloud_owner/test_cloud_region/tenants/")
+
+@mock.patch.object(Tenant, "send_message")
+def test_tenant_delete(mock_send_message):
+ cloud_regin = CloudRegion(cloud_owner="test_cloud_owner",
+ cloud_region_id="test_cloud_region",
+ orchestration_disabled=True,
+ in_maint=False)
+ tenant = Tenant(cloud_region=cloud_regin, tenant_id="test_tenant_id", tenant_name="test_tenant_name")
+ tenant.delete()
+ mock_send_message.assert_called_once_with(
+ "DELETE",
+ f"Remove tenant {tenant.name} from {tenant.cloud_region.cloud_region_id} cloud region",
+ url=tenant.url
+ )