2016-06-20 15:59:22 -04:00
|
|
|
from datetime import datetime, timedelta
|
2016-06-12 10:38:28 -04:00
|
|
|
from time import sleep
|
|
|
|
|
2016-05-18 16:08:09 -04:00
|
|
|
import pytest
|
2016-05-19 15:35:39 -04:00
|
|
|
|
|
|
|
from tsstats.exceptions import InvalidLog
|
2016-06-20 15:59:22 -04:00
|
|
|
from tsstats.log import TimedLog, _bundle_logs, _parse_details
|
2016-05-18 16:08:09 -04:00
|
|
|
|
2016-06-12 10:39:41 -04:00
|
|
|
testlog_path = 'tsstats/tests/res/test.log'
|
|
|
|
|
2016-05-18 16:08:09 -04:00
|
|
|
|
|
|
|
@pytest.fixture
|
|
|
|
def clients():
|
2016-06-20 15:59:22 -04:00
|
|
|
return _parse_details(testlog_path, online_dc=False)
|
2016-05-18 16:08:09 -04:00
|
|
|
|
|
|
|
|
|
|
|
def test_log_client_count(clients):
|
2016-05-19 09:41:19 -04:00
|
|
|
assert len(clients) == 3
|
2016-05-18 16:08:09 -04:00
|
|
|
|
|
|
|
|
|
|
|
def test_log_onlinetime(clients):
|
2016-06-12 11:55:52 -04:00
|
|
|
assert clients['1'].onlinetime == timedelta(0, 402, 149208)
|
|
|
|
assert clients['2'].onlinetime == timedelta(0, 19, 759644)
|
2016-05-18 16:08:09 -04:00
|
|
|
|
|
|
|
|
|
|
|
def test_log_kicks(clients):
|
|
|
|
assert clients['UIDClient1'].kicks == 1
|
|
|
|
|
|
|
|
|
|
|
|
def test_log_pkicks(clients):
|
|
|
|
assert clients['2'].pkicks == 1
|
|
|
|
|
|
|
|
|
|
|
|
def test_log_bans(clients):
|
|
|
|
assert clients['UIDClient1'].bans == 1
|
|
|
|
|
|
|
|
|
|
|
|
def test_log_pbans(clients):
|
|
|
|
assert clients['2'].pbans == 1
|
2016-05-19 15:35:39 -04:00
|
|
|
|
|
|
|
|
2016-06-20 15:59:22 -04:00
|
|
|
@pytest.mark.parametrize("logs,bundled", [
|
|
|
|
(
|
|
|
|
['l1.log', 'l2.log'],
|
|
|
|
{'': [TimedLog('l1.log', None), TimedLog('l2.log', None)]}
|
|
|
|
),
|
|
|
|
(
|
|
|
|
[
|
|
|
|
'ts3server_2016-06-06__14_22_09.527229_1.log',
|
|
|
|
'ts3server_2017-07-07__15_23_10.638340_1.log'
|
|
|
|
],
|
|
|
|
{
|
|
|
|
'1': [
|
|
|
|
TimedLog('ts3server_2016-06-06__14_22_09.527229_1.log',
|
|
|
|
datetime(year=2016, month=6, day=6, hour=14,
|
|
|
|
minute=22, second=9, microsecond=527229)),
|
|
|
|
TimedLog('ts3server_2017-07-07__15_23_10.638340_1.log',
|
|
|
|
datetime(year=2017, month=7, day=7, hour=15,
|
|
|
|
minute=23, second=10, microsecond=638340))
|
|
|
|
]
|
|
|
|
}
|
|
|
|
)
|
|
|
|
])
|
|
|
|
def test_log_bundle(logs, bundled):
|
|
|
|
assert _bundle_logs(logs) == bundled
|
|
|
|
|
|
|
|
|
2016-05-19 15:35:39 -04:00
|
|
|
def test_log_invalid():
|
|
|
|
with pytest.raises(InvalidLog):
|
2016-05-23 15:50:10 -04:00
|
|
|
parse_log('tsstats/tests/res/test.log.broken')
|
2016-05-24 16:38:52 -04:00
|
|
|
|
|
|
|
|
|
|
|
def test_log_multiple():
|
2016-06-12 10:58:17 -04:00
|
|
|
assert len(parse_log(testlog_path, online_dc=False)) == \
|
|
|
|
len(parse_logs(testlog_path, online_dc=False))
|
2016-06-12 10:38:28 -04:00
|
|
|
|
|
|
|
|
|
|
|
@pytest.mark.slowtest
|
|
|
|
def test_log_client_online():
|
2016-06-12 10:39:41 -04:00
|
|
|
clients = parse_log(testlog_path)
|
2016-06-12 11:55:52 -04:00
|
|
|
old_onlinetime = int(clients['1'].onlinetime.total_seconds())
|
2016-06-12 10:38:28 -04:00
|
|
|
sleep(2)
|
2016-06-12 10:39:41 -04:00
|
|
|
clients = parse_log(testlog_path)
|
2016-06-12 11:55:52 -04:00
|
|
|
assert int(clients['1'].onlinetime.total_seconds()) == old_onlinetime + 2
|