testdyndns12update.py 8.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185
  1. from django.core.urlresolvers import reverse
  2. from rest_framework import status
  3. from rest_framework.test import APITestCase
  4. from .utils import utils
  5. from django.db import transaction
  6. import base64
  7. import httpretty
  8. from django.conf import settings
  9. class DynDNS12UpdateTest(APITestCase):
  10. owner = None
  11. token = None
  12. username = None
  13. password = None
  14. def setUp(self):
  15. self.owner = utils.createUser()
  16. self.token = utils.createToken(user=self.owner)
  17. self.domain = utils.generateDynDomainname()
  18. self.client.credentials(HTTP_AUTHORIZATION='Token ' + self.token)
  19. url = reverse('domain-list')
  20. data = {'name': self.domain, 'dyn': True}
  21. response = self.client.post(url, data)
  22. self.assertEqual(response.status_code, status.HTTP_201_CREATED)
  23. self.assertEqual(response.data['dyn'], True)
  24. self.username = response.data['name']
  25. self.password = self.token
  26. self.client.credentials(HTTP_AUTHORIZATION='Basic ' + base64.b64encode((self.username + ':' + self.password).encode()).decode())
  27. httpretty.enable()
  28. httpretty.HTTPretty.allow_net_connect = False
  29. httpretty.register_uri(httpretty.POST, settings.POWERDNS_API + '/zones')
  30. httpretty.register_uri(httpretty.PATCH, settings.POWERDNS_API + '/zones/' + self.domain + '.')
  31. def tearDown(self):
  32. httpretty.disable()
  33. def assertIP(self, ipv4=None, ipv6=None):
  34. old_credentials = self.client._credentials['HTTP_AUTHORIZATION']
  35. self.client.credentials(HTTP_AUTHORIZATION='Token ' + self.password)
  36. url = reverse('domain-detail/byName', args=(self.username,))
  37. response = self.client.get(url)
  38. self.assertEqual(response.status_code, status.HTTP_200_OK)
  39. if ipv4 is not None:
  40. self.assertEqual(response.data['arecord'], ipv4)
  41. if ipv6 is not None:
  42. self.assertEqual(response.data['aaaarecord'], ipv6)
  43. self.client.credentials(HTTP_AUTHORIZATION=old_credentials)
  44. def testDynDNS1UpdateDDClientSuccess(self):
  45. # /nic/dyndns?action=edit&started=1&hostname=YES&host_id=foobar.dedyn.io&myip=10.1.2.3
  46. url = reverse('dyndns12update')
  47. response = self.client.get(url,
  48. {
  49. 'action': 'edit',
  50. 'started': 1,
  51. 'hostname': 'YES',
  52. 'host_id': self.username,
  53. 'myip': '10.1.2.3'
  54. })
  55. self.assertEqual(response.status_code, status.HTTP_200_OK)
  56. self.assertEqual(response.data, 'good')
  57. self.assertIP(ipv4='10.1.2.3')
  58. def testDynDNS1UpdateDDClientIPv6Success(self):
  59. # /nic/dyndns?action=edit&started=1&hostname=YES&host_id=foobar.dedyn.io&myipv6=::1337
  60. url = reverse('dyndns12update')
  61. response = self.client.get(url,
  62. {
  63. 'action': 'edit',
  64. 'started': 1,
  65. 'hostname': 'YES',
  66. 'host_id': self.username,
  67. 'myipv6': '::1337'
  68. })
  69. self.assertEqual(response.status_code, status.HTTP_200_OK)
  70. self.assertEqual(response.data, 'good')
  71. self.assertIP(ipv6='::1337')
  72. def testDynDNS2UpdateDDClientIPv4Success(self):
  73. #/nic/update?system=dyndns&hostname=foobar.dedyn.io&myip=10.2.3.4
  74. url = reverse('dyndns12update')
  75. response = self.client.get(url,
  76. {
  77. 'system': 'dyndns',
  78. 'hostname': self.username,
  79. 'myip': '10.2.3.4'
  80. })
  81. self.assertEqual(response.status_code, status.HTTP_200_OK)
  82. self.assertEqual(response.data, 'good')
  83. self.assertIP(ipv4='10.2.3.4')
  84. def testDynDNS2UpdateDDClientIPv6Success(self):
  85. #/nic/update?system=dyndns&hostname=foobar.dedyn.io&myipv6=::1338
  86. url = reverse('dyndns12update')
  87. response = self.client.get(url,
  88. {
  89. 'system': 'dyndns',
  90. 'hostname': self.username,
  91. 'myipv6': '::1338'
  92. })
  93. self.assertEqual(response.status_code, status.HTTP_200_OK)
  94. self.assertEqual(response.data, 'good')
  95. self.assertIP(ipv6='::1338')
  96. def testFritzBoxIPv6(self):
  97. #/
  98. url = reverse('dyndns12update')
  99. response = self.client.get(url)
  100. self.assertEqual(response.status_code, status.HTTP_200_OK)
  101. self.assertEqual(response.data, 'good')
  102. self.assertIP(ipv4='127.0.0.1')
  103. def testManualIPv6(self):
  104. #/update?username=foobar.dedyn.io&password=secret
  105. self.client.credentials(HTTP_AUTHORIZATION='')
  106. url = reverse('dyndns12update')
  107. response = self.client.get(url,
  108. {
  109. 'username': self.username,
  110. 'password': self.token,
  111. })
  112. self.assertEqual(response.status_code, status.HTTP_200_OK)
  113. self.assertEqual(response.data, 'good')
  114. self.assertIP(ipv4='127.0.0.1')
  115. def testSuspendedUpdates(self):
  116. self.owner.captcha_required = True
  117. self.owner.save()
  118. httpretty.reset()
  119. httpretty.enable()
  120. httpretty.HTTPretty.allow_net_connect = False
  121. domain = self.owner.domains.all()[0]
  122. domain.arecord = '10.1.1.1'
  123. domain.save()
  124. httpretty.register_uri(httpretty.PATCH, settings.POWERDNS_API + '/zones/' + self.domain + '.')
  125. httpretty.register_uri(httpretty.GET, settings.POWERDNS_API + '/zones/' + self.domain + '.', status=200)
  126. self.owner.unlock()
  127. self.assertEqual(httpretty.last_request().method, 'PATCH')
  128. self.assertTrue((settings.POWERDNS_API + '/zones/' + self.domain + '.').endswith(httpretty.last_request().path))
  129. self.assertTrue(self.domain in httpretty.last_request().parsed_body)
  130. self.assertTrue('10.1.1.1' in httpretty.last_request().parsed_body)
  131. def testSuspendedUpdatesDomainCreation(self):
  132. self.owner.captcha_required = True
  133. self.owner.save()
  134. httpretty.reset()
  135. httpretty.enable()
  136. httpretty.HTTPretty.allow_net_connect = False
  137. url = reverse('domain-list')
  138. newdomain = utils.generateDynDomainname()
  139. data = {'name': newdomain, 'dyn': True, 'arecord': '10.2.2.2'}
  140. self.client.credentials(HTTP_AUTHORIZATION='Token ' + self.token)
  141. response = self.client.post(url, data)
  142. self.assertEqual(response.status_code, status.HTTP_201_CREATED)
  143. self.assertEqual(response.data['dyn'], True)
  144. domain = self.owner.domains.all()[0]
  145. domain.arecord = '10.1.1.1'
  146. domain.save()
  147. httpretty.register_uri(httpretty.POST, settings.POWERDNS_API + '/zones')
  148. httpretty.register_uri(httpretty.PATCH, settings.POWERDNS_API + '/zones/' + newdomain + '.')
  149. httpretty.register_uri(httpretty.GET, settings.POWERDNS_API + '/zones/' + newdomain + '.', status=200)
  150. httpretty.register_uri(httpretty.PATCH, settings.POWERDNS_API + '/zones/' + self.domain + '.')
  151. httpretty.register_uri(httpretty.GET, settings.POWERDNS_API + '/zones/' + self.domain + '.', status=200)
  152. self.owner.unlock()
  153. self.assertEqual(httpretty.last_request().method, 'PATCH')
  154. self.assertTrue(
  155. (settings.POWERDNS_API + '/zones/' + self.domain + '.').endswith(httpretty.last_request().path) \
  156. or (settings.POWERDNS_API + '/zones/' + newdomain + '.').endswith(httpretty.last_request().path)
  157. )
  158. self.assertTrue('10.2.2.2' in httpretty.last_request().parsed_body)