route53_zone: return existing zone id in check mode (#56702)
* Returns zone ID for existing zone or `null` * route53_zone: add module unit tests * route53_zone: add compatibility with Python 2.6 to the unit tests * route53_zone: address pycodestyle warning (add blank line)
This commit is contained in:
parent
6ebfe413b0
commit
d88d71e4b1
2 changed files with 611 additions and 1 deletions
|
@ -172,6 +172,7 @@ def create(module, client, matching_zones):
|
|||
'comment': comment,
|
||||
'name': zone_in,
|
||||
'delegation_set_id': delegation_set_id,
|
||||
'zone_id': None,
|
||||
}
|
||||
|
||||
if private_zone:
|
||||
|
@ -287,7 +288,10 @@ def create_or_update_public(module, client, matching_zones, record):
|
|||
module.fail_json_aws(e, msg="Could not create hosted zone")
|
||||
changed = True
|
||||
|
||||
if not module.check_mode:
|
||||
if module.check_mode:
|
||||
if zone_details:
|
||||
record['zone_id'] = zone_details['Id'].replace('/hostedzone/', '')
|
||||
else:
|
||||
record['zone_id'] = zone_details['Id'].replace('/hostedzone/', '')
|
||||
record['name'] = zone_details['Name']
|
||||
record['delegation_set_id'] = zone_delegation_set_details.get('Id', '').replace('/delegationset/', '')
|
||||
|
|
606
test/units/modules/cloud/amazon/test_route53_zone.py
Normal file
606
test/units/modules/cloud/amazon/test_route53_zone.py
Normal file
|
@ -0,0 +1,606 @@
|
|||
import functools
|
||||
|
||||
from ansible.modules.cloud.amazon import route53_zone
|
||||
from units.compat import unittest
|
||||
from units.compat.mock import patch, call
|
||||
from units.modules.utils import AnsibleExitJson, AnsibleFailJson, ModuleTestCase, set_module_args
|
||||
|
||||
|
||||
def parameterized(params_list):
|
||||
def decorator(func):
|
||||
@functools.wraps(func)
|
||||
def wrapper(*args, **kwargs):
|
||||
for params_map in params_list:
|
||||
params_map.update(kwargs)
|
||||
func(*args, **params_map)
|
||||
return wrapper
|
||||
return decorator
|
||||
|
||||
|
||||
# Inline and replace with subdict.items() <= superdict.items(), when Python 2.6 compat can be dropped
|
||||
def is_subdict(subdict, superdict):
|
||||
return all(superdict[k] == v for k, v in subdict.items())
|
||||
|
||||
|
||||
@patch('ansible.module_utils.aws.core.HAS_BOTO3', new=True)
|
||||
@patch.object(route53_zone.AnsibleAWSModule, 'client')
|
||||
@patch.object(route53_zone.time, 'time', return_value=1)
|
||||
class TestRoute53Module(ModuleTestCase):
|
||||
def test_mutually_exclusive(self, *args):
|
||||
with self.assertRaises(AnsibleFailJson) as exec_info:
|
||||
set_module_args({
|
||||
'secret_key': 'SECRET_KEY',
|
||||
'access_key': 'ACCESS_KEY',
|
||||
'region': 'eu-central-1',
|
||||
'zone': 'example.com',
|
||||
'vpc_id': 'vpc-94ccc2ff',
|
||||
'vpc_region': 'eu-central-1',
|
||||
'comment': 'foobar',
|
||||
'delegation_set_id': 'A1BCDEF2GHIJKL',
|
||||
'state': 'present',
|
||||
})
|
||||
route53_zone.main()
|
||||
|
||||
self.assertEqual(
|
||||
exec_info.exception.args[0]['msg'],
|
||||
'parameters are mutually exclusive: delegation_set_id|vpc_id, delegation_set_id|vpc_region',
|
||||
)
|
||||
|
||||
@parameterized([
|
||||
{
|
||||
'check_mode': False,
|
||||
'response': {
|
||||
'private_zone': False,
|
||||
'vpc_id': None,
|
||||
'vpc_region': None,
|
||||
'comment': 'foobar',
|
||||
'name': 'example.com.',
|
||||
'delegation_set_id': '',
|
||||
'zone_id': 'ZONE_ID',
|
||||
},
|
||||
},
|
||||
{
|
||||
'check_mode': True,
|
||||
'response': {
|
||||
'private_zone': False,
|
||||
'vpc_id': None,
|
||||
'vpc_region': None,
|
||||
'comment': 'foobar',
|
||||
'name': 'example.com.',
|
||||
'delegation_set_id': None,
|
||||
'zone_id': None,
|
||||
},
|
||||
}
|
||||
])
|
||||
@patch.object(route53_zone, 'find_zones', return_value=[])
|
||||
def test_create_public_zone(self, find_zones_mock, time_mock, client_mock, check_mode, response):
|
||||
client_mock.return_value.create_hosted_zone.return_value = {
|
||||
'HostedZone': {
|
||||
'Id': '/hostedzone/ZONE_ID',
|
||||
'Name': 'example.com.',
|
||||
'Config': {
|
||||
'Comment': 'foobar',
|
||||
'PrivateZone': False,
|
||||
},
|
||||
},
|
||||
}
|
||||
|
||||
with self.assertRaises(AnsibleExitJson) as exec_info:
|
||||
set_module_args({
|
||||
'secret_key': 'SECRET_KEY',
|
||||
'access_key': 'ACCESS_KEY',
|
||||
'region': 'eu-central-1',
|
||||
'zone': 'example.com',
|
||||
'comment': 'foobar',
|
||||
'state': 'present',
|
||||
'_ansible_check_mode': check_mode,
|
||||
})
|
||||
route53_zone.main()
|
||||
|
||||
if check_mode:
|
||||
client_mock.return_value.create_hosted_zone.assert_not_called()
|
||||
else:
|
||||
client_mock.return_value.create_hosted_zone.assert_called_once_with(**{
|
||||
'HostedZoneConfig': {
|
||||
'Comment': 'foobar',
|
||||
'PrivateZone': False,
|
||||
},
|
||||
'Name': 'example.com.',
|
||||
'CallerReference': 'example.com.-1',
|
||||
})
|
||||
|
||||
self.assertEqual(exec_info.exception.args[0]['changed'], True)
|
||||
self.assertTrue(is_subdict(response, exec_info.exception.args[0]))
|
||||
|
||||
@parameterized([
|
||||
{
|
||||
'check_mode': False,
|
||||
'response': {
|
||||
'private_zone': True,
|
||||
'vpc_id': 'vpc-1',
|
||||
'vpc_region': 'eu-central-1',
|
||||
'comment': 'foobar',
|
||||
'name': 'example.com.',
|
||||
'delegation_set_id': None,
|
||||
'zone_id': 'ZONE_ID',
|
||||
},
|
||||
},
|
||||
{
|
||||
'check_mode': True,
|
||||
'response': {
|
||||
'private_zone': True,
|
||||
'vpc_id': 'vpc-1',
|
||||
'vpc_region': 'eu-central-1',
|
||||
'comment': 'foobar',
|
||||
'name': 'example.com.',
|
||||
'delegation_set_id': None,
|
||||
'zone_id': None,
|
||||
},
|
||||
}
|
||||
])
|
||||
@patch.object(route53_zone, 'find_zones', return_value=[])
|
||||
def test_create_private_zone(self, find_zones_mock, time_mock, client_mock, check_mode, response):
|
||||
client_mock.return_value.create_hosted_zone.return_value = {
|
||||
'HostedZone': {
|
||||
'Id': '/hostedzone/ZONE_ID',
|
||||
'Name': 'example.com.',
|
||||
'Config': {
|
||||
'Comment': 'foobar',
|
||||
'PrivateZone': True
|
||||
},
|
||||
},
|
||||
}
|
||||
|
||||
with self.assertRaises(AnsibleExitJson) as exec_info:
|
||||
set_module_args({
|
||||
'secret_key': 'SECRET_KEY',
|
||||
'access_key': 'ACCESS_KEY',
|
||||
'region': 'eu-central-1',
|
||||
'zone': 'example.com',
|
||||
'comment': 'foobar',
|
||||
'vpc_id': 'vpc-1',
|
||||
'vpc_region': 'eu-central-1',
|
||||
'state': 'present',
|
||||
'_ansible_check_mode': check_mode,
|
||||
})
|
||||
route53_zone.main()
|
||||
|
||||
if check_mode:
|
||||
client_mock.return_value.create_hosted_zone.assert_not_called()
|
||||
else:
|
||||
client_mock.return_value.create_hosted_zone.assert_called_once_with(**{
|
||||
'HostedZoneConfig': {
|
||||
'Comment': 'foobar',
|
||||
'PrivateZone': True,
|
||||
},
|
||||
'Name': 'example.com.',
|
||||
'CallerReference': 'example.com.-1',
|
||||
'VPC': {
|
||||
'VPCRegion': 'eu-central-1',
|
||||
'VPCId': 'vpc-1',
|
||||
},
|
||||
})
|
||||
|
||||
self.assertEqual(exec_info.exception.args[0]['changed'], True)
|
||||
self.assertTrue(is_subdict(response, exec_info.exception.args[0]))
|
||||
|
||||
@parameterized([
|
||||
{
|
||||
'check_mode': False,
|
||||
'response': {
|
||||
'private_zone': False,
|
||||
'vpc_id': None,
|
||||
'vpc_region': None,
|
||||
'comment': 'new',
|
||||
'name': 'example.com.',
|
||||
'delegation_set_id': '',
|
||||
'zone_id': 'ZONE_ID',
|
||||
},
|
||||
},
|
||||
{
|
||||
'check_mode': True,
|
||||
'response': {
|
||||
'private_zone': False,
|
||||
'vpc_id': None,
|
||||
'vpc_region': None,
|
||||
'comment': 'new',
|
||||
'name': 'example.com.',
|
||||
'delegation_set_id': None,
|
||||
'zone_id': 'ZONE_ID',
|
||||
},
|
||||
}
|
||||
])
|
||||
@patch.object(route53_zone, 'find_zones', return_value=[{
|
||||
'Id': '/hostedzone/ZONE_ID',
|
||||
'Name': 'example.com.',
|
||||
'Config': {'Comment': '', 'PrivateZone': False},
|
||||
}])
|
||||
def test_update_comment_public_zone(self, find_zones_mock, time_mock, client_mock, check_mode, response):
|
||||
client_mock.return_value.get_hosted_zone.return_value = {
|
||||
'HostedZone': {
|
||||
'Id': '/hostedzone/ZONE_ID',
|
||||
'Name': 'example.com.',
|
||||
'Config': {'Comment': '', 'PrivateZone': False},
|
||||
},
|
||||
}
|
||||
|
||||
with self.assertRaises(AnsibleExitJson) as exec_info:
|
||||
set_module_args({
|
||||
'secret_key': 'SECRET_KEY',
|
||||
'access_key': 'ACCESS_KEY',
|
||||
'region': 'eu-central-1',
|
||||
'zone': 'example.com',
|
||||
'comment': 'new',
|
||||
'state': 'present',
|
||||
'_ansible_check_mode': check_mode,
|
||||
})
|
||||
route53_zone.main()
|
||||
|
||||
if check_mode:
|
||||
client_mock.return_value.update_hosted_zone_comment.assert_not_called()
|
||||
else:
|
||||
client_mock.return_value.update_hosted_zone_comment.assert_called_once_with(**{
|
||||
'Id': '/hostedzone/ZONE_ID',
|
||||
'Comment': 'new',
|
||||
})
|
||||
|
||||
self.assertEqual(exec_info.exception.args[0]['changed'], True)
|
||||
self.assertTrue(is_subdict(response, exec_info.exception.args[0]))
|
||||
|
||||
@patch.object(route53_zone, 'find_zones', return_value=[{
|
||||
'Id': '/hostedzone/Z22OU4IUOVYM30',
|
||||
'Name': 'example.com.',
|
||||
'Config': {'Comment': '', 'PrivateZone': False},
|
||||
}])
|
||||
def test_update_public_zone_no_changes(self, find_zones_mock, time_mock, client_mock):
|
||||
client_mock.return_value.get_hosted_zone.return_value = {
|
||||
'HostedZone': {
|
||||
'Id': '/hostedzone/ZONE_ID',
|
||||
'Name': 'example.com.',
|
||||
'Config': {'Comment': '', 'PrivateZone': False},
|
||||
},
|
||||
}
|
||||
|
||||
with self.assertRaises(AnsibleExitJson) as exec_info:
|
||||
set_module_args({
|
||||
'secret_key': 'SECRET_KEY',
|
||||
'access_key': 'ACCESS_KEY',
|
||||
'region': 'eu-central-1',
|
||||
'zone': 'example.com',
|
||||
'comment': '',
|
||||
'state': 'present',
|
||||
})
|
||||
route53_zone.main()
|
||||
|
||||
client_mock.return_value.update_hosted_zone_comment.assert_not_called()
|
||||
self.assertEqual(exec_info.exception.args[0]['changed'], False)
|
||||
|
||||
@parameterized([
|
||||
{
|
||||
'check_mode': False,
|
||||
'response': {
|
||||
'private_zone': True,
|
||||
'vpc_id': 'vpc-1',
|
||||
'vpc_region': 'eu-central-1',
|
||||
'comment': 'new',
|
||||
'name': 'example.com.',
|
||||
'delegation_set_id': None,
|
||||
'zone_id': 'ZONE_ID',
|
||||
},
|
||||
},
|
||||
{
|
||||
'check_mode': True,
|
||||
'response': {
|
||||
'private_zone': True,
|
||||
'vpc_id': 'vpc-1',
|
||||
'vpc_region': 'eu-central-1',
|
||||
'comment': 'new',
|
||||
'name': 'example.com.',
|
||||
'delegation_set_id': None,
|
||||
'zone_id': 'ZONE_ID',
|
||||
},
|
||||
}
|
||||
])
|
||||
@patch.object(route53_zone, 'find_zones', return_value=[{
|
||||
'Id': '/hostedzone/ZONE_ID',
|
||||
'Name': 'example.com.',
|
||||
'Config': {'Comment': 'foobar', 'PrivateZone': True},
|
||||
}])
|
||||
def test_update_comment_private_zone(self, find_zones_mock, time_mock, client_mock, check_mode, response):
|
||||
client_mock.return_value.get_hosted_zone.return_value = {
|
||||
'HostedZone': {
|
||||
'Id': '/hostedzone/ZONE_ID',
|
||||
'Name': 'example.com.',
|
||||
'Config': {'Comment': 'foobar', 'PrivateZone': True},
|
||||
},
|
||||
'VPCs': [{'VPCRegion': 'eu-central-1', 'VPCId': 'vpc-1'}],
|
||||
}
|
||||
|
||||
with self.assertRaises(AnsibleExitJson) as exec_info:
|
||||
set_module_args({
|
||||
'secret_key': 'SECRET_KEY',
|
||||
'access_key': 'ACCESS_KEY',
|
||||
'region': 'eu-central-1',
|
||||
'zone': 'example.com',
|
||||
'comment': 'new',
|
||||
'vpc_id': 'vpc-1',
|
||||
'vpc_region': 'eu-central-1',
|
||||
'state': 'present',
|
||||
'_ansible_check_mode': check_mode,
|
||||
})
|
||||
route53_zone.main()
|
||||
|
||||
if check_mode:
|
||||
client_mock.return_value.update_hosted_zone_comment.assert_not_called()
|
||||
else:
|
||||
client_mock.return_value.update_hosted_zone_comment.assert_called_once_with(**{
|
||||
'Id': '/hostedzone/ZONE_ID',
|
||||
'Comment': 'new',
|
||||
})
|
||||
|
||||
self.assertEqual(exec_info.exception.args[0]['changed'], True)
|
||||
self.assertTrue(is_subdict(response, exec_info.exception.args[0]))
|
||||
|
||||
@parameterized([
|
||||
{
|
||||
'check_mode': False,
|
||||
'response': {
|
||||
'private_zone': True,
|
||||
'vpc_id': 'vpc-2',
|
||||
'vpc_region': 'us-east-2',
|
||||
'comment': 'foobar',
|
||||
'name': 'example.com.',
|
||||
'delegation_set_id': None,
|
||||
'zone_id': 'ZONE_ID_2',
|
||||
},
|
||||
},
|
||||
{
|
||||
'check_mode': True,
|
||||
'response': {
|
||||
'private_zone': True,
|
||||
'vpc_id': 'vpc-2',
|
||||
'vpc_region': 'us-east-2',
|
||||
'comment': 'foobar',
|
||||
'name': 'example.com.',
|
||||
'delegation_set_id': None,
|
||||
'zone_id': None,
|
||||
},
|
||||
}
|
||||
])
|
||||
@patch.object(route53_zone, 'find_zones', return_value=[{
|
||||
'Id': '/hostedzone/ZONE_ID',
|
||||
'Name': 'example.com.',
|
||||
'Config': {'Comment': 'foobar', 'PrivateZone': True},
|
||||
}])
|
||||
def test_update_vpc_private_zone(self, find_zones_mock, time_mock, client_mock, check_mode, response):
|
||||
client_mock.return_value.get_hosted_zone.return_value = {
|
||||
'HostedZone': {
|
||||
'Id': '/hostedzone/ZONE_ID',
|
||||
'Name': 'example.com.',
|
||||
'Config': {'Comment': 'foobar', 'PrivateZone': True},
|
||||
},
|
||||
'VPCs': [{'VPCRegion': 'eu-central-1', 'VPCId': 'vpc-1'}],
|
||||
}
|
||||
client_mock.return_value.create_hosted_zone.return_value = {
|
||||
'HostedZone': {
|
||||
'Id': '/hostedzone/ZONE_ID_2',
|
||||
'Name': 'example.com.',
|
||||
'Config': {
|
||||
'Comment': 'foobar',
|
||||
'PrivateZone': True
|
||||
},
|
||||
},
|
||||
}
|
||||
|
||||
with self.assertRaises(AnsibleExitJson) as exec_info:
|
||||
set_module_args({
|
||||
'secret_key': 'SECRET_KEY',
|
||||
'access_key': 'ACCESS_KEY',
|
||||
'region': 'us-east-2',
|
||||
'zone': 'example.com',
|
||||
'comment': 'foobar',
|
||||
'vpc_id': 'vpc-2',
|
||||
'vpc_region': 'us-east-2',
|
||||
'state': 'present',
|
||||
'_ansible_check_mode': check_mode,
|
||||
})
|
||||
route53_zone.main()
|
||||
|
||||
if check_mode:
|
||||
client_mock.return_value.create_hosted_zone.assert_not_called()
|
||||
else:
|
||||
client_mock.return_value.create_hosted_zone.assert_called_once_with(**{
|
||||
'HostedZoneConfig': {
|
||||
'Comment': 'foobar',
|
||||
'PrivateZone': True,
|
||||
},
|
||||
'Name': 'example.com.',
|
||||
'CallerReference': 'example.com.-1',
|
||||
'VPC': {
|
||||
'VPCRegion': 'us-east-2',
|
||||
'VPCId': 'vpc-2',
|
||||
},
|
||||
})
|
||||
|
||||
self.assertEqual(exec_info.exception.args[0]['changed'], True)
|
||||
self.assertTrue(is_subdict(response, exec_info.exception.args[0]))
|
||||
|
||||
@patch.object(route53_zone, 'find_zones', return_value=[{
|
||||
'Id': '/hostedzone/ZONE_ID',
|
||||
'Name': 'example.com.',
|
||||
'Config': {'Comment': 'foobar', 'PrivateZone': True},
|
||||
}])
|
||||
def test_update_private_zone_no_changes(self, find_zones_mock, time_mock, client_mock):
|
||||
client_mock.return_value.get_hosted_zone.return_value = {
|
||||
'HostedZone': {
|
||||
'Id': '/hostedzone/ZONE_ID',
|
||||
'Name': 'example.com.',
|
||||
'Config': {'Comment': 'foobar', 'PrivateZone': True},
|
||||
},
|
||||
'VPCs': [{'VPCRegion': 'eu-central-1', 'VPCId': 'vpc-1'}],
|
||||
}
|
||||
|
||||
with self.assertRaises(AnsibleExitJson) as exec_info:
|
||||
set_module_args({
|
||||
'secret_key': 'SECRET_KEY',
|
||||
'access_key': 'ACCESS_KEY',
|
||||
'region': 'eu-central-1',
|
||||
'zone': 'example.com',
|
||||
'comment': 'foobar',
|
||||
'vpc_id': 'vpc-1',
|
||||
'vpc_region': 'eu-central-1',
|
||||
'state': 'present',
|
||||
})
|
||||
route53_zone.main()
|
||||
|
||||
client_mock.return_value.update_hosted_zone_comment.assert_not_called()
|
||||
self.assertEqual(exec_info.exception.args[0]['changed'], False)
|
||||
|
||||
response = {
|
||||
'private_zone': True,
|
||||
'vpc_id': 'vpc-1',
|
||||
'vpc_region': 'eu-central-1',
|
||||
'comment': 'foobar',
|
||||
'name': 'example.com.',
|
||||
'delegation_set_id': None,
|
||||
'zone_id': 'ZONE_ID',
|
||||
}
|
||||
self.assertTrue(is_subdict(response, exec_info.exception.args[0]))
|
||||
|
||||
@parameterized([
|
||||
{'check_mode': False},
|
||||
{'check_mode': True}
|
||||
])
|
||||
@patch.object(route53_zone, 'find_zones', return_value=[{
|
||||
'Id': '/hostedzone/ZONE_ID',
|
||||
'Name': 'example.com.',
|
||||
'Config': {'Comment': '', 'PrivateZone': False},
|
||||
}])
|
||||
def test_delete_public_zone(self, find_zones_mock, time_mock, client_mock, check_mode):
|
||||
with self.assertRaises(AnsibleExitJson) as exec_info:
|
||||
set_module_args({
|
||||
'secret_key': 'SECRET_KEY',
|
||||
'access_key': 'ACCESS_KEY',
|
||||
'region': 'eu-central-1',
|
||||
'zone': 'example.com',
|
||||
'state': 'absent',
|
||||
'_ansible_check_mode': check_mode,
|
||||
})
|
||||
route53_zone.main()
|
||||
|
||||
if check_mode:
|
||||
client_mock.return_value.delete_hosted_zone.assert_not_called()
|
||||
else:
|
||||
client_mock.return_value.delete_hosted_zone.assert_called_once_with(**{
|
||||
'Id': '/hostedzone/ZONE_ID',
|
||||
})
|
||||
|
||||
self.assertEqual(exec_info.exception.args[0]['changed'], True)
|
||||
|
||||
@parameterized([
|
||||
{'check_mode': False},
|
||||
{'check_mode': True}
|
||||
])
|
||||
@patch.object(route53_zone, 'find_zones', return_value=[{
|
||||
'Id': '/hostedzone/ZONE_ID',
|
||||
'Name': 'example.com.',
|
||||
'Config': {'Comment': 'foobar', 'PrivateZone': True},
|
||||
}])
|
||||
def test_delete_private_zone(self, find_zones_mock, time_mock, client_mock, check_mode):
|
||||
client_mock.return_value.get_hosted_zone.return_value = {
|
||||
'HostedZone': {
|
||||
'Id': '/hostedzone/ZONE_ID',
|
||||
'Name': 'example.com.',
|
||||
'Config': {'Comment': 'foobar', 'PrivateZone': True},
|
||||
},
|
||||
'VPCs': [{'VPCRegion': 'eu-central-1', 'VPCId': 'vpc-1'}],
|
||||
}
|
||||
|
||||
with self.assertRaises(AnsibleExitJson) as exec_info:
|
||||
set_module_args({
|
||||
'secret_key': 'SECRET_KEY',
|
||||
'access_key': 'ACCESS_KEY',
|
||||
'region': 'eu-central-1',
|
||||
'zone': 'example.com',
|
||||
'vpc_id': 'vpc-1',
|
||||
'vpc_region': 'eu-central-1',
|
||||
'state': 'absent',
|
||||
'_ansible_check_mode': check_mode,
|
||||
})
|
||||
route53_zone.main()
|
||||
|
||||
if check_mode:
|
||||
client_mock.return_value.delete_hosted_zone.assert_not_called()
|
||||
else:
|
||||
client_mock.return_value.delete_hosted_zone.assert_called_once_with(**{
|
||||
'Id': '/hostedzone/ZONE_ID',
|
||||
})
|
||||
|
||||
self.assertEqual(exec_info.exception.args[0]['changed'], True)
|
||||
|
||||
@parameterized([
|
||||
{'check_mode': False},
|
||||
{'check_mode': True}
|
||||
])
|
||||
@parameterized([
|
||||
{
|
||||
'hosted_zone_id': 'PRIVATE_ZONE_ID',
|
||||
'call_params': [call(**{
|
||||
'Id': 'PRIVATE_ZONE_ID',
|
||||
})],
|
||||
}, {
|
||||
'hosted_zone_id': 'all',
|
||||
'call_params': [call(**{
|
||||
'Id': '/hostedzone/PUBLIC_ZONE_ID',
|
||||
}), call(**{
|
||||
'Id': '/hostedzone/PRIVATE_ZONE_ID',
|
||||
})],
|
||||
}
|
||||
])
|
||||
@patch.object(route53_zone, 'find_zones', return_value=[{
|
||||
'Id': '/hostedzone/PUBLIC_ZONE_ID',
|
||||
'Name': 'example.com.',
|
||||
'Config': {'Comment': '', 'PrivateZone': False},
|
||||
}, {
|
||||
'Id': '/hostedzone/PRIVATE_ZONE_ID',
|
||||
'Name': 'example.com.',
|
||||
'Config': {'Comment': 'foobar', 'PrivateZone': True},
|
||||
}])
|
||||
def test_delete_by_zone_id(self, find_zones_mock, time_mock, client_mock, hosted_zone_id, call_params, check_mode):
|
||||
with self.assertRaises(AnsibleExitJson) as exec_info:
|
||||
set_module_args({
|
||||
'secret_key': 'SECRET_KEY',
|
||||
'access_key': 'ACCESS_KEY',
|
||||
'region': 'eu-central-1',
|
||||
'zone': 'example.com',
|
||||
'hosted_zone_id': hosted_zone_id,
|
||||
'state': 'absent',
|
||||
'_ansible_check_mode': check_mode,
|
||||
})
|
||||
route53_zone.main()
|
||||
|
||||
if check_mode:
|
||||
client_mock.return_value.delete_hosted_zone.assert_not_called()
|
||||
else:
|
||||
client_mock.return_value.delete_hosted_zone.assert_has_calls(call_params)
|
||||
|
||||
self.assertEqual(exec_info.exception.args[0]['changed'], True)
|
||||
|
||||
@patch.object(route53_zone, 'find_zones', return_value=[])
|
||||
def test_delete_absent_zone(self, find_zones_mock, time_mock, client_mock):
|
||||
with self.assertRaises(AnsibleExitJson) as exec_info:
|
||||
set_module_args({
|
||||
'secret_key': 'SECRET_KEY',
|
||||
'access_key': 'ACCESS_KEY',
|
||||
'region': 'eu-central-1',
|
||||
'zone': 'example.com',
|
||||
'state': 'absent',
|
||||
})
|
||||
route53_zone.main()
|
||||
|
||||
client_mock.return_value.delete_hosted_zone.assert_not_called()
|
||||
self.assertEqual(exec_info.exception.args[0]['changed'], False)
|
||||
|
||||
|
||||
if __name__ == '__main__':
|
||||
unittest.main()
|
Loading…
Reference in a new issue