Skip to content

Commit

Permalink
Merge pull request #178 from jazzband/split-up-tests
Browse files Browse the repository at this point in the history
Split up test modules
  • Loading branch information
mbeijen authored Mar 12, 2024
2 parents fccea08 + b9faa80 commit 84534ec
Show file tree
Hide file tree
Showing 8 changed files with 383 additions and 337 deletions.
61 changes: 61 additions & 0 deletions tests/test_admin.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,61 @@
from urllib.parse import urlencode

from django.contrib.auth.models import User
from django.test import TestCase
from django.urls import reverse

from user_sessions.backends.db import SessionStore

from .utils import Client


class AdminTest(TestCase):
client_class = Client

def setUp(self):
User.objects.create_superuser('bouke', '', 'secret')
assert self.client.login(username='bouke', password='secret')

expired = SessionStore(user_agent='Python/2.5', ip='20.13.1.1')
expired.set_expiry(-365 * 86400)
expired.save()
unexpired = SessionStore(user_agent='Python/2.7', ip='1.1.1.1')
unexpired.save()

self.admin_url = reverse('admin:user_sessions_session_changelist')

def test_list(self):
with self.assertWarnsRegex(UserWarning, r"The address 1\.1\.1\.1 is not in the database"):
response = self.client.get(self.admin_url)
self.assertContains(response, 'Select session to change')
self.assertContains(response, '127.0.0.1')
self.assertContains(response, '20.13.1.1')
self.assertContains(response, '1.1.1.1')

def test_search(self):
with self.assertWarnsRegex(UserWarning, r"The address 127\.0\.0\.1 is not in the database"):
response = self.client.get(self.admin_url, {'q': 'bouke'})
self.assertContains(response, '127.0.0.1')
self.assertNotContains(response, '20.13.1.1')
self.assertNotContains(response, '1.1.1.1')

def test_mine(self):
my_sessions = f"{self.admin_url}?{urlencode({'owner': 'my'})}"
with self.assertWarnsRegex(UserWarning, r"The address 127\.0\.0\.1 is not in the database"):
response = self.client.get(my_sessions)
self.assertContains(response, '127.0.0.1')
self.assertNotContains(response, '1.1.1.1')

def test_expired(self):
expired = f"{self.admin_url}?{urlencode({'active': '0'})}"
with self.assertWarnsRegex(UserWarning, r"The address 20\.13\.1\.1 is not in the database"):
response = self.client.get(expired)
self.assertContains(response, '20.13.1.1')
self.assertNotContains(response, '1.1.1.1')

def test_unexpired(self):
unexpired = f"{self.admin_url}?{urlencode({'active': '1'})}"
with self.assertWarnsRegex(UserWarning, r"The address 1\.1\.1\.1 is not in the database"):
response = self.client.get(unexpired)
self.assertContains(response, '1.1.1.1')
self.assertNotContains(response, '20.13.1.1')
51 changes: 51 additions & 0 deletions tests/test_client.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,51 @@
from unittest.mock import patch

from django.contrib.auth.models import User
from django.conf import settings
from django.test import TestCase
from django.test.utils import override_settings

from user_sessions.backends.db import SessionStore

from .utils import Client


class ClientTest(TestCase):
def test_invalid_login(self):
client = Client()
self.assertFalse(client.login())

def test_restore_session(self):
store = SessionStore(user_agent='Python/2.7', ip='127.0.0.1')
store['foo'] = 'bar'
store.save()
client = Client()
client.cookies[settings.SESSION_COOKIE_NAME] = store.session_key
User.objects.create_user('bouke', '', 'secret')
assert client.login(username='bouke', password='secret')
self.assertEqual(client.session['foo'], 'bar')

def test_login_logout(self):
client = Client()
User.objects.create_user('bouke', '', 'secret')
assert client.login(username='bouke', password='secret')
assert settings.SESSION_COOKIE_NAME in client.cookies

client.logout()
assert settings.SESSION_COOKIE_NAME not in client.cookies

# should not raise
client.logout()

@patch('django.contrib.auth.signals.user_logged_in.send')
def test_login_signal(self, mock_user_logged_in):
client = Client()
User.objects.create_user('bouke', '', 'secret')
assert client.login(username='bouke', password='secret')
assert mock_user_logged_in.called
request = mock_user_logged_in.call_args[1]['request']
assert getattr(request, 'user', None) is not None

@override_settings(INSTALLED_APPS=())
def test_no_session(self):
self.assertIsNone(Client().session)
42 changes: 42 additions & 0 deletions tests/test_commands.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,42 @@
from datetime import timedelta

from django.contrib.auth.models import User
from django.core.management import call_command
from django.test import TestCase, TransactionTestCase
from django.test.utils import modify_settings
from django.utils.timezone import now

from user_sessions.models import Session


class ClearsessionsCommandTest(TestCase):
def test_can_call(self):
Session.objects.create(expire_date=now() - timedelta(days=1),
ip='127.0.0.1')
call_command('clearsessions')
self.assertEqual(Session.objects.count(), 0)


class MigratesessionsCommandTest(TransactionTestCase):
@modify_settings(INSTALLED_APPS={'append': 'django.contrib.sessions'})
def test_migrate_from_login(self):
from django.contrib.sessions.backends.db import (
SessionStore as DjangoSessionStore,
)
from django.contrib.sessions.models import Session as DjangoSession
try:
call_command('migrate', 'sessions')
call_command('clearsessions')
user = User.objects.create_user('bouke', '', 'secret')
session = DjangoSessionStore()
session['_auth_user_id'] = user.id
session.save()
self.assertEqual(Session.objects.count(), 0)
self.assertEqual(DjangoSession.objects.count(), 1)
call_command('migratesessions')
new_sessions = list(Session.objects.all())
self.assertEqual(len(new_sessions), 1)
self.assertEqual(new_sessions[0].user, user)
self.assertEqual(new_sessions[0].ip, '127.0.0.1')
finally:
call_command('migrate', 'sessions', 'zero')
45 changes: 45 additions & 0 deletions tests/test_middleware.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,45 @@
from django.contrib.auth.models import User
from django.conf import settings
from django.test import TestCase
from django.urls import reverse

from user_sessions.models import Session


class MiddlewareTest(TestCase):
def test_unmodified_session(self):
self.client.get('/', HTTP_USER_AGENT='Python/2.7')
self.assertNotIn(settings.SESSION_COOKIE_NAME, self.client.cookies)

def test_modify_session(self):
self.client.get('/modify_session/', HTTP_USER_AGENT='Python/2.7')
self.assertIn(settings.SESSION_COOKIE_NAME, self.client.cookies)
session = Session.objects.get(
pk=self.client.cookies[settings.SESSION_COOKIE_NAME].value
)
self.assertEqual(session.user_agent, 'Python/2.7')
self.assertEqual(session.ip, '127.0.0.1')

def test_login(self):
admin_login_url = reverse('admin:login')
user = User.objects.create_superuser('bouke', '', 'secret')
response = self.client.post(admin_login_url,
data={
'username': 'bouke',
'password': 'secret',
'this_is_the_login_form': '1',
'next': '/admin/'},
HTTP_USER_AGENT='Python/2.7')
self.assertRedirects(response, '/admin/')
session = Session.objects.get(
pk=self.client.cookies[settings.SESSION_COOKIE_NAME].value
)
self.assertEqual(
self.client.cookies[settings.SESSION_COOKIE_NAME]["samesite"],
settings.SESSION_COOKIE_SAMESITE,
)
self.assertEqual(user, session.user)

def test_long_ua(self):
self.client.get('/modify_session/',
HTTP_USER_AGENT=''.join('a' for _ in range(400)))
30 changes: 30 additions & 0 deletions tests/test_models.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,30 @@
from django.contrib import auth
from django.contrib.auth.models import User
from django.test import TestCase

from user_sessions.backends.db import SessionStore
from user_sessions.models import Session


class ModelTest(TestCase):
def test_get_decoded(self):
User.objects.create_user('bouke', '', 'secret', id=1)
store = SessionStore(user_agent='Python/2.7', ip='127.0.0.1')
store[auth.SESSION_KEY] = 1
store['foo'] = 'bar'
store.save()

session = Session.objects.get(pk=store.session_key)
self.assertEqual(session.get_decoded(),
{'foo': 'bar', auth.SESSION_KEY: 1})

def test_very_long_ua(self):
ua = 'Mozilla/4.0 (compatible; MSIE 7.0; Windows NT 6.1; WOW64; ' \
'Trident/5.0; SLCC2; .NET CLR 2.0.50727; .NET CLR 3.5.30729; ' \
'.NET CLR 3.0.30729; Media Center PC 6.0; .NET4.0C; .NET4.0E; ' \
'InfoPath.3; ms-office; MSOffice 14)'
store = SessionStore(user_agent=ua, ip='127.0.0.1')
store.save()

session = Session.objects.get(pk=store.session_key)
self.assertEqual(session.user_agent, ua[:200])
99 changes: 99 additions & 0 deletions tests/test_sessionstore.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,99 @@
from datetime import timedelta

from django.contrib import auth
from django.contrib.auth.models import User
from django.contrib.sessions.backends.base import CreateError
from django.test import TestCase
from django.utils.timezone import now

from user_sessions.backends.db import SessionStore
from user_sessions.models import Session


class SessionStoreTest(TestCase):
def setUp(self):
self.store = SessionStore(user_agent='Python/2.7', ip='127.0.0.1')
User.objects.create_user('bouke', '', 'secret', id=1)

def test_untouched_init(self):
self.assertFalse(self.store.modified)
self.assertFalse(self.store.accessed)

def test_auth_session_key(self):
self.assertFalse(auth.SESSION_KEY in self.store)
self.assertFalse(self.store.modified)
self.assertTrue(self.store.accessed)

self.store.get(auth.SESSION_KEY)
self.assertFalse(self.store.modified)

self.store[auth.SESSION_KEY] = 1
self.assertTrue(self.store.modified)

def test_save(self):
self.store[auth.SESSION_KEY] = 1
self.store.save()

session = Session.objects.get(pk=self.store.session_key)
self.assertEqual(session.user_agent, 'Python/2.7')
self.assertEqual(session.ip, '127.0.0.1')
self.assertEqual(session.user_id, 1)
self.assertAlmostEqual(now(), session.last_activity,
delta=timedelta(seconds=5))

def test_load_unmodified(self):
self.store[auth.SESSION_KEY] = 1
self.store.save()
store2 = SessionStore(session_key=self.store.session_key,
user_agent='Python/2.7', ip='127.0.0.1')
store2.load()
self.assertEqual(store2.user_agent, 'Python/2.7')
self.assertEqual(store2.ip, '127.0.0.1')
self.assertEqual(store2.user_id, 1)
self.assertEqual(store2.modified, False)

def test_load_modified(self):
self.store[auth.SESSION_KEY] = 1
self.store.save()
store2 = SessionStore(session_key=self.store.session_key,
user_agent='Python/3.3', ip='8.8.8.8')
store2.load()
self.assertEqual(store2.user_agent, 'Python/3.3')
self.assertEqual(store2.ip, '8.8.8.8')
self.assertEqual(store2.user_id, 1)
self.assertEqual(store2.modified, True)

def test_duplicate_create(self):
s1 = SessionStore(session_key='DUPLICATE', user_agent='Python/2.7', ip='127.0.0.1')
s1.create()
s2 = SessionStore(session_key='DUPLICATE', user_agent='Python/2.7', ip='127.0.0.1')
s2.create()
self.assertNotEqual(s1.session_key, s2.session_key)

s3 = SessionStore(session_key=s1.session_key, user_agent='Python/2.7', ip='127.0.0.1')
with self.assertRaises(CreateError):
s3.save(must_create=True)

def test_delete(self):
# not persisted, should just return
self.store.delete()

# create, then delete
self.store.create()
session_key = self.store.session_key
self.store.delete()

# non-existing sessions, should not raise
self.store.delete()
self.store.delete(session_key)

def test_clear(self):
"""
Clearing the session should clear all non-browser information
"""
self.store[auth.SESSION_KEY] = 1
self.store.clear()
self.store.save()

session = Session.objects.get(pk=self.store.session_key)
self.assertEqual(session.user_id, None)
Loading

0 comments on commit 84534ec

Please sign in to comment.