diff options
Diffstat (limited to 'tests/test_dnsviz_print_run.py')
-rw-r--r-- | tests/test_dnsviz_print_run.py | 130 |
1 files changed, 130 insertions, 0 deletions
diff --git a/tests/test_dnsviz_print_run.py b/tests/test_dnsviz_print_run.py new file mode 100644 index 0000000..8849403 --- /dev/null +++ b/tests/test_dnsviz_print_run.py @@ -0,0 +1,130 @@ +import gzip +import io +import os +import subprocess +import tempfile +import unittest + +DATA_DIR = os.path.dirname(__file__) +EXAMPLE_AUTHORITATIVE = os.path.join(DATA_DIR, 'data', 'example-authoritative.json.gz') +EXAMPLE_RECURSIVE = os.path.join(DATA_DIR, 'data', 'example-recursive.json.gz') +ROOT_AUTHORITATIVE = os.path.join(DATA_DIR, 'data', 'root-authoritative.json.gz') +ROOT_RECURSIVE = os.path.join(DATA_DIR, 'data', 'root-recursive.json.gz') + +class DNSPrintRunTestCase(unittest.TestCase): + def setUp(self): + self.devnull = io.open('/dev/null', 'wb') + self.current_cwd = os.getcwd() + self.dnsviz_bin = os.path.join(self.current_cwd, 'bin', 'dnsviz') + + tk = 'example.com. IN DNSKEY 256 3 7 AwEAAZ2YEuBl4X58v1CezDfZjT1viYn5kY3MF3lSDjvHjMZ6gJlYt4Qq oIdpChifmeJldEX9/wPc04Tg7MlEfV3m0x2j80dMyObM0FZTxzMgbTFk Zs0AWrDXELieGkFZv1FB9YoxSX2XqvpFxwvPyyszUtCy/c5hrb6vfKRB Jh+qIO+NsNrl6O8NiYjWWNjdiFw+c2BxzpArQoaA+rcoyDYwH4xGpvTw YLnE9HmkwTSQuwASkgWgX3KgTmsDEw4I0P5Tk+wvmNnaqDhmFMHJK5Oh 92wUX+ppxxSgUx4UIJmftzi7sCg0qekIYUf99Dkn7OlC8X0rjj+xO4cD hbTjGkxmsD0=' + + with tempfile.NamedTemporaryFile('wb', prefix='dnsviz', delete=False) as self.tk_file: + self.tk_file.write(tk.encode('utf-8')) + + with gzip.open(EXAMPLE_AUTHORITATIVE, 'rb') as example_auth_in: + with tempfile.NamedTemporaryFile('wb', prefix='dnsviz', delete=False) as self.example_auth_out: + self.example_auth_out.write(example_auth_in.read()) + + with gzip.open(EXAMPLE_RECURSIVE, 'rb') as example_rec_in: + with tempfile.NamedTemporaryFile('wb', prefix='dnsviz', delete=False) as self.example_rec_out: + self.example_rec_out.write(example_rec_in.read()) + + with tempfile.NamedTemporaryFile('wb', prefix='dnsviz', delete=False) as self.names_file: + self.names_file.write('example.com\nexample.net\n'.encode('utf-8')) + + self.output = tempfile.NamedTemporaryFile('wb', prefix='dnsviz', delete=False) + self.output.close() + + self.run_cwd = tempfile.mkdtemp(prefix='dnsviz') + + def tearDown(self): + self.devnull.close() + os.remove(self.tk_file.name) + os.remove(self.example_auth_out.name) + os.remove(self.example_rec_out.name) + os.remove(self.names_file.name) + os.remove(self.output.name) + subprocess.check_call(['rm', '-rf', self.run_cwd]) + + def test_dnsviz_print_input(self): + with io.open(self.output.name, 'wb') as fh_out: + with gzip.open(EXAMPLE_AUTHORITATIVE) as fh_in: + p = subprocess.Popen([self.dnsviz_bin, 'print'], stdin=subprocess.PIPE, stdout=fh_out) + p.communicate(fh_in.read()) + self.assertEqual(p.returncode, 0) + + with io.open(self.output.name, 'wb') as fh_out: + with gzip.open(EXAMPLE_AUTHORITATIVE) as fh_in: + p = subprocess.Popen([self.dnsviz_bin, 'print', '-r', '-'], stdin=subprocess.PIPE, stdout=fh_out) + p.communicate(fh_in.read()) + self.assertEqual(p.returncode, 0) + + with io.open(self.output.name, 'wb') as fh: + self.assertEqual(subprocess.call([self.dnsviz_bin, 'print', '-r', self.example_auth_out.name], stdout=fh), 0) + + def test_dnsviz_print_names_input(self): + with io.open(self.output.name, 'wb') as fh: + self.assertEqual(subprocess.call([self.dnsviz_bin, 'print', '-r', self.example_auth_out.name, '-f', self.names_file.name], stdout=fh), 0) + + with io.open(self.output.name, 'wb') as fh_out: + with io.open(self.names_file.name, 'rb') as fh_in: + p = subprocess.Popen([self.dnsviz_bin, 'print', '-r', self.example_auth_out.name, '-f', '-'], stdin=subprocess.PIPE, stdout=fh_out) + p.communicate(fh_in.read()) + self.assertEqual(p.returncode, 0) + + def test_dnsviz_print_tk_input(self): + with io.open(self.output.name, 'wb') as fh: + self.assertEqual(subprocess.call([self.dnsviz_bin, 'print', '-r', self.example_auth_out.name, '-t', self.tk_file.name], stdout=fh), 0) + + with io.open(self.output.name, 'wb') as fh_out: + with io.open(self.tk_file.name, 'rb') as fh_in: + p = subprocess.Popen([self.dnsviz_bin, 'print', '-r', self.example_auth_out.name, '-t', '-'], stdin=subprocess.PIPE, stdout=fh_out) + p.communicate(fh_in.read()) + self.assertEqual(p.returncode, 0) + + def test_dnsviz_print_output(self): + with io.open(self.output.name, 'wb') as fh: + self.assertEqual(subprocess.call([self.dnsviz_bin, 'print', '-r', self.example_auth_out.name], cwd=self.run_cwd, stdout=fh), 0) + + with io.open(self.output.name, 'wb') as fh: + self.assertEqual(subprocess.call([self.dnsviz_bin, 'print', '-r', self.example_auth_out.name, '-o', '-'], cwd=self.run_cwd, stdout=fh), 0) + + with io.open(self.output.name, 'wb') as fh: + self.assertEqual(subprocess.call([self.dnsviz_bin, 'print', '-r', self.example_auth_out.name, '-o', 'all.txt'], cwd=self.run_cwd, stdout=fh), 0) + self.assertTrue(os.path.exists(os.path.join(self.run_cwd, 'all.txt'))) + self.assertFalse(os.path.exists(os.path.join(self.run_cwd, 'example.com.txt'))) + self.assertFalse(os.path.exists(os.path.join(self.run_cwd, 'example.net.txt'))) + + self.assertEqual(subprocess.call([self.dnsviz_bin, 'print', '-r', self.example_auth_out.name, '-O'], cwd=self.run_cwd), 0) + self.assertTrue(os.path.exists(os.path.join(self.run_cwd, 'example.com.txt'))) + self.assertTrue(os.path.exists(os.path.join(self.run_cwd, 'example.net.txt'))) + + def test_dnsviz_print_input_auth(self): + with io.open(self.output.name, 'wb') as fh_out: + with gzip.open(EXAMPLE_AUTHORITATIVE) as fh_in: + p = subprocess.Popen([self.dnsviz_bin, 'print'], stdin=subprocess.PIPE, stdout=fh_out) + p.communicate(fh_in.read()) + self.assertEqual(p.returncode, 0) + + with io.open(self.output.name, 'wb') as fh_out: + with gzip.open(ROOT_AUTHORITATIVE) as fh_in: + p = subprocess.Popen([self.dnsviz_bin, 'print'], stdin=subprocess.PIPE, stdout=fh_out) + p.communicate(fh_in.read()) + self.assertEqual(p.returncode, 0) + + def test_dnsviz_print_input_rec(self): + with io.open(self.output.name, 'wb') as fh_out: + with gzip.open(EXAMPLE_RECURSIVE) as fh_in: + p = subprocess.Popen([self.dnsviz_bin, 'print'], stdin=subprocess.PIPE, stdout=fh_out) + p.communicate(fh_in.read()) + self.assertEqual(p.returncode, 0) + + with io.open(self.output.name, 'wb') as fh_out: + with gzip.open(ROOT_RECURSIVE) as fh_in: + p = subprocess.Popen([self.dnsviz_bin, 'print'], stdin=subprocess.PIPE, stdout=fh_out) + p.communicate(fh_in.read()) + self.assertEqual(p.returncode, 0) + +if __name__ == '__main__': + unittest.main() |