1
0
mirror of https://github.com/peeringdb/peeringdb.git synced 2024-05-11 05:55:09 +00:00
Files
peeringdb-peeringdb/tests/test_partners.py
Matt Griswold ba6f9b6432 Qu1003 (#621)
* use new peeringdb client (1.0.0) for pdb_load_data sync (#599)

* drop django-mobi for lack of py3/dj2 support (#492)
remove django-forms-bootstrap for lack of py3/dj2 support (#492)

* black formatted

* django2.2 and py3 upgrade (#492)

* drop ixlans (#21) ui and api changes

* drop local_asn (#168)

* org search (#193)

* phone number validation (#50)

* implement help text tooltips (#228)

* Mark own ASN as transit-free (#394)

* py3 fix for `pdb_migrate_ixlans` command when writing migration report

* pdb_migrate_ixlans: properly handle py3 Runtime error if ixlan dict changes during iteration

* set rest DEFAULT_SCHEMA_CLASS to coreapi to fix swagger apidocs
fix migration 0027 missing from facsimile manifest

* fix swagger doc strings

* fix tests that were broken from api doc fixes

* fix UniqueFieldValidator for netixlan ipaddress validation that broke during django/drf upgrade

* fix org merge tool layout issues

* travis config

* update pipfile and lock

* black formatting

* update travis dist

* beta mode banner (#411)

* add beta banner template (#411)

* automatically scheduled sync may not always be on, add a flag that lets us reflect that state in the beta banner message
clean up beta banner implementation (#411)

* add tests for beta banner (#411)
2020-01-08 13:29:58 -06:00

97 lines
3.0 KiB
Python

import pytest
import json
import uuid
import re
from django.test import Client, TestCase, RequestFactory
from django.contrib.auth.models import Group, AnonymousUser
from django.contrib.auth import get_user
import django_namespace_perms as nsp
import peeringdb_server.views as views
import peeringdb_server.models as models
class ViewTestCase(TestCase):
entities = ["ix", "net", "fac"]
@classmethod
def setUpTestData(cls):
# create user and guest group
guest_group = Group.objects.create(name="guest")
user_group = Group.objects.create(name="user")
cls.guest_user = models.User.objects.create_user(
"guest", "guest@localhost", "guest"
)
cls.guest_user.set_password("guest")
guest_group.user_set.add(cls.guest_user)
# create organizations
cls.organizations = dict(
(
k,
models.Organization.objects.create(
name="Partner Org %s" % k, status="ok"
),
)
for k in ["a", "b", "c", "d"]
)
# create partnerships
cls.partnerships = {
"a": models.Partnership.objects.create(
org=cls.organizations.get("a"),
logo="fake.png",
url="org-a.com",
level=1,
),
"b": models.Partnership.objects.create(
org=cls.organizations.get("b"), logo="fake.png", level=1
),
"c": models.Partnership.objects.create(
org=cls.organizations.get("c"), logo="fake.png", level=2
),
"d": models.Partnership.objects.create(
org=cls.organizations.get("d"), level=1
),
}
def setUp(self):
self.factory = RequestFactory()
def test_view(self):
# disable this test until we re-enable the partners page
return
c = Client()
resp = c.get("/partners", follow=True)
self.assertEqual(resp.status_code, 200)
# make sure org a,b and c exist in the partners page
assert self.organizations["a"].name in resp.content.decode()
assert self.organizations["b"].name in resp.content.decode()
assert self.organizations["c"].name in resp.content.decode()
# make sure org d does not exist in the partners page
assert self.organizations["d"].name not in resp.content.decode()
# make sure partnership a url exists in the partners page
assert self.organizations["a"].url in resp.content.decode()
# makre sure order is randomized with each view
i = 0
rgx = re.compile(r'fake.png" alt="([^"]+)"')
a = re.findall(rgx, resp.content)
while i < 100:
resp = c.get("/partners", follow=True)
b = re.findall(rgx, resp.content)
self.assertEqual(len(a), len(b))
if b != a:
break
i += 1
self.assertLess(i, 99)