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())