uncloud-mravi/uncloud_net/tests.py
Nico Schottelius caedf874e4 [vpn] add tests
2020-05-20 21:00:08 +02:00

74 lines
2.9 KiB
Python

from django.test import TestCase
from rest_framework.test import APIRequestFactory, force_authenticate
from rest_framework.reverse import reverse
from django.contrib.auth import get_user_model
from django.core.exceptions import ValidationError
from .views import *
from .models import *
class VPNTests(TestCase):
def setUp(self):
self.user = get_user_model().objects.create_user('django-test-user', 'noreply@ungleich.ch')
self.admin_user = get_user_model().objects.create_user('django-test-adminuser', 'noreply-admin@ungleich.ch')
self.admin_user.is_staff = True
self.admin_user.save()
self.pool_network = '2001:db8::'
self.pool_network2 = '2001:db8:1::'
self.pool_network_size = '48'
self.pool_subnetwork_size = '64'
self.pool_vpn_hostname = 'vpn.example.org'
self.pool_wireguard_private_key = 'MOz8kk0m4jhNtAXlge0qzexZh1MipIhu4HJwtdvZ2EY='
self.vpn_wireguard_public_key = 'B2b78eWBIXPMM1x4DDjkCDZepS0qDgcLN3T3PjcgXkY='
self.vpnpool = VPNPool.objects.get_or_create(network=self.pool_network,
network_size=self.pool_network_size,
subnetwork_size=self.pool_subnetwork_size,
vpn_hostname=self.pool_vpn_hostname,
wireguard_private_key=self.pool_wireguard_private_key
)
self.factory = APIRequestFactory()
def test_create_vpnpool(self):
url = reverse("vpnpool-list")
view = VPNPoolViewSet.as_view({'post': 'create'})
request = self.factory.post(url, { 'network': self.pool_network2,
'network_size': self.pool_network_size,
'subnetwork_size': self.pool_subnetwork_size,
'vpn_hostname': self.pool_vpn_hostname,
'wireguard_private_key': self.pool_wireguard_private_key
})
force_authenticate(request, user=self.admin_user)
response = view(request)
# This raises an exception if the request was not successful
# No assert needed
pool = VPNPool.objects.get(network=self.pool_network2)
def test_create_vpn(self):
url = reverse("vpnnetwork-list")
view = VPNNetworkViewSet.as_view({'post': 'create'})
request = self.factory.post(url, { 'network_size': self.pool_subnetwork_size,
'wireguard_public_key': self.vpn_wireguard_public_key
})
force_authenticate(request, user=self.user)
# we don't have a billing address
with self.assertRaises(ValidationError):
response = view(request)
#print(response)
def tearDown(self):
self.user.delete()
self.admin_user.delete()