mirror of
				https://github.com/peeringdb/peeringdb.git
				synced 2024-05-11 05:55:09 +00:00 
			
		
		
		
	* 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)
		
			
				
	
	
		
			97 lines
		
	
	
		
			3.0 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			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)
 |