You are viewing a plain text version of this content. The canonical link for it is here.
Posted to notifications@libcloud.apache.org by an...@apache.org on 2016/03/21 11:23:18 UTC
[09/17] libcloud git commit: adds unittests for nsone driver
adds unittests for nsone driver
Project: http://git-wip-us.apache.org/repos/asf/libcloud/repo
Commit: http://git-wip-us.apache.org/repos/asf/libcloud/commit/2463fb84
Tree: http://git-wip-us.apache.org/repos/asf/libcloud/tree/2463fb84
Diff: http://git-wip-us.apache.org/repos/asf/libcloud/diff/2463fb84
Branch: refs/heads/trunk
Commit: 2463fb84d59ac822ece432a33a83d6f97bdfcf1b
Parents: 7a9018b
Author: lostbird <lostbird@lostbird.(none)>
Authored: Wed Mar 9 01:32:03 2016 +0100
Committer: anthony-shaw <an...@gmail.com>
Committed: Mon Mar 21 21:20:31 2016 +1100
----------------------------------------------------------------------
libcloud/dns/drivers/nsone.py | 15 +-
.../dns/fixtures/nsone/create_zone_success.json | 38 ++++
.../fixtures/nsone/delete_record_success.json | 0
.../dns/fixtures/nsone/delete_zone_success.json | 0
.../dns/fixtures/nsone/get_record_success.json | 117 ++++++++++
.../dns/fixtures/nsone/get_zone_success.json | 48 ++++
.../dns/fixtures/nsone/list_records_empty.json | 24 ++
.../test/dns/fixtures/nsone/list_zones.json | 40 ++++
.../fixtures/nsone/record_does_not_exist.json | 1 +
.../dns/fixtures/nsone/zone_already_exists.json | 1 +
.../dns/fixtures/nsone/zone_does_not_exist.json | 1 +
libcloud/test/dns/test_nsone.py | 220 +++++++++++++++++++
12 files changed, 501 insertions(+), 4 deletions(-)
----------------------------------------------------------------------
http://git-wip-us.apache.org/repos/asf/libcloud/blob/2463fb84/libcloud/dns/drivers/nsone.py
----------------------------------------------------------------------
diff --git a/libcloud/dns/drivers/nsone.py b/libcloud/dns/drivers/nsone.py
index 3de153d..77442f2 100644
--- a/libcloud/dns/drivers/nsone.py
+++ b/libcloud/dns/drivers/nsone.py
@@ -111,11 +111,18 @@ class NsOneDNSDriver(DNSDriver):
:return: Boolean
"""
action = '/v1/zones/%s' % zone.domain
- zones_list = self.list_zones()
+ """zones_list = self.list_zones()
if not self.ex_zone_exists(zone_id=zone.id, zones_list=zones_list):
raise ZoneDoesNotExistError(value='', driver=self, zone_id=zone.id)
-
- response = self.connection.request(action=action, method='DELETE')
+ """
+ try:
+ response = self.connection.request(action=action, method='DELETE')
+ except NsOneException, e:
+ if e.message == 'zone not found':
+ raise ZoneDoesNotExistError(value=e.message, driver=self,
+ zone_id=zone.id)
+ else:
+ raise e
return response.status == httplib.OK
@@ -160,7 +167,7 @@ class NsOneDNSDriver(DNSDriver):
else:
raise e
zone = self.get_zone(zone_id=zone_id)
- record = self._to_record(item=response.objects[0], zone=zone)
+ record = self._to_record(item=response.parse_body(), zone=zone)
return record
http://git-wip-us.apache.org/repos/asf/libcloud/blob/2463fb84/libcloud/test/dns/fixtures/nsone/create_zone_success.json
----------------------------------------------------------------------
diff --git a/libcloud/test/dns/fixtures/nsone/create_zone_success.json b/libcloud/test/dns/fixtures/nsone/create_zone_success.json
new file mode 100644
index 0000000..bc20afe
--- /dev/null
+++ b/libcloud/test/dns/fixtures/nsone/create_zone_success.json
@@ -0,0 +1,38 @@
+{
+ "id": "52051b2c9f782d58bb4df41b",
+ "hostmaster": "hostmaster@nsone.net",
+ "ttl": 3600,
+ "nx_ttl": 60,
+ "retry": 7200,
+ "zone": "newzone.com",
+ "refresh": 43200,
+ "expiry": 1209600,
+ "dns_servers": [
+ "dns1.p06.nsone.net",
+ "dns2.p06.nsone.net",
+ "dns3.p06.nsone.net",
+ "dns4.p06.nsone.net"
+ ],
+ "networks": [0],
+ "network_pools": ["p06"],
+ "primary": {
+ "enabled": false,
+ "secondaries": []
+ },
+ "records": [
+ {
+ "id": "52051b2c9f782d58bb4df420",
+ "type": "NS",
+ "tier": 1,
+ "ttl": 3600,
+ "short_answers": [
+ "dns1.p06.nsone.net",
+ "dns2.p06.nsone.net",
+ "dns3.p06.nsone.net",
+ "dns4.p06.nsone.net"
+ ],
+ "domain": "newzone.com"
+ }
+ ],
+ "meta": {}
+}
\ No newline at end of file
http://git-wip-us.apache.org/repos/asf/libcloud/blob/2463fb84/libcloud/test/dns/fixtures/nsone/delete_record_success.json
----------------------------------------------------------------------
diff --git a/libcloud/test/dns/fixtures/nsone/delete_record_success.json b/libcloud/test/dns/fixtures/nsone/delete_record_success.json
new file mode 100644
index 0000000..e69de29
http://git-wip-us.apache.org/repos/asf/libcloud/blob/2463fb84/libcloud/test/dns/fixtures/nsone/delete_zone_success.json
----------------------------------------------------------------------
diff --git a/libcloud/test/dns/fixtures/nsone/delete_zone_success.json b/libcloud/test/dns/fixtures/nsone/delete_zone_success.json
new file mode 100644
index 0000000..e69de29
http://git-wip-us.apache.org/repos/asf/libcloud/blob/2463fb84/libcloud/test/dns/fixtures/nsone/get_record_success.json
----------------------------------------------------------------------
diff --git a/libcloud/test/dns/fixtures/nsone/get_record_success.json b/libcloud/test/dns/fixtures/nsone/get_record_success.json
new file mode 100644
index 0000000..9644017
--- /dev/null
+++ b/libcloud/test/dns/fixtures/nsone/get_record_success.json
@@ -0,0 +1,117 @@
+{
+ "id": "520519509f782d58bb4df419",
+ "networks": [0],
+ "type": "A",
+ "tier": 3,
+ "domain": "www.example.com",
+ "zone": "example.com",
+ "answers": [
+ {
+ "id": "520519509f782d58bb4df418",
+ "feeds": [
+ {
+ "source": "a53252f9e583c6708331a1daeb172e12",
+ "feed": "520533b89f782d5b1a10a851"
+ }
+ ],
+ "answer": [
+ "1.1.1.1"
+ ],
+ "meta": {
+ "up": { "feed": "520533b89f782d5b1a10a851" },
+ "priority": 1
+ },
+ "region": "us-east"
+ },
+ {
+ "id": "5205338e9f782d5b1a10a84e",
+ "feeds": [
+ {
+ "source": "a53252f9e583c6708331a1daeb172e12",
+ "feed": "520533c09f782d5b1a10a852"
+ }
+ ],
+ "answer": [
+ "2.2.2.2"
+ ],
+ "meta": {
+ "up": { "feed": "520533b89f782d5b1a10a852" },
+ "priority": 2
+ },
+ "region": "us-east"
+ },
+ {
+ "id": "5205338e9f782d5b1a10a84f",
+ "feeds": [
+ {
+ "source": "a53252f9e583c6708331a1daeb172e12",
+ "feed": "520533dc9f782d5b1a10a854"
+ }
+ ],
+ "answer": [
+ "8.8.8.8"
+ ],
+ "meta": {
+ "up": { "feed": "520533b89f782d5b1a10a854" },
+ "priority": 3
+ },
+ "region": "us-west"
+ },
+ {
+ "id": "5205338e9f782d5b1a10a850",
+ "feeds": [
+ {
+ "source": "a53252f9e583c6708331a1daeb172e12",
+ "feed": "520533e49f782d5b1a10a855"
+ }
+ ],
+ "answer": [
+ "9.9.9.9"
+ ],
+ "meta": {
+ "up": { "feed": "520533b89f782d5b1a10a855" },
+ "priority": 3
+ },
+ "region": "us-west"
+ }
+ ],
+ "regions": {
+ "us-east": {
+ "meta": {
+ "georegion": ["US-EAST"]
+ }
+ },
+ "us-west": {
+ "meta": {
+ "georegion": ["US-WEST"]
+ }
+ }
+ },
+ "meta": {},
+ "filters": [
+ {
+ "config": {},
+ "filter": "up"
+ },
+ {
+ "config": {},
+ "filter": "geotarget_regional"
+ },
+ {
+ "config": {},
+ "filter": "select_first_region"
+ },
+ {
+ "config": {},
+ "filter": "weighted_shuffle"
+ },
+ {
+ "config": {
+ "N": 1
+ },
+ "filter": "select_first_n"
+ }
+ ],
+ "ttl": 60,
+ "use_client_subnet": true
+}
\ No newline at end of file
http://git-wip-us.apache.org/repos/asf/libcloud/blob/2463fb84/libcloud/test/dns/fixtures/nsone/get_zone_success.json
----------------------------------------------------------------------
diff --git a/libcloud/test/dns/fixtures/nsone/get_zone_success.json b/libcloud/test/dns/fixtures/nsone/get_zone_success.json
new file mode 100644
index 0000000..25a5800
--- /dev/null
+++ b/libcloud/test/dns/fixtures/nsone/get_zone_success.json
@@ -0,0 +1,48 @@
+{
+ "id": "520422af9f782d37dffb588b",
+ "hostmaster": "hostmaster@nsone.net",
+ "ttl": 3600,
+ "nx_ttl": 3600,
+ "retry": 7200,
+ "zone": "example.com",
+ "refresh": 43200,
+ "expiry": 1209600,
+ "dns_servers": [
+ "dns1.p03.nsone.net",
+ "dns2.p03.nsone.net",
+ "dns3.p03.nsone.net",
+ "dns4.p03.nsone.net"
+ ],
+ "networks": [0],
+ "network_pools": ["p03"],
+ "primary": {
+ "enabled": false,
+ "secondaries": []
+ },
+ "records": [
+ {
+ "id": "520422af9f782d37dffb5890",
+ "type": "NS",
+ "tier": 1,
+ "ttl": 3600,
+ "short_answers": [
+ "dns1.p03.nsone.net",
+ "dns2.p03.nsone.net",
+ "dns3.p03.nsone.net",
+ "dns4.p03.nsone.net"
+ ],
+ "domain": "example.com"
+ },
+ {
+ "id": "520519509f782d58bb4df419",
+ "type": "A",
+ "tier": 1,
+ "ttl": 3600,
+ "short_answers": [
+ "1.2.3.4"
+ ],
+ "domain": "www.example.com"
+ }
+ ],
+ "meta": {}
+}
\ No newline at end of file
http://git-wip-us.apache.org/repos/asf/libcloud/blob/2463fb84/libcloud/test/dns/fixtures/nsone/list_records_empty.json
----------------------------------------------------------------------
diff --git a/libcloud/test/dns/fixtures/nsone/list_records_empty.json b/libcloud/test/dns/fixtures/nsone/list_records_empty.json
new file mode 100644
index 0000000..6d6c8c9
--- /dev/null
+++ b/libcloud/test/dns/fixtures/nsone/list_records_empty.json
@@ -0,0 +1,24 @@
+{
+ "id": "520422af9f782d37dffb588b",
+ "hostmaster": "hostmaster@nsone.net",
+ "ttl": 3600,
+ "nx_ttl": 3600,
+ "retry": 7200,
+ "zone": "example.com",
+ "refresh": 43200,
+ "expiry": 1209600,
+ "dns_servers": [
+ "dns1.p03.nsone.net",
+ "dns2.p03.nsone.net",
+ "dns3.p03.nsone.net",
+ "dns4.p03.nsone.net"
+ ],
+ "networks": [0],
+ "network_pools": ["p03"],
+ "primary": {
+ "enabled": false,
+ "secondaries": []
+ },
+ "records": [],
+ "meta": {}
+}
\ No newline at end of file
http://git-wip-us.apache.org/repos/asf/libcloud/blob/2463fb84/libcloud/test/dns/fixtures/nsone/list_zones.json
----------------------------------------------------------------------
diff --git a/libcloud/test/dns/fixtures/nsone/list_zones.json b/libcloud/test/dns/fixtures/nsone/list_zones.json
index e69de29..8d7433a 100644
--- a/libcloud/test/dns/fixtures/nsone/list_zones.json
+++ b/libcloud/test/dns/fixtures/nsone/list_zones.json
@@ -0,0 +1,40 @@
+[
+ {
+ "id": "520422af9f782d37dffb588b",
+ "ttl": 3600,
+ "nx_ttl": 3600,
+ "retry": 7200,
+ "zone": "example.com",
+ "refresh": 43200,
+ "expiry": 1209600,
+ "dns_servers": [
+ "dns1.p03.nsone.net",
+ "dns2.p03.nsone.net",
+ "dns3.p03.nsone.net",
+ "dns4.p03.nsone.net"
+ ],
+ "networks": [0],
+ "network_pools": ["p03"],
+ "meta": {},
+ "hostmaster": "hostmaster@nsone.net"
+ },
+ {
+ "id": "520422c99f782d37dffb5892",
+ "ttl": 3600,
+ "nx_ttl": 3600,
+ "retry": 7200,
+ "zone": "nsoneisgreat.com",
+ "refresh": 43200,
+ "expiry": 1209600,
+ "dns_servers": [
+ "dns1.p04.nsone.net",
+ "dns2.p04.nsone.net",
+ "dns3.p04.nsone.net",
+ "dns4.p04.nsone.net"
+ ],
+ "networks": [0],
+ "network_pools": ["p04"],
+ "meta": {},
+ "hostmaster": "hostmaster@nsone.net"
+ }
+]
\ No newline at end of file
http://git-wip-us.apache.org/repos/asf/libcloud/blob/2463fb84/libcloud/test/dns/fixtures/nsone/record_does_not_exist.json
----------------------------------------------------------------------
diff --git a/libcloud/test/dns/fixtures/nsone/record_does_not_exist.json b/libcloud/test/dns/fixtures/nsone/record_does_not_exist.json
new file mode 100644
index 0000000..0aef49e
--- /dev/null
+++ b/libcloud/test/dns/fixtures/nsone/record_does_not_exist.json
@@ -0,0 +1 @@
+{"message":"record not found"}
\ No newline at end of file
http://git-wip-us.apache.org/repos/asf/libcloud/blob/2463fb84/libcloud/test/dns/fixtures/nsone/zone_already_exists.json
----------------------------------------------------------------------
diff --git a/libcloud/test/dns/fixtures/nsone/zone_already_exists.json b/libcloud/test/dns/fixtures/nsone/zone_already_exists.json
new file mode 100644
index 0000000..3340a53
--- /dev/null
+++ b/libcloud/test/dns/fixtures/nsone/zone_already_exists.json
@@ -0,0 +1 @@
+{"message":"zone already exists"}
\ No newline at end of file
http://git-wip-us.apache.org/repos/asf/libcloud/blob/2463fb84/libcloud/test/dns/fixtures/nsone/zone_does_not_exist.json
----------------------------------------------------------------------
diff --git a/libcloud/test/dns/fixtures/nsone/zone_does_not_exist.json b/libcloud/test/dns/fixtures/nsone/zone_does_not_exist.json
new file mode 100644
index 0000000..ffe02d2
--- /dev/null
+++ b/libcloud/test/dns/fixtures/nsone/zone_does_not_exist.json
@@ -0,0 +1 @@
+{"message":"zone not found"}
\ No newline at end of file
http://git-wip-us.apache.org/repos/asf/libcloud/blob/2463fb84/libcloud/test/dns/test_nsone.py
----------------------------------------------------------------------
diff --git a/libcloud/test/dns/test_nsone.py b/libcloud/test/dns/test_nsone.py
index 6edf09d..f3c16f7 100644
--- a/libcloud/test/dns/test_nsone.py
+++ b/libcloud/test/dns/test_nsone.py
@@ -6,6 +6,9 @@ from libcloud.test.file_fixtures import DNSFileFixtures
from libcloud.test.secrets import DNS_PARAMS_NSONE
from libcloud.dns.drivers.nsone import NsOneDNSDriver
from libcloud.utils.py3 import httplib
+from libcloud.dns.types import ZoneDoesNotExistError, ZoneAlreadyExistsError,\
+ RecordDoesNotExistError, RecordAlreadyExistsError, RecordType
+from libcloud.dns.base import Zone, Record
class NsOneTests(unittest.TestCase):
@@ -13,6 +16,11 @@ class NsOneTests(unittest.TestCase):
NsOneMockHttp.type = None
NsOneDNSDriver.connectionCls.conn_classes = (None, NsOneMockHttp)
self.driver = NsOneDNSDriver(*DNS_PARAMS_NSONE)
+ self.test_zone = Zone(id='test.com', type='master', ttl=None,
+ domain='test.com', extra={}, driver=self)
+ self.test_record = Record(id='13', type=RecordType.A,
+ name='example.com', zone=self.test_zone,
+ data='127.0.0.1', driver=self, extra={})
def test_list_zones_empty(self):
NsOneMockHttp.type = 'EMPTY_ZONES_LIST'
@@ -20,6 +28,144 @@ class NsOneTests(unittest.TestCase):
self.assertEqual(zones, [])
+ def test_list_zones_success(self):
+ zones = self.driver.list_zones()
+
+ self.assertEqual(len(zones), 2)
+
+ zone = zones[0]
+ self.assertEqual(zone.id, '520422af9f782d37dffb588b')
+ self.assertEqual(zone.type, None)
+ self.assertEqual(zone.domain, 'example.com')
+ self.assertEqual(zone.ttl, 3600)
+
+ zone = zones[1]
+ self.assertEqual(zone.id, '520422c99f782d37dffb5892')
+ self.assertEqual(zone.type, None)
+ self.assertEqual(zone.domain, 'nsoneisgreat.com')
+ self.assertEqual(zone.ttl, 3600)
+
+ def test_delete_zone_zone_does_not_exist(self):
+ NsOneMockHttp.type = 'DELETE_ZONE_ZONE_DOES_NOT_EXIST'
+
+ try:
+ self.driver.delete_zone(zone=self.test_zone)
+ except ZoneDoesNotExistError:
+ e = sys.exc_info()[1]
+ self.assertEqual(e.zone_id, self.test_zone.id)
+ else:
+ self.fail('Exception was not thrown')
+
+ def test_delete_zone_success(self):
+ NsOneMockHttp.type = 'DELETE_ZONE_SUCCESS'
+ status = self.driver.delete_zone(zone=self.test_zone)
+
+ self.assertTrue(status)
+
+ def test_get_zone_success(self):
+ NsOneMockHttp.type = 'GET_ZONE_SUCCESS'
+ zone = self.driver.get_zone(zone_id='getzone.com')
+
+ self.assertEqual(zone.id, '52051b2c9f782d58bb4df41b')
+ self.assertEqual(zone.domain, 'example.com')
+ self.assertEqual(zone.type, None)
+ self.assertEqual(zone.ttl, 3600)
+
+ def test_get_zone_zone_does_not_exist(self):
+ NsOneMockHttp.type = 'GET_ZONE_ZONE_DOES_NOT_EXIST'
+ try:
+ self.driver.get_zone(zone_id='zonedoesnotexist.com')
+ except ZoneDoesNotExistError:
+ e = sys.exc_info()[1]
+ self.assertEqual(e.zone_id, 'zonedoesnotexist.com')
+ else:
+ self.fail('Exception was not thrown')
+
+ def test_create_zone_success(self):
+ NsOneMockHttp.type = 'CREATE_ZONE_SUCCESS'
+ zone = self.driver.create_zone(domain='newzone.com')
+
+ self.assertEqual(zone.id, '52051b2c9f782d58bb4df41b')
+ self.assertEqual(zone.domain, 'newzone.com')
+ self.assertEqual(zone.type, None),
+ self.assertEqual(zone.ttl, 3600)
+
+ def test_create_zone_zone_already_exists(self):
+ NsOneMockHttp.type = 'CREATE_ZONE_ZONE_ALREADY_EXISTS'
+
+ try:
+ self.driver.create_zone(domain='newzone.com')
+ except ZoneAlreadyExistsError:
+ e = sys.exc_info()[1]
+ self.assertEqual(e.zone_id, 'newzone.com')
+ else:
+ self.fail('Exception was not thrown')
+
+ def test_get_record_record_does_not_exist(self):
+ NsOneMockHttp.type = 'GET_RECORD_RECORD_DOES_NOT_EXIST'
+
+ try:
+ self.driver.get_record(zone_id='getrecord.com', record_id='A')
+ except RecordDoesNotExistError:
+ e = sys.exc_info()[1]
+ self.assertEqual(e.record_id, 'A')
+ else:
+ self.fail('Exception was not thrown')
+
+ def test_get_record_success(self):
+ NsOneMockHttp.type = 'GET_RECORD_SUCCESS'
+ record = self.driver.get_record(zone_id='getrecord.com', record_id='A')
+
+ self.assertEqual(record.id, '520519509f782d58bb4df419')
+ self.assertEqual(record.name, 'www.example.com')
+ self.assertEqual(record.data, ['1.1.1.1'])
+ self.assertEqual(record.type, RecordType.A)
+
+ def test_list_records_zone_does_not_exist(self):
+ NsOneMockHttp.type = 'LIST_RECORDS_ZONE_DOES_NOT_EXIST'
+
+ try:
+ self.driver.list_records(zone=self.test_zone)
+ except ZoneDoesNotExistError:
+ e = sys.exc_info()[1]
+ self.assertEqual(e.zone_id, self.test_zone.id)
+ else:
+ self.fail('Exception was not thrown')
+
+ def test_list_records_empty(self):
+ NsOneMockHttp.type = 'LIST_RECORDS_EMPTY'
+ records = self.driver.list_records(zone=self.test_zone)
+
+ self.assertEqual(records, [])
+
+ def test_list_records_success(self):
+ NsOneMockHttp.type = 'LIST_RECORDS_SUCCESS'
+ records = self.driver.list_records(zone=self.test_zone)
+ self.assertEqual(len(records), 2)
+
+ arecord = records[1]
+ self.assertEqual(arecord.id, '520519509f782d58bb4df419')
+ self.assertEqual(arecord.name, 'www.example.com')
+ self.assertEqual(arecord.type, RecordType.A)
+ self.assertEqual(arecord.data, ['1.2.3.4'])
+
+ def test_delete_record_record_does_not_exist(self):
+ NsOneMockHttp.type = 'DELETE_RECORD_RECORD_DOES_NOT_EXIST'
+
+ try:
+ self.driver.delete_record(record=self.test_record)
+ except RecordDoesNotExistError:
+ e = sys.exc_info()[1]
+ self.assertEqual(e.record_id, self.test_record.id)
+ else:
+ self.fail('Exception was not thrown')
+
+ def test_delete_record_success(self):
+ NsOneMockHttp.type = 'DELETE_RECORD_SUCCESS'
+ status = self.driver.delete_record(record=self.test_record)
+
+ self.assertTrue(status)
+
class NsOneMockHttp(MockHttp):
fixtures = DNSFileFixtures('nsone')
@@ -29,6 +175,80 @@ class NsOneMockHttp(MockHttp):
return httplib.OK, body, {}, httplib.responses[httplib.OK]
+ def _v1_zones(self, method, url, body, headers):
+ body = self.fixtures.load('list_zones.json')
+
+ return httplib.OK, body, {}, httplib.responses[httplib.OK]
+
+ def _v1_zones_getzone_com_GET_ZONE_SUCCESS(self, method, url, body, headers):
+ body = self.fixtures.load('get_zone_success.json')
+
+ return httplib.OK, body, {}, httplib.responses[httplib.OK]
+
+ def _v1_zones_zonedoesnotexist_com_GET_ZONE_ZONE_DOES_NOT_EXIST(self, method, url, body, headers):
+ body = self.fixtures.load('zone_does_not_exist.json')
+
+ return 404, body, {}, httplib.responses[httplib.OK]
+
+ def _v1_zones_test_com_DELETE_ZONE_SUCCESS(self, method, url, body, headers):
+ body = self.fixtures.load('delete_zone_success.json')
+
+ return httplib.OK, body, {}, httplib.responses[httplib.OK]
+
+ def _v1_zones_test_com_DELETE_ZONE_ZONE_DOES_NOT_EXIST(self, method, url, body, headers):
+ body = self.fixtures.load('zone_does_not_exist.json')
+
+ return httplib.OK, body, {}, httplib.responses[httplib.OK]
+
+ def _v1_zones_newzone_com_CREATE_ZONE_SUCCESS(self, method, url, body, headers):
+ body = self.fixtures.load('create_zone_success.json')
+
+ return httplib.OK, body, {}, httplib.responses[httplib.OK]
+
+ def _v1_zones_newzone_com_CREATE_ZONE_ZONE_ALREADY_EXISTS(self, method, url, body, headers):
+ body = self.fixtures.load('zone_already_exists.json')
+
+ return httplib.OK, body, {}, httplib.responses[httplib.OK]
+
+ def _v1_zones_test_com_LIST_RECORDS_SUCCESS(self, method, url, body, headers):
+ body = self.fixtures.load('get_zone_success.json')
+
+ return httplib.OK, body, {}, httplib.responses[httplib.OK]
+
+ def _v1_zones_test_com_LIST_RECORDS_EMPTY(self, method, url, body, headers):
+ body = self.fixtures.load('list_records_empty.json')
+
+ return httplib.OK, body, {}, httplib.responses[httplib.OK]
+
+ def _v1_zones_test_com_LIST_RECORDS_ZONE_DOES_NOT_EXIST(self, method, url, body, headers):
+ body = self.fixtures.load('zone_does_not_exist.json')
+
+ return httplib.OK, body, {}, httplib.responses[httplib.OK]
+
+ def _v1_zones_test_com_example_com_A_DELETE_RECORD_RECORD_DOES_NOT_EXIST(self, method, url, body, headers):
+ body = self.fixtures.load('record_does_not_exist.json')
+
+ return 404, body, {}, httplib.responses[httplib.OK]
+
+ def _v1_zones_test_com_example_com_A_DELETE_RECORD_SUCCESS(self, method, url, body, headers):
+ body = self.fixtures.load('delete_record_success.json')
+
+ return httplib.OK, body, {}, httplib.responses[httplib.OK]
+
+ def _v1_zones_getrecord_com_getrecord_com_A_GET_RECORD_SUCCESS(self, method, url, body, headers):
+ body = self.fixtures.load('get_record_success.json')
+
+ return httplib.OK, body, {}, httplib.responses[httplib.OK]
+
+ def _v1_zones_getrecord_com_GET_RECORD_SUCCESS(self, method, url, body, headers):
+ body = self.fixtures.load('get_zone_success.json')
+
+ return httplib.OK, body, {}, httplib.responses[httplib.OK]
+
+ def _v1_zones_getrecord_com_getrecord_com_A_GET_RECORD_RECORD_DOES_NOT_EXIST(self, method, url, body, headers):
+ body = self.fixtures.load('record_does_not_exist.json')
+
+ return httplib.OK, body, {}, httplib.responses[httplib.OK]
if __name__ == '__main__':
sys.exit(unittest.main())