test_integration_azure_security_group.py 4.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192
  1. import json
  2. import unittest
  3. import uuid
  4. from cloudbridge.cloud.interfaces import TestMockHelperMixin
  5. from test.helpers import ProviderTestBase
  6. import test.helpers as helpers
  7. class AzureIntegrationSecurityServiceTestCase(ProviderTestBase):
  8. def __init__(self, methodName, provider):
  9. super(AzureIntegrationSecurityServiceTestCase, self).__init__(
  10. methodName=methodName, provider=provider)
  11. @helpers.skipIfNoService(['security.security_groups'])
  12. def test_azure_security_group(self):
  13. sg_name = '{0}'.format(uuid.uuid4())
  14. print("SG guid - " + sg_name)
  15. listBeforeCreate = self.provider.security.security_groups.list()
  16. print("Length Before create - " + str(len(listBeforeCreate)))
  17. netId = "/subscriptions/7904d702-e01c-4826-8519-f5a25c866a96/resourceGroups/CloudBridge-Azure'\
  18. '/providers/Microsoft.Network/virtualNetworks/SampleNetwork"
  19. sg = self.provider.security.security_groups.create(name=sg_name, description="testCreateSecGroup",
  20. network_id=netId)
  21. self.assertEqual(sg_name, sg.name)
  22. listAfterCreate = self.provider.security.security_groups.list()
  23. print("Length After create - " + str(len(listAfterCreate)))
  24. self.assertEqual(len(listAfterCreate), len(listBeforeCreate) + 1)
  25. get = self.provider.security.security_groups.get(
  26. "/subscriptions/7904d702-e01c-4826-8519-f5a25c866a96/resourceGroups/CloudBridge-Azure/providers'\
  27. '/Microsoft.Network/networkSecurityGroups/sampleSG")
  28. print("Get SG - " + str(get))
  29. print(str(get.rules))
  30. self.assertEqual(get.name, "sampleSG")
  31. get_notfound = self.provider.security.security_groups.get(
  32. "/subscriptions/7904d702-e01c-4826-8519-f5a25c866a96/resourceGroups/cloudbridge-azure'\
  33. '/providers/Microsoft.Network/networkSecurityGroups/SecgrupDontFindMe")
  34. self.assertEqual(get_notfound, None)
  35. find_exists_list = self.provider.security.security_groups.find(sg_name)
  36. for sg in find_exists_list:
  37. self.assertTrue(sg_name in sg.name)
  38. print("Find - " + str(find_exists_list))
  39. print("Find Total Results- " + str(find_exists_list.total_results))
  40. self.assertTrue(find_exists_list.total_results > 0)
  41. find_not_exists_list = self.provider.security.security_groups.find('dontfindme')
  42. self.assertTrue(find_not_exists_list.total_results == 0)
  43. cb = listAfterCreate.data[0]
  44. lenBeforeCreateRule = len(cb.rules)
  45. cb.add_rule('tcp', '1111', '2222', '0.0.0.0/0')
  46. lenAfterCreateRule = len(cb.rules)
  47. self.assertEqual(lenAfterCreateRule, lenBeforeCreateRule+1)
  48. print(str(cb.rules))
  49. get_rule = cb.get_rule('tcp', '1111', '2222', '0.0.0.0/0')
  50. print("Get Rule - " + str(get_rule))
  51. self.assertEqual(str(get_rule), "<CBSecurityGroupRule: IP: tcp; from: 1111; to: 2222; grp: None>")
  52. get_rule_notfound = cb.get_rule('*', '25', '1', '1')
  53. self.assertEqual(str(get_rule_notfound), 'None')
  54. rule_json = cb.rules[1].to_json()
  55. print("Rule json - " + str(rule_json))
  56. self.assertEqual(rule_json[2:9], "cidr_ip")
  57. sg_json = cb.to_json()
  58. print("SG json - " + str(sg_json))
  59. self.assertEqual(sg_json[2:4], "id")
  60. with self.assertRaises(Exception):
  61. cb.rules[1].delete()
  62. listBeforeDeleteFound = self.provider.security.security_groups.list()
  63. sg_id = "/subscriptions/7904d702-e01c-4826-8519-f5a25c866a96/resourceGroups/cloudbridge-azure/providers'\
  64. '/Microsoft.Network/networkSecurityGroups/" + sg_name
  65. sg_del = self.provider.security.security_groups.delete(sg_id)
  66. listAfterDeleteFound = self.provider.security.security_groups.list()
  67. print("Length before delete - " + str(len(listBeforeDeleteFound)))
  68. print("Length after delete - " + str(len(listAfterDeleteFound)))
  69. self.assertEqual(len(listAfterDeleteFound), len(listBeforeDeleteFound)-1)
  70. sg_id = "/subscriptions/7904d702-e01c-4826-8519-f5a25c866a96/resourceGroups/cloudbridge-azure/providers'\
  71. '/Microsoft.Network/networkSecurityGroups/sg5"
  72. sg_del_notfound = self.provider.security.security_groups.delete(sg_id)
  73. listAfterDeleteNotFound = self.provider.security.security_groups.list()
  74. self.assertEqual(len(listAfterDeleteNotFound), len(listAfterDeleteFound))