diff --git a/tests/fixtures/debian10/uname-a.json b/tests/fixtures/debian10/uname-a.json new file mode 100644 index 00000000..1936ac99 --- /dev/null +++ b/tests/fixtures/debian10/uname-a.json @@ -0,0 +1,10 @@ +{ + "kernel_name": "Linux", + "node_name": "debian", + "kernel_release": "5.7.0-2-amd64", + "operating_system": "GNU/Linux", + "processor": "unknown", + "hardware_platform": "unknown", + "machine": "x86_64", + "kernel_version": "#1 SMP Debian 5.7.10-1 (2020-07-26)" +} diff --git a/tests/fixtures/debian10/uname-a.out b/tests/fixtures/debian10/uname-a.out new file mode 100644 index 00000000..453f4a20 --- /dev/null +++ b/tests/fixtures/debian10/uname-a.out @@ -0,0 +1,2 @@ +Linux debian 5.7.0-2-amd64 #1 SMP Debian 5.7.10-1 (2020-07-26) x86_64 GNU/Linux + diff --git a/tests/fixtures/freebsd12/uname-a.json b/tests/fixtures/freebsd12/uname-a.json new file mode 100644 index 00000000..09b48961 --- /dev/null +++ b/tests/fixtures/freebsd12/uname-a.json @@ -0,0 +1 @@ +{"machine":"amd64","kernel_name":"FreeBSD","node_name":"freebsd","kernel_release":"12.1-RELEASE","kernel_version":"FreeBSD 12.1-RELEASE r354233 GENERIC"} diff --git a/tests/fixtures/freebsd12/uname-a.out b/tests/fixtures/freebsd12/uname-a.out new file mode 100644 index 00000000..e4585d6b --- /dev/null +++ b/tests/fixtures/freebsd12/uname-a.out @@ -0,0 +1,2 @@ +FreeBSD freebsd 12.1-RELEASE FreeBSD 12.1-RELEASE r354233 GENERIC amd64 + diff --git a/tests/fixtures/freebsd12/uname-a2.json b/tests/fixtures/freebsd12/uname-a2.json new file mode 100644 index 00000000..0e8fd908 --- /dev/null +++ b/tests/fixtures/freebsd12/uname-a2.json @@ -0,0 +1,7 @@ +{ + "machine": "amd64", + "kernel_name": "FreeBSD", + "node_name": "freebsd", + "kernel_release": "10.1-RELEASE-p10", + "kernel_version": "FreeBSD 10.1-RELEASE-p10 #0: Wed May 13 06:54:13 UTC 2015 root@amd64-builder.daemonology.net:/usr/obj/usr/src/sys/GENERIC" +} diff --git a/tests/fixtures/freebsd12/uname-a2.out b/tests/fixtures/freebsd12/uname-a2.out new file mode 100644 index 00000000..c5ff5e5f --- /dev/null +++ b/tests/fixtures/freebsd12/uname-a2.out @@ -0,0 +1,2 @@ +FreeBSD freebsd 10.1-RELEASE-p10 FreeBSD 10.1-RELEASE-p10 #0: Wed May 13 06:54:13 UTC 2015 root@amd64-builder.daemonology.net:/usr/obj/usr/src/sys/GENERIC amd64 + diff --git a/tests/fixtures/generic/uname-a-different-proc.json b/tests/fixtures/generic/uname-a-different-proc.json new file mode 100644 index 00000000..3bd00cd8 --- /dev/null +++ b/tests/fixtures/generic/uname-a-different-proc.json @@ -0,0 +1 @@ +{"kernel_name":"Linux","node_name":"mymachine","kernel_release":"2.6.18-194.e15PAE","operating_system":"GNU/Linux","processor":"i386","hardware_platform":"i686","machine":"i686","kernel_version":"#1 SMP Fri Apr 2 15:37:44 EDT 2010"} diff --git a/tests/fixtures/generic/uname-a-different-proc.out b/tests/fixtures/generic/uname-a-different-proc.out new file mode 100644 index 00000000..d127a8cf --- /dev/null +++ b/tests/fixtures/generic/uname-a-different-proc.out @@ -0,0 +1 @@ +Linux mymachine 2.6.18-194.e15PAE #1 SMP Fri Apr 2 15:37:44 EDT 2010 i686 i686 i386 GNU/Linux diff --git a/tests/fixtures/generic/uname-a.json b/tests/fixtures/generic/uname-a.json new file mode 100644 index 00000000..abce8608 --- /dev/null +++ b/tests/fixtures/generic/uname-a.json @@ -0,0 +1 @@ +{"kernel_name":"Linux","node_name":"host.example.com","kernel_release":"4.19.0-17-amd64","operating_system":"GNU/Linux","processor":"unknown","hardware_platform":"unknown","machine":"x86_64","kernel_version":"#1 SMP Debian 4.19.194-3 (2021-07-18)"} diff --git a/tests/fixtures/generic/uname-a.out b/tests/fixtures/generic/uname-a.out new file mode 100644 index 00000000..70272ba3 --- /dev/null +++ b/tests/fixtures/generic/uname-a.out @@ -0,0 +1,2 @@ +Linux host.example.com 4.19.0-17-amd64 #1 SMP Debian 4.19.194-3 (2021-07-18) x86_64 GNU/Linux + diff --git a/tests/test_uname.py b/tests/test_uname.py index 41bc22a1..d53cc471 100644 --- a/tests/test_uname.py +++ b/tests/test_uname.py @@ -25,6 +25,21 @@ class MyTests(unittest.TestCase): with open(os.path.join(THIS_DIR, os.pardir, 'tests/fixtures/osx-10.14.6/uname.out'), 'r', encoding='utf-8') as f: self.osx_10_14_6_uname = f.read() + with open(os.path.join(THIS_DIR, os.pardir, 'tests/fixtures/freebsd12/uname-a.out'), 'r', encoding='utf-8') as f: + self.freebsd12_uname_a = f.read() + + with open(os.path.join(THIS_DIR, os.pardir, 'tests/fixtures/freebsd12/uname-a2.out'), 'r', encoding='utf-8') as f: + self.freebsd12_uname_a2 = f.read() + + with open(os.path.join(THIS_DIR, os.pardir, 'tests/fixtures/generic/uname-a.out'), 'r', encoding='utf-8') as f: + self.generic_uname_a = f.read() + + with open(os.path.join(THIS_DIR, os.pardir, 'tests/fixtures/generic/uname-a-different-proc.out'), 'r', encoding='utf-8') as f: + self.generic_uname_a_different_proc = f.read() + + with open(os.path.join(THIS_DIR, os.pardir, 'tests/fixtures/debian10/uname-a.out'), 'r', encoding='utf-8') as f: + self.debian_10_uname_a = f.read() + # output with open(os.path.join(THIS_DIR, os.pardir, 'tests/fixtures/centos-7.7/uname-a.json'), 'r', encoding='utf-8') as f: self.centos_7_7_uname_a_json = json.loads(f.read()) @@ -38,6 +53,21 @@ class MyTests(unittest.TestCase): with open(os.path.join(THIS_DIR, os.pardir, 'tests/fixtures/osx-10.14.6/uname-a.json'), 'r', encoding='utf-8') as f: self.osx_10_14_6_uname_a_json = json.loads(f.read()) + with open(os.path.join(THIS_DIR, os.pardir, 'tests/fixtures/freebsd12/uname-a.json'), 'r', encoding='utf-8') as f: + self.freebsd12_uname_a_json = json.loads(f.read()) + + with open(os.path.join(THIS_DIR, os.pardir, 'tests/fixtures/freebsd12/uname-a2.json'), 'r', encoding='utf-8') as f: + self.freebsd12_uname_a2_json = json.loads(f.read()) + + with open(os.path.join(THIS_DIR, os.pardir, 'tests/fixtures/generic/uname-a.json'), 'r', encoding='utf-8') as f: + self.generic_uname_a_json = json.loads(f.read()) + + with open(os.path.join(THIS_DIR, os.pardir, 'tests/fixtures/generic/uname-a-different-proc.json'), 'r', encoding='utf-8') as f: + self.generic_uname_a_different_proc_json = json.loads(f.read()) + + with open(os.path.join(THIS_DIR, os.pardir, 'tests/fixtures/debian10/uname-a.json'), 'r', encoding='utf-8') as f: + self.debian_10_uname_a_json = json.loads(f.read()) + def test_uname_nodata(self): """ Test 'uname -a' with no data @@ -74,6 +104,36 @@ class MyTests(unittest.TestCase): """ self.assertEqual(jc.parsers.uname.parse(self.osx_10_14_6_uname_a, quiet=True), self.osx_10_14_6_uname_a_json) + def test_uname_freebsd12(self): + """ + Test 'uname -a' on freebsd12 + """ + self.assertEqual(jc.parsers.uname.parse(self.freebsd12_uname_a, quiet=True), self.freebsd12_uname_a_json) + + def test_uname2_freebsd12(self): + """ + Test 'uname -a' on freebsd12 with longer version level string + """ + self.assertEqual(jc.parsers.uname.parse(self.freebsd12_uname_a2, quiet=True), self.freebsd12_uname_a2_json) + + def test_uname_generic(self): + """ + Test 'uname -a' on debian with missing hardware platform and processor + """ + self.assertEqual(jc.parsers.uname.parse(self.generic_uname_a, quiet=True), self.generic_uname_a_json) + + def test_uname_different_proc_generic(self): + """ + Test 'uname -a' on machine with different processor type + """ + self.assertEqual(jc.parsers.uname.parse(self.generic_uname_a_different_proc, quiet=True), self.generic_uname_a_different_proc_json) + + def test_uname_debian_10(self): + """ + Test 'uname -a' on debian 10 with missing hardware platform and processor + """ + self.assertEqual(jc.parsers.uname.parse(self.debian_10_uname_a, quiet=True), self.debian_10_uname_a_json) + if __name__ == '__main__': unittest.main()