debian-koji/tests/test_hub/test_get_session_info.py
Yuming Zhu ca05418fb5 unittest: use unittest.mock instead of mock
because the absence of unittest.mock on python2.7, we still fallback to
mock
2024-10-23 16:35:30 +00:00

114 lines
6.4 KiB
Python

import koji
import kojihub
from unittest import mock
from .utils import DBQueryTestCase
class TestGetSessionInfo(DBQueryTestCase):
def setUp(self):
super(TestGetSessionInfo, self).setUp()
self.context = mock.patch('kojihub.kojihub.context').start()
self.exports = kojihub.RootExports()
self.context.session.hasPerm = mock.MagicMock()
self.get_user = mock.patch('kojihub.kojihub.get_user').start()
self.userinfo = {'id': 123, 'name': 'testuser'}
self.exports.getLoggedInUser = mock.MagicMock()
def tearDown(self):
mock.patch.stopall()
def test_get_session_info_not_logged(self):
self.context.session.logged_in = False
result = self.exports.getSessionInfo()
self.assertIsNone(result)
def test_get_session_info_user_not_admin_and_not_logged_user(self):
self.context.session.logged_in = True
self.context.session.hasPerm.return_value = False
self.get_user.return_value = self.userinfo
self.exports.getLoggedInUser.return_value = {'id': 159, 'name': 'testuser2'}
with self.assertRaises(koji.ActionNotAllowed) as ex:
self.exports.getSessionInfo(user_id='testuser')
self.assertEqual("only admins or owners may see all active sessions", str(ex.exception))
self.assertEqual(len(self.queries), 0)
def test_get_session_info_user_logged_user(self):
self.context.session.logged_in = True
self.context.session.hasPerm.return_value = False
self.get_user.return_value = self.userinfo
self.exports.getLoggedInUser.return_value = {'id': 123, 'name': 'testuser'}
self.exports.getSessionInfo(user_id='testuser')
self.assertEqual(len(self.queries), 1)
query = self.queries[0]
self.assertEqual(query.tables, ['sessions'])
self.assertEqual(query.clauses, ['expired is FALSE', 'user_id = %(user_id)i'])
self.assertEqual(query.joins, None)
self.assertEqual(query.columns, ['authtype', 'callnum', 'exclusive', 'expired', 'master',
'renew_time', "date_part('epoch', renew_time)",
'start_time', "date_part('epoch', start_time)",
'update_time', "date_part('epoch', update_time)",
'user_id'])
self.assertEqual(query.aliases, ['authtype', 'callnum', 'exclusive', 'expired', 'master',
'renew_time', 'renew_ts',
'start_time', 'start_ts', 'update_time', 'update_ts',
'user_id'])
def test_get_session_info_user_and_details(self):
self.context.session.logged_in = True
self.context.session.hasPerm.return_value = True
self.exports.getSessionInfo(details=True, user_id='testuser')
self.assertEqual(len(self.queries), 1)
query = self.queries[0]
self.assertEqual(query.tables, ['sessions'])
self.assertEqual(query.clauses, ['expired is FALSE', 'user_id = %(user_id)i'])
self.assertEqual(query.joins, None)
self.assertEqual(query.columns, ['authtype', 'callnum', 'exclusive', 'expired', 'hostip',
'id', 'master',
'renew_time', "date_part('epoch', renew_time)",
'start_time', "date_part('epoch', start_time)",
'update_time', "date_part('epoch', update_time)",
'user_id'])
self.assertEqual(query.aliases, ['authtype', 'callnum', 'exclusive', 'expired', 'hostip',
'id', 'master', 'renew_time', 'renew_ts',
'start_time', 'start_ts', 'update_time',
'update_ts', 'user_id'])
def test_get_session_info_user(self):
self.context.session.logged_in = True
self.context.session.hasPerm.return_value = True
self.exports.getSessionInfo(user_id='testuser')
self.assertEqual(len(self.queries), 1)
query = self.queries[0]
self.assertEqual(query.tables, ['sessions'])
self.assertEqual(query.clauses, ['expired is FALSE', 'user_id = %(user_id)i'])
self.assertEqual(query.joins, None)
self.assertEqual(query.columns, ['authtype', 'callnum', 'exclusive', 'expired', 'master',
'renew_time', "date_part('epoch', renew_time)",
'start_time', "date_part('epoch', start_time)",
'update_time', "date_part('epoch', update_time)",
'user_id'])
self.assertEqual(query.aliases, ['authtype', 'callnum', 'exclusive', 'expired', 'master',
'renew_time', 'renew_ts',
'start_time', 'start_ts', 'update_time', 'update_ts',
'user_id'])
def test_get_session_info_details(self):
self.context.session.logged_in = True
self.context.session.hasPerm.return_value = True
self.qp_execute_one_return_value = {'hostip': '10.0.0.0', 'id': 123}
self.exports.getSessionInfo(details=True)
self.assertEqual(len(self.queries), 1)
query = self.queries[0]
self.assertEqual(query.tables, ['sessions'])
self.assertEqual(query.clauses, ['expired is FALSE', 'id = %(id)i'])
self.assertEqual(query.joins, None)
self.assertEqual(query.columns, ['authtype', 'callnum', 'exclusive', 'expired', 'hostip',
'id', 'master',
'renew_time', "date_part('epoch', renew_time)",
'start_time', "date_part('epoch', start_time)",
'update_time', "date_part('epoch', update_time)",
'user_id'])
self.assertEqual(query.aliases, ['authtype', 'callnum', 'exclusive', 'expired', 'hostip',
'id', 'master', 'renew_time', 'renew_ts',
'start_time', 'start_ts', 'update_time',
'update_ts', 'user_id'])