1
0
mirror of https://github.com/kellyjonbrazil/jc.git synced 2025-06-17 00:07:37 +02:00
Files
jc/tests/test_clf_s.py
2022-11-22 13:10:15 -08:00

51 lines
1.3 KiB
Python

import os
import json
import unittest
from typing import Dict
from jc.parsers.clf_s import parse
THIS_DIR = os.path.dirname(os.path.abspath(__file__))
# To create streaming output use:
# $ cat clf.out | jc --clf-s | jello -c > clf-streaming.json
class MyTests(unittest.TestCase):
f_in: Dict = {}
f_json: Dict = {}
@classmethod
def setUpClass(cls):
fixtures = {
'clf_s': (
'fixtures/generic/common-log-format.log',
'fixtures/generic/common-log-format-streaming.json')
}
for file, filepaths in fixtures.items():
with open(os.path.join(THIS_DIR, filepaths[0]), 'r', encoding='utf-8') as a, \
open(os.path.join(THIS_DIR, filepaths[1]), 'r', encoding='utf-8') as b:
cls.f_in[file] = a.read()
cls.f_json[file] = json.loads(b.read())
def test_clf_s_nodata(self):
"""
Test 'clf-s' with no data
"""
self.assertEqual(list(parse([], quiet=True)), [])
def test_clf_s_centos_7_7(self):
"""
Test 'clf-s' with various logs
"""
self.assertEqual(
list(parse(self.f_in['clf_s'].splitlines(), quiet=True)),
self.f_json['clf_s']
)
if __name__ == '__main__':
unittest.main()