commit e935661834a27b421509fa82b6a17a4ccc571fa0 Author: Damian Johnson atagar@torproject.org Date: Sat Feb 7 17:07:15 2015 -0800
Test 'tor --dump-config' and 'tor --validate-config' --- test/integ/process.py | 32 ++++++++++++++++++++++++++++++++ 1 file changed, 32 insertions(+)
diff --git a/test/integ/process.py b/test/integ/process.py index e1a1432..65f4a7a 100644 --- a/test/integ/process.py +++ b/test/integ/process.py @@ -106,6 +106,34 @@ class TestProcess(unittest.TestCase): self.assertTrue("[warn] Command-line option '--hash-password' with no value. Failing." in output) self.assertTrue("[err] Reading config failed--see warnings above." in output)
+ def test_dump_config_argument(self): + """ + Exercises our 'tor --dump-config' arugments. + """ + + short_output = self.run_tor('--dump-config', 'short', with_torrc = True) + non_builtin_output = self.run_tor('--dump-config', 'non-builtin', with_torrc = True) + full_output = self.run_tor('--dump-config', 'full', with_torrc = True) + self.run_tor('--dump-config', 'invalid_option', with_torrc = True, expect_failure = True) + + torrc_contents = [line for line in test.runner.get_runner().get_torrc_contents().splitlines() if not line.startswith('#')] + + self.assertItemsEqual(torrc_contents, short_output.strip().splitlines()) + self.assertItemsEqual(torrc_contents, non_builtin_output.strip().splitlines()) + + for line in torrc_contents: + self.assertTrue(line in full_output) + + def test_validate_config_argument(self): + """ + Exercises our 'tor --validate-config' argument. + """ + + valid_output = self.run_tor('--hush', '--verify-config', with_torrc = True) + self.assertTrue('Configuration was valid\n' in valid_output) + + self.run_tor('--verify-config', '-f', __file__, expect_failure = True) + def test_launch_tor_with_config(self): """ Exercises launch_tor_with_config. @@ -274,10 +302,14 @@ class TestProcess(unittest.TestCase): # an arbitrary number of positional arguments, so explicitly checking
expect_failure = kwargs.pop('expect_failure', False) + with_torrc = kwargs.pop('with_torrc', False)
if kwargs: raise ValueError("Got unexpected keyword arguments: %s" % kwargs)
+ if with_torrc: + args = ['-f', test.runner.get_runner().get_torrc_path()] + list(args) + args = [test.runner.get_runner().get_tor_command()] + list(args) tor_process = subprocess.Popen(args, stdout = subprocess.PIPE)