1
0
mirror of https://github.com/spl0k/supysonic.git synced 2024-11-10 04:02:17 +00:00
supysonic/tests/managers/test_manager_user.py

133 lines
6.2 KiB
Python
Raw Normal View History

#!/usr/bin/env python
2017-07-13 20:02:03 +00:00
# -*- coding: utf-8 -*-
# vim:fenc=utf-8
#
# This file is part of Supysonic.
# Supysonic is a Python implementation of the Subsonic server API.
2017-07-13 20:02:03 +00:00
#
# Copyright (C) 2013-2017 Alban 'spl0k' Féron
# 2017 Óscar García Amor
#
# Distributed under terms of the GNU AGPLv3 license.
2017-07-13 20:02:03 +00:00
from supysonic import db
from supysonic.managers.user import UserManager
import unittest
import uuid
2017-10-28 13:54:41 +00:00
import io
2017-07-13 20:02:03 +00:00
class UserManagerTestCase(unittest.TestCase):
def setUp(self):
# Create an empty sqlite database in memory
self.store = db.get_store("sqlite:")
# Read schema from file
2017-10-28 13:54:41 +00:00
with io.open('schema/sqlite.sql', 'r') as sql:
2017-07-13 20:02:03 +00:00
schema = sql.read()
2017-10-28 13:54:41 +00:00
# Create tables on memory database
for command in schema.split(';'):
self.store.execute(command)
2017-07-13 20:02:03 +00:00
# Create some users
2017-10-28 13:54:41 +00:00
self.assertEqual(UserManager.add(self.store, 'alice', 'ALICE', 'test@example.com', True), UserManager.SUCCESS)
self.assertEqual(UserManager.add(self.store, 'bob', 'BOB', 'bob@example.com', False), UserManager.SUCCESS)
self.assertEqual(UserManager.add(self.store, 'charlie', 'CHARLIE', 'charlie@example.com', False), UserManager.SUCCESS)
2017-07-13 20:02:03 +00:00
def test_encrypt_password(self):
2017-10-28 13:54:41 +00:00
func = UserManager._UserManager__encrypt_password
self.assertEqual(func(u'password',u'salt'), (u'59b3e8d637cf97edbe2384cf59cb7453dfe30789', u'salt'))
self.assertEqual(func(u'pass-word',u'pepper'), (u'd68c95a91ed7773aa57c7c044d2309a5bf1da2e7', u'pepper'))
self.assertEqual(func(u'éèàïô', u'ABC+'), (u'b639ba5217b89c906019d89d5816b407d8730898', u'ABC+'))
2017-07-13 20:02:03 +00:00
def test_get_user(self):
# Get existing users
for name in ['alice', 'bob', 'charlie']:
user = self.store.find(db.User, db.User.name == name).one()
self.assertEqual(UserManager.get(self.store, user.id), (UserManager.SUCCESS, user))
2017-10-28 13:54:41 +00:00
2017-07-13 20:02:03 +00:00
# Get with invalid UUID
self.assertEqual(UserManager.get(self.store, 'invalid-uuid'), (UserManager.INVALID_ID, None))
2017-10-28 13:54:41 +00:00
self.assertEqual(UserManager.get(self.store, 0xfee1bad), (UserManager.INVALID_ID, None))
2017-07-13 20:02:03 +00:00
# Non-existent user
self.assertEqual(UserManager.get(self.store, uuid.uuid4()), (UserManager.NO_SUCH_USER, None))
def test_add_user(self):
2017-10-28 13:54:41 +00:00
# Added in setUp()
self.assertEqual(self.store.find(db.User).count(), 3)
2017-07-13 20:02:03 +00:00
# Create duplicate
2017-10-28 13:54:41 +00:00
self.assertEqual(UserManager.add(self.store, 'alice', 'Alic3', 'alice@example.com', True), UserManager.NAME_EXISTS)
2017-07-13 20:02:03 +00:00
def test_delete_user(self):
# Delete invalid UUID
self.assertEqual(UserManager.delete(self.store, 'invalid-uuid'), UserManager.INVALID_ID)
2017-10-28 13:54:41 +00:00
self.assertEqual(UserManager.delete(self.store, 0xfee1b4d), UserManager.INVALID_ID)
self.assertEqual(self.store.find(db.User).count(), 3)
2017-07-13 20:02:03 +00:00
# Delete non-existent user
self.assertEqual(UserManager.delete(self.store, uuid.uuid4()), UserManager.NO_SUCH_USER)
2017-10-28 13:54:41 +00:00
self.assertEqual(self.store.find(db.User).count(), 3)
# Delete existing users
for name in ['alice', 'bob', 'charlie']:
user = self.store.find(db.User, db.User.name == name).one()
self.assertEqual(UserManager.delete(self.store, user.id), UserManager.SUCCESS)
self.assertIsNone(self.store.get(db.User, user.id))
self.assertEqual(self.store.find(db.User).count(), 0)
2017-07-13 20:02:03 +00:00
def test_try_auth(self):
# Test authentication
for name in ['alice', 'bob', 'charlie']:
user = self.store.find(db.User, db.User.name == name).one()
2017-10-28 13:54:41 +00:00
self.assertEqual(UserManager.try_auth(self.store, name, name.upper()), (UserManager.SUCCESS, user))
2017-07-13 20:02:03 +00:00
# Wrong password
2017-10-28 13:54:41 +00:00
self.assertEqual(UserManager.try_auth(self.store, 'alice', 'bad'), (UserManager.WRONG_PASS, None))
self.assertEqual(UserManager.try_auth(self.store, 'alice', 'alice'), (UserManager.WRONG_PASS, None))
2017-07-13 20:02:03 +00:00
# Non-existent user
self.assertEqual(UserManager.try_auth(self.store, 'null', 'null'), (UserManager.NO_SUCH_USER, None))
def test_change_password(self):
# With existing users
for name in ['alice', 'bob', 'charlie']:
user = self.store.find(db.User, db.User.name == name).one()
2017-10-28 13:54:41 +00:00
# Good password
self.assertEqual(UserManager.change_password(self.store, user.id, name.upper(), 'newpass'), UserManager.SUCCESS)
2017-07-13 20:02:03 +00:00
self.assertEqual(UserManager.try_auth(self.store, name, 'newpass'), (UserManager.SUCCESS, user))
2017-10-28 13:54:41 +00:00
# Old password
self.assertEqual(UserManager.try_auth(self.store, name, name.upper()), (UserManager.WRONG_PASS, None))
2017-07-13 20:02:03 +00:00
# Wrong password
self.assertEqual(UserManager.change_password(self.store, user.id, 'badpass', 'newpass'), UserManager.WRONG_PASS)
2017-10-28 13:54:41 +00:00
# Ensure we still got the same number of users
self.assertEqual(self.store.find(db.User).count(), 3)
2017-07-13 20:02:03 +00:00
# With invalid UUID
self.assertEqual(UserManager.change_password(self.store, 'invalid-uuid', 'oldpass', 'newpass'), UserManager.INVALID_ID)
2017-10-28 13:54:41 +00:00
2017-07-13 20:02:03 +00:00
# Non-existent user
self.assertEqual(UserManager.change_password(self.store, uuid.uuid4(), 'oldpass', 'newpass'), UserManager.NO_SUCH_USER)
def test_change_password2(self):
# With existing users
for name in ['alice', 'bob', 'charlie']:
self.assertEqual(UserManager.change_password2(self.store, name, 'newpass'), UserManager.SUCCESS)
user = self.store.find(db.User, db.User.name == name).one()
self.assertEqual(UserManager.try_auth(self.store, name, 'newpass'), (UserManager.SUCCESS, user))
2017-10-28 13:54:41 +00:00
self.assertEqual(UserManager.try_auth(self.store, name, name.upper()), (UserManager.WRONG_PASS, None))
2017-07-13 20:02:03 +00:00
# Non-existent user
self.assertEqual(UserManager.change_password2(self.store, 'null', 'newpass'), UserManager.NO_SUCH_USER)
2017-10-28 13:54:41 +00:00
def test_human_readable_error(self):
values = [ UserManager.SUCCESS, UserManager.INVALID_ID, UserManager.NO_SUCH_USER, UserManager.NAME_EXISTS,
UserManager.WRONG_PASS, 1594826, 'string', uuid.uuid4() ]
for value in values:
self.assertIsInstance(UserManager.error_str(value), basestring)
2017-07-13 20:02:03 +00:00
if __name__ == '__main__':
unittest.main()
2017-10-28 13:54:41 +00:00