mirror of
https://github.com/kellyjonbrazil/jc.git
synced 2025-08-13 20:04:04 +02:00
.github
docs
jc
man
templates
tests
fixtures
__init__.py
_test_foo.py
_test_foo_s.py
test_acpi.py
test_airport.py
test_airport_s.py
test_arp.py
test_asciitable.py
test_asciitable_m.py
test_blkid.py
test_cksum.py
test_cli.py
test_crontab.py
test_crontab_u.py
test_csv.py
test_csv_s.py
test_date.py
test_df.py
test_dig.py
test_dir.py
test_dmidecode.py
test_dpkg_l.py
test_du.py
test_env.py
test_file.py
test_finger.py
test_free.py
test_fstab.py
test_group.py
test_gshadow.py
test_hash.py
test_hashsum.py
test_hciconfig.py
test_history.py
test_hosts.py
test_id.py
test_ifconfig.py
test_ini.py
test_iostat.py
test_iostat_s.py
test_iptables.py
test_iw_scan.py
test_jar_manifest.py
test_jc.py
test_jc_lib.py
test_jc_streaming.py
test_jc_utils.py
test_jobs.py
test_kv.py
test_last.py
test_ls.py
test_ls_s.py
test_lsblk.py
test_lsmod.py
test_lsof.py
test_lsusb.py
test_mount.py
test_mpstat.py
test_mpstat_s.py
test_netstat.py
test_nmcli.py
test_ntpq.py
test_passwd.py
test_pidstat.py
test_pidstat_s.py
test_ping.py
test_ping_s.py
test_pip_list.py
test_pip_show.py
test_ps.py
test_route.py
test_rpm_qai.py
test_rsync.py
test_rsync_s.py
test_sfdisk.py
test_shadow.py
test_ss.py
test_stat.py
test_stat_s.py
test_sysctl.py
test_systemctl.py
test_systemctl_lj.py
test_systemctl_ls.py
test_systemctl_luf.py
test_systeminfo.py
test_time.py
test_timedatectl.py
test_tracepath.py
test_traceroute.py
test_ufw.py
test_ufw_appinfo.py
test_uname.py
test_upower.py
test_uptime.py
test_vmstat.py
test_vmstat_s.py
test_w.py
test_wc.py
test_who.py
test_xml.py
test_xrandr.py
test_yaml.py
test_zipinfo.py
.gitignore
CHANGELOG
CONTRIBUTING.md
EXAMPLES.md
LICENSE.md
MANIFEST.in
README.md
_config.yml
build-package.sh
docgen.sh
install.sh
mangen.py
pypi-upload.sh
readmegen.py
requirements.txt
runtests.sh
setup.cfg
setup.py
updatedocs.sh
159 lines
7.3 KiB
Python
159 lines
7.3 KiB
Python
import os
|
|
import json
|
|
import unittest
|
|
import jc.parsers.csv_s
|
|
from jc.exceptions import ParseError
|
|
|
|
THIS_DIR = os.path.dirname(os.path.abspath(__file__))
|
|
|
|
|
|
# To create streaming output use:
|
|
# $ cat file.csv | jc --csv-s | jello -c > csv-file-streaming.json
|
|
|
|
|
|
class MyTests(unittest.TestCase):
|
|
|
|
def setUp(self):
|
|
# input
|
|
with open(os.path.join(THIS_DIR, os.pardir, 'tests/fixtures/generic/csv-biostats.csv'), 'r', encoding='utf-8') as f:
|
|
self.generic_csv_biostats = f.read()
|
|
|
|
with open(os.path.join(THIS_DIR, os.pardir, 'tests/fixtures/generic/csv-cities.csv'), 'r', encoding='utf-8') as f:
|
|
self.generic_csv_cities = f.read()
|
|
|
|
with open(os.path.join(THIS_DIR, os.pardir, 'tests/fixtures/generic/csv-deniro.csv'), 'r', encoding='utf-8') as f:
|
|
self.generic_csv_deniro = f.read()
|
|
|
|
with open(os.path.join(THIS_DIR, os.pardir, 'tests/fixtures/generic/csv-example.csv'), 'r', encoding='utf-8') as f:
|
|
self.generic_csv_example = f.read()
|
|
|
|
with open(os.path.join(THIS_DIR, os.pardir, 'tests/fixtures/generic/csv-flyrna.tsv'), 'r', encoding='utf-8') as f:
|
|
self.generic_csv_flyrna = f.read()
|
|
|
|
with open(os.path.join(THIS_DIR, os.pardir, 'tests/fixtures/generic/csv-flyrna2.tsv'), 'r', encoding='utf-8') as f:
|
|
self.generic_csv_flyrna2 = f.read()
|
|
|
|
with open(os.path.join(THIS_DIR, os.pardir, 'tests/fixtures/generic/csv-homes-pipe.csv'), 'r', encoding='utf-8') as f:
|
|
self.generic_csv_homes_pipe = f.read()
|
|
|
|
with open(os.path.join(THIS_DIR, os.pardir, 'tests/fixtures/generic/csv-homes.csv'), 'r', encoding='utf-8') as f:
|
|
self.generic_csv_homes = f.read()
|
|
|
|
with open(os.path.join(THIS_DIR, os.pardir, 'tests/fixtures/generic/csv-10k-sales-records.csv'), 'r', encoding='utf-8') as f:
|
|
self.generic_csv_10k_sales_records = f.read()
|
|
|
|
with open(os.path.join(THIS_DIR, os.pardir, 'tests/fixtures/generic/csv-doubleqouted.csv'), 'r', encoding='utf-8') as f:
|
|
self.generic_csv_doubleqouted = f.read()
|
|
|
|
# output
|
|
with open(os.path.join(THIS_DIR, os.pardir, 'tests/fixtures/generic/csv-biostats-streaming.json'), 'r', encoding='utf-8') as f:
|
|
self.generic_csv_biostats_streaming_json = json.loads(f.read())
|
|
|
|
with open(os.path.join(THIS_DIR, os.pardir, 'tests/fixtures/generic/csv-cities-streaming.json'), 'r', encoding='utf-8') as f:
|
|
self.generic_csv_cities_streaming_json = json.loads(f.read())
|
|
|
|
with open(os.path.join(THIS_DIR, os.pardir, 'tests/fixtures/generic/csv-deniro-streaming.json'), 'r', encoding='utf-8') as f:
|
|
self.generic_csv_deniro_streaming_json = json.loads(f.read())
|
|
|
|
with open(os.path.join(THIS_DIR, os.pardir, 'tests/fixtures/generic/csv-example-streaming.json'), 'r', encoding='utf-8') as f:
|
|
self.generic_csv_example_streaming_json = json.loads(f.read())
|
|
|
|
with open(os.path.join(THIS_DIR, os.pardir, 'tests/fixtures/generic/csv-flyrna-streaming.json'), 'r', encoding='utf-8') as f:
|
|
self.generic_csv_flyrna_streaming_json = json.loads(f.read())
|
|
|
|
with open(os.path.join(THIS_DIR, os.pardir, 'tests/fixtures/generic/csv-flyrna2-streaming.json'), 'r', encoding='utf-8') as f:
|
|
self.generic_csv_flyrna2_streaming_json = json.loads(f.read())
|
|
|
|
with open(os.path.join(THIS_DIR, os.pardir, 'tests/fixtures/generic/csv-homes-pipe-streaming.json'), 'r', encoding='utf-8') as f:
|
|
self.generic_csv_homes_pipe_streaming_json = json.loads(f.read())
|
|
|
|
with open(os.path.join(THIS_DIR, os.pardir, 'tests/fixtures/generic/csv-homes-streaming.json'), 'r', encoding='utf-8') as f:
|
|
self.generic_csv_homes_streaming_json = json.loads(f.read())
|
|
|
|
with open(os.path.join(THIS_DIR, os.pardir, 'tests/fixtures/generic/csv-10k-sales-records-streaming.json'), 'r', encoding='utf-8') as f:
|
|
self.generic_csv_10k_sales_records_streaming_json = json.loads(f.read())
|
|
|
|
with open(os.path.join(THIS_DIR, os.pardir, 'tests/fixtures/generic/csv-doubleqouted-streaming.json'), 'r', encoding='utf-8') as f:
|
|
self.generic_csv_doublequoted_streaming_json = json.loads(f.read())
|
|
|
|
def test_csv_s_nodata(self):
|
|
"""
|
|
Test CSV parser with no data
|
|
"""
|
|
self.assertEqual(list(jc.parsers.csv_s.parse([], quiet=True)), [])
|
|
|
|
def test_csv_unparsable(self):
|
|
"""
|
|
Test CSV streaming parser with '\r' newlines. This will raise ParseError due to a Python bug
|
|
that does not correctly iterate on that line ending with sys.stdin. This is not a great test.
|
|
https://bugs.python.org/issue45617
|
|
"""
|
|
data = r'unparsable\rdata' # raw mode simulates unrecognized line separator - not great
|
|
g = jc.parsers.csv_s.parse(data.splitlines(), quiet=True)
|
|
with self.assertRaises(ParseError):
|
|
list(g)
|
|
|
|
def test_csv_s_biostats(self):
|
|
"""
|
|
Test 'biostats.csv' file
|
|
"""
|
|
self.assertEqual(list(jc.parsers.csv_s.parse(self.generic_csv_biostats.splitlines(), quiet=True)), self.generic_csv_biostats_streaming_json)
|
|
|
|
def test_csv_s_cities(self):
|
|
"""
|
|
Test 'cities.csv' file
|
|
"""
|
|
self.assertEqual(list(jc.parsers.csv_s.parse(self.generic_csv_cities.splitlines(), quiet=True)), self.generic_csv_cities_streaming_json)
|
|
|
|
def test_csv_s_deniro(self):
|
|
"""
|
|
Test 'deniro.csv' file
|
|
"""
|
|
self.assertEqual(list(jc.parsers.csv_s.parse(self.generic_csv_deniro.splitlines(), quiet=True)), self.generic_csv_deniro_streaming_json)
|
|
|
|
def test_csv_s_example(self):
|
|
"""
|
|
Test 'example.csv' file
|
|
"""
|
|
self.assertEqual(list(jc.parsers.csv_s.parse(self.generic_csv_example.splitlines(), quiet=True)), self.generic_csv_example_streaming_json)
|
|
|
|
def test_csv_s_flyrna(self):
|
|
"""
|
|
Test 'flyrna.tsv' file
|
|
"""
|
|
self.assertEqual(list(jc.parsers.csv_s.parse(self.generic_csv_flyrna.splitlines(), quiet=True)), self.generic_csv_flyrna_streaming_json)
|
|
|
|
def test_csv_s_flyrna2(self):
|
|
"""
|
|
Test 'flyrna2.tsv' file
|
|
"""
|
|
self.assertEqual(list(jc.parsers.csv_s.parse(self.generic_csv_flyrna2.splitlines(), quiet=True)), self.generic_csv_flyrna2_streaming_json)
|
|
|
|
def test_csv_s_homes_pipe(self):
|
|
"""
|
|
Test 'homes-pipe.csv' file
|
|
"""
|
|
self.assertEqual(list(jc.parsers.csv_s.parse(self.generic_csv_homes_pipe.splitlines(), quiet=True)), self.generic_csv_homes_pipe_streaming_json)
|
|
|
|
def test_csv_s_homes(self):
|
|
"""
|
|
Test 'homes.csv' file
|
|
"""
|
|
self.assertEqual(list(jc.parsers.csv_s.parse(self.generic_csv_homes.splitlines(), quiet=True)), self.generic_csv_homes_streaming_json)
|
|
|
|
def test_csv_s_10k_records(self):
|
|
"""
|
|
Test '10k-sales-records.csv' file
|
|
"""
|
|
self.assertEqual(list(jc.parsers.csv_s.parse(self.generic_csv_10k_sales_records.splitlines(), quiet=True)), self.generic_csv_10k_sales_records_streaming_json)
|
|
|
|
def test_csv_s_doublequoted(self):
|
|
"""
|
|
Test 'doublequoted.csv' file
|
|
"""
|
|
self.assertEqual(list(jc.parsers.csv_s.parse(self.generic_csv_doubleqouted.splitlines(), quiet=True)), self.generic_csv_doublequoted_streaming_json)
|
|
|
|
|
|
if __name__ == '__main__':
|
|
unittest.main()
|