17db96d56Sopenharmony_ci# 27db96d56Sopenharmony_ci# Test suite for Optik. Supplied by Johannes Gijsbers 37db96d56Sopenharmony_ci# (taradino@softhome.net) -- translated from the original Optik 47db96d56Sopenharmony_ci# test suite to this PyUnit-based version. 57db96d56Sopenharmony_ci# 67db96d56Sopenharmony_ci# $Id$ 77db96d56Sopenharmony_ci# 87db96d56Sopenharmony_ci 97db96d56Sopenharmony_ciimport sys 107db96d56Sopenharmony_ciimport os 117db96d56Sopenharmony_ciimport re 127db96d56Sopenharmony_ciimport copy 137db96d56Sopenharmony_ciimport unittest 147db96d56Sopenharmony_ci 157db96d56Sopenharmony_cifrom io import StringIO 167db96d56Sopenharmony_cifrom test import support 177db96d56Sopenharmony_cifrom test.support import os_helper 187db96d56Sopenharmony_ci 197db96d56Sopenharmony_ci 207db96d56Sopenharmony_ciimport optparse 217db96d56Sopenharmony_cifrom optparse import make_option, Option, \ 227db96d56Sopenharmony_ci TitledHelpFormatter, OptionParser, OptionGroup, \ 237db96d56Sopenharmony_ci SUPPRESS_USAGE, OptionError, OptionConflictError, \ 247db96d56Sopenharmony_ci BadOptionError, OptionValueError, Values 257db96d56Sopenharmony_cifrom optparse import _match_abbrev 267db96d56Sopenharmony_cifrom optparse import _parse_num 277db96d56Sopenharmony_ci 287db96d56Sopenharmony_ciclass InterceptedError(Exception): 297db96d56Sopenharmony_ci def __init__(self, 307db96d56Sopenharmony_ci error_message=None, 317db96d56Sopenharmony_ci exit_status=None, 327db96d56Sopenharmony_ci exit_message=None): 337db96d56Sopenharmony_ci self.error_message = error_message 347db96d56Sopenharmony_ci self.exit_status = exit_status 357db96d56Sopenharmony_ci self.exit_message = exit_message 367db96d56Sopenharmony_ci 377db96d56Sopenharmony_ci def __str__(self): 387db96d56Sopenharmony_ci return self.error_message or self.exit_message or "intercepted error" 397db96d56Sopenharmony_ci 407db96d56Sopenharmony_ciclass InterceptingOptionParser(OptionParser): 417db96d56Sopenharmony_ci def exit(self, status=0, msg=None): 427db96d56Sopenharmony_ci raise InterceptedError(exit_status=status, exit_message=msg) 437db96d56Sopenharmony_ci 447db96d56Sopenharmony_ci def error(self, msg): 457db96d56Sopenharmony_ci raise InterceptedError(error_message=msg) 467db96d56Sopenharmony_ci 477db96d56Sopenharmony_ci 487db96d56Sopenharmony_ciclass BaseTest(unittest.TestCase): 497db96d56Sopenharmony_ci def assertParseOK(self, args, expected_opts, expected_positional_args): 507db96d56Sopenharmony_ci """Assert the options are what we expected when parsing arguments. 517db96d56Sopenharmony_ci 527db96d56Sopenharmony_ci Otherwise, fail with a nicely formatted message. 537db96d56Sopenharmony_ci 547db96d56Sopenharmony_ci Keyword arguments: 557db96d56Sopenharmony_ci args -- A list of arguments to parse with OptionParser. 567db96d56Sopenharmony_ci expected_opts -- The options expected. 577db96d56Sopenharmony_ci expected_positional_args -- The positional arguments expected. 587db96d56Sopenharmony_ci 597db96d56Sopenharmony_ci Returns the options and positional args for further testing. 607db96d56Sopenharmony_ci """ 617db96d56Sopenharmony_ci 627db96d56Sopenharmony_ci (options, positional_args) = self.parser.parse_args(args) 637db96d56Sopenharmony_ci optdict = vars(options) 647db96d56Sopenharmony_ci 657db96d56Sopenharmony_ci self.assertEqual(optdict, expected_opts, 667db96d56Sopenharmony_ci """ 677db96d56Sopenharmony_ciOptions are %(optdict)s. 687db96d56Sopenharmony_ciShould be %(expected_opts)s. 697db96d56Sopenharmony_ciArgs were %(args)s.""" % locals()) 707db96d56Sopenharmony_ci 717db96d56Sopenharmony_ci self.assertEqual(positional_args, expected_positional_args, 727db96d56Sopenharmony_ci """ 737db96d56Sopenharmony_ciPositional arguments are %(positional_args)s. 747db96d56Sopenharmony_ciShould be %(expected_positional_args)s. 757db96d56Sopenharmony_ciArgs were %(args)s.""" % locals ()) 767db96d56Sopenharmony_ci 777db96d56Sopenharmony_ci return (options, positional_args) 787db96d56Sopenharmony_ci 797db96d56Sopenharmony_ci def assertRaises(self, 807db96d56Sopenharmony_ci func, 817db96d56Sopenharmony_ci args, 827db96d56Sopenharmony_ci kwargs, 837db96d56Sopenharmony_ci expected_exception, 847db96d56Sopenharmony_ci expected_message): 857db96d56Sopenharmony_ci """ 867db96d56Sopenharmony_ci Assert that the expected exception is raised when calling a 877db96d56Sopenharmony_ci function, and that the right error message is included with 887db96d56Sopenharmony_ci that exception. 897db96d56Sopenharmony_ci 907db96d56Sopenharmony_ci Arguments: 917db96d56Sopenharmony_ci func -- the function to call 927db96d56Sopenharmony_ci args -- positional arguments to `func` 937db96d56Sopenharmony_ci kwargs -- keyword arguments to `func` 947db96d56Sopenharmony_ci expected_exception -- exception that should be raised 957db96d56Sopenharmony_ci expected_message -- expected exception message (or pattern 967db96d56Sopenharmony_ci if a compiled regex object) 977db96d56Sopenharmony_ci 987db96d56Sopenharmony_ci Returns the exception raised for further testing. 997db96d56Sopenharmony_ci """ 1007db96d56Sopenharmony_ci if args is None: 1017db96d56Sopenharmony_ci args = () 1027db96d56Sopenharmony_ci if kwargs is None: 1037db96d56Sopenharmony_ci kwargs = {} 1047db96d56Sopenharmony_ci 1057db96d56Sopenharmony_ci try: 1067db96d56Sopenharmony_ci func(*args, **kwargs) 1077db96d56Sopenharmony_ci except expected_exception as err: 1087db96d56Sopenharmony_ci actual_message = str(err) 1097db96d56Sopenharmony_ci if isinstance(expected_message, re.Pattern): 1107db96d56Sopenharmony_ci self.assertTrue(expected_message.search(actual_message), 1117db96d56Sopenharmony_ci """\ 1127db96d56Sopenharmony_ciexpected exception message pattern: 1137db96d56Sopenharmony_ci/%s/ 1147db96d56Sopenharmony_ciactual exception message: 1157db96d56Sopenharmony_ci'''%s''' 1167db96d56Sopenharmony_ci""" % (expected_message.pattern, actual_message)) 1177db96d56Sopenharmony_ci else: 1187db96d56Sopenharmony_ci self.assertEqual(actual_message, 1197db96d56Sopenharmony_ci expected_message, 1207db96d56Sopenharmony_ci """\ 1217db96d56Sopenharmony_ciexpected exception message: 1227db96d56Sopenharmony_ci'''%s''' 1237db96d56Sopenharmony_ciactual exception message: 1247db96d56Sopenharmony_ci'''%s''' 1257db96d56Sopenharmony_ci""" % (expected_message, actual_message)) 1267db96d56Sopenharmony_ci 1277db96d56Sopenharmony_ci return err 1287db96d56Sopenharmony_ci else: 1297db96d56Sopenharmony_ci self.fail("""expected exception %(expected_exception)s not raised 1307db96d56Sopenharmony_cicalled %(func)r 1317db96d56Sopenharmony_ciwith args %(args)r 1327db96d56Sopenharmony_ciand kwargs %(kwargs)r 1337db96d56Sopenharmony_ci""" % locals ()) 1347db96d56Sopenharmony_ci 1357db96d56Sopenharmony_ci 1367db96d56Sopenharmony_ci # -- Assertions used in more than one class -------------------- 1377db96d56Sopenharmony_ci 1387db96d56Sopenharmony_ci def assertParseFail(self, cmdline_args, expected_output): 1397db96d56Sopenharmony_ci """ 1407db96d56Sopenharmony_ci Assert the parser fails with the expected message. Caller 1417db96d56Sopenharmony_ci must ensure that self.parser is an InterceptingOptionParser. 1427db96d56Sopenharmony_ci """ 1437db96d56Sopenharmony_ci try: 1447db96d56Sopenharmony_ci self.parser.parse_args(cmdline_args) 1457db96d56Sopenharmony_ci except InterceptedError as err: 1467db96d56Sopenharmony_ci self.assertEqual(err.error_message, expected_output) 1477db96d56Sopenharmony_ci else: 1487db96d56Sopenharmony_ci self.assertFalse("expected parse failure") 1497db96d56Sopenharmony_ci 1507db96d56Sopenharmony_ci def assertOutput(self, 1517db96d56Sopenharmony_ci cmdline_args, 1527db96d56Sopenharmony_ci expected_output, 1537db96d56Sopenharmony_ci expected_status=0, 1547db96d56Sopenharmony_ci expected_error=None): 1557db96d56Sopenharmony_ci """Assert the parser prints the expected output on stdout.""" 1567db96d56Sopenharmony_ci save_stdout = sys.stdout 1577db96d56Sopenharmony_ci try: 1587db96d56Sopenharmony_ci try: 1597db96d56Sopenharmony_ci sys.stdout = StringIO() 1607db96d56Sopenharmony_ci self.parser.parse_args(cmdline_args) 1617db96d56Sopenharmony_ci finally: 1627db96d56Sopenharmony_ci output = sys.stdout.getvalue() 1637db96d56Sopenharmony_ci sys.stdout = save_stdout 1647db96d56Sopenharmony_ci 1657db96d56Sopenharmony_ci except InterceptedError as err: 1667db96d56Sopenharmony_ci self.assertTrue( 1677db96d56Sopenharmony_ci isinstance(output, str), 1687db96d56Sopenharmony_ci "expected output to be an ordinary string, not %r" 1697db96d56Sopenharmony_ci % type(output)) 1707db96d56Sopenharmony_ci 1717db96d56Sopenharmony_ci if output != expected_output: 1727db96d56Sopenharmony_ci self.fail("expected: \n'''\n" + expected_output + 1737db96d56Sopenharmony_ci "'''\nbut got \n'''\n" + output + "'''") 1747db96d56Sopenharmony_ci self.assertEqual(err.exit_status, expected_status) 1757db96d56Sopenharmony_ci self.assertEqual(err.exit_message, expected_error) 1767db96d56Sopenharmony_ci else: 1777db96d56Sopenharmony_ci self.assertFalse("expected parser.exit()") 1787db96d56Sopenharmony_ci 1797db96d56Sopenharmony_ci def assertTypeError(self, func, expected_message, *args): 1807db96d56Sopenharmony_ci """Assert that TypeError is raised when executing func.""" 1817db96d56Sopenharmony_ci self.assertRaises(func, args, None, TypeError, expected_message) 1827db96d56Sopenharmony_ci 1837db96d56Sopenharmony_ci def assertHelp(self, parser, expected_help): 1847db96d56Sopenharmony_ci actual_help = parser.format_help() 1857db96d56Sopenharmony_ci if actual_help != expected_help: 1867db96d56Sopenharmony_ci raise self.failureException( 1877db96d56Sopenharmony_ci 'help text failure; expected:\n"' + 1887db96d56Sopenharmony_ci expected_help + '"; got:\n"' + 1897db96d56Sopenharmony_ci actual_help + '"\n') 1907db96d56Sopenharmony_ci 1917db96d56Sopenharmony_ci# -- Test make_option() aka Option ------------------------------------- 1927db96d56Sopenharmony_ci 1937db96d56Sopenharmony_ci# It's not necessary to test correct options here. All the tests in the 1947db96d56Sopenharmony_ci# parser.parse_args() section deal with those, because they're needed 1957db96d56Sopenharmony_ci# there. 1967db96d56Sopenharmony_ci 1977db96d56Sopenharmony_ciclass TestOptionChecks(BaseTest): 1987db96d56Sopenharmony_ci def setUp(self): 1997db96d56Sopenharmony_ci self.parser = OptionParser(usage=SUPPRESS_USAGE) 2007db96d56Sopenharmony_ci 2017db96d56Sopenharmony_ci def assertOptionError(self, expected_message, args=[], kwargs={}): 2027db96d56Sopenharmony_ci self.assertRaises(make_option, args, kwargs, 2037db96d56Sopenharmony_ci OptionError, expected_message) 2047db96d56Sopenharmony_ci 2057db96d56Sopenharmony_ci def test_opt_string_empty(self): 2067db96d56Sopenharmony_ci self.assertTypeError(make_option, 2077db96d56Sopenharmony_ci "at least one option string must be supplied") 2087db96d56Sopenharmony_ci 2097db96d56Sopenharmony_ci def test_opt_string_too_short(self): 2107db96d56Sopenharmony_ci self.assertOptionError( 2117db96d56Sopenharmony_ci "invalid option string 'b': must be at least two characters long", 2127db96d56Sopenharmony_ci ["b"]) 2137db96d56Sopenharmony_ci 2147db96d56Sopenharmony_ci def test_opt_string_short_invalid(self): 2157db96d56Sopenharmony_ci self.assertOptionError( 2167db96d56Sopenharmony_ci "invalid short option string '--': must be " 2177db96d56Sopenharmony_ci "of the form -x, (x any non-dash char)", 2187db96d56Sopenharmony_ci ["--"]) 2197db96d56Sopenharmony_ci 2207db96d56Sopenharmony_ci def test_opt_string_long_invalid(self): 2217db96d56Sopenharmony_ci self.assertOptionError( 2227db96d56Sopenharmony_ci "invalid long option string '---': " 2237db96d56Sopenharmony_ci "must start with --, followed by non-dash", 2247db96d56Sopenharmony_ci ["---"]) 2257db96d56Sopenharmony_ci 2267db96d56Sopenharmony_ci def test_attr_invalid(self): 2277db96d56Sopenharmony_ci self.assertOptionError( 2287db96d56Sopenharmony_ci "option -b: invalid keyword arguments: bar, foo", 2297db96d56Sopenharmony_ci ["-b"], {'foo': None, 'bar': None}) 2307db96d56Sopenharmony_ci 2317db96d56Sopenharmony_ci def test_action_invalid(self): 2327db96d56Sopenharmony_ci self.assertOptionError( 2337db96d56Sopenharmony_ci "option -b: invalid action: 'foo'", 2347db96d56Sopenharmony_ci ["-b"], {'action': 'foo'}) 2357db96d56Sopenharmony_ci 2367db96d56Sopenharmony_ci def test_type_invalid(self): 2377db96d56Sopenharmony_ci self.assertOptionError( 2387db96d56Sopenharmony_ci "option -b: invalid option type: 'foo'", 2397db96d56Sopenharmony_ci ["-b"], {'type': 'foo'}) 2407db96d56Sopenharmony_ci self.assertOptionError( 2417db96d56Sopenharmony_ci "option -b: invalid option type: 'tuple'", 2427db96d56Sopenharmony_ci ["-b"], {'type': tuple}) 2437db96d56Sopenharmony_ci 2447db96d56Sopenharmony_ci def test_no_type_for_action(self): 2457db96d56Sopenharmony_ci self.assertOptionError( 2467db96d56Sopenharmony_ci "option -b: must not supply a type for action 'count'", 2477db96d56Sopenharmony_ci ["-b"], {'action': 'count', 'type': 'int'}) 2487db96d56Sopenharmony_ci 2497db96d56Sopenharmony_ci def test_no_choices_list(self): 2507db96d56Sopenharmony_ci self.assertOptionError( 2517db96d56Sopenharmony_ci "option -b/--bad: must supply a list of " 2527db96d56Sopenharmony_ci "choices for type 'choice'", 2537db96d56Sopenharmony_ci ["-b", "--bad"], {'type': "choice"}) 2547db96d56Sopenharmony_ci 2557db96d56Sopenharmony_ci def test_bad_choices_list(self): 2567db96d56Sopenharmony_ci typename = type('').__name__ 2577db96d56Sopenharmony_ci self.assertOptionError( 2587db96d56Sopenharmony_ci "option -b/--bad: choices must be a list of " 2597db96d56Sopenharmony_ci "strings ('%s' supplied)" % typename, 2607db96d56Sopenharmony_ci ["-b", "--bad"], 2617db96d56Sopenharmony_ci {'type': "choice", 'choices':"bad choices"}) 2627db96d56Sopenharmony_ci 2637db96d56Sopenharmony_ci def test_no_choices_for_type(self): 2647db96d56Sopenharmony_ci self.assertOptionError( 2657db96d56Sopenharmony_ci "option -b: must not supply choices for type 'int'", 2667db96d56Sopenharmony_ci ["-b"], {'type': 'int', 'choices':"bad"}) 2677db96d56Sopenharmony_ci 2687db96d56Sopenharmony_ci def test_no_const_for_action(self): 2697db96d56Sopenharmony_ci self.assertOptionError( 2707db96d56Sopenharmony_ci "option -b: 'const' must not be supplied for action 'store'", 2717db96d56Sopenharmony_ci ["-b"], {'action': 'store', 'const': 1}) 2727db96d56Sopenharmony_ci 2737db96d56Sopenharmony_ci def test_no_nargs_for_action(self): 2747db96d56Sopenharmony_ci self.assertOptionError( 2757db96d56Sopenharmony_ci "option -b: 'nargs' must not be supplied for action 'count'", 2767db96d56Sopenharmony_ci ["-b"], {'action': 'count', 'nargs': 2}) 2777db96d56Sopenharmony_ci 2787db96d56Sopenharmony_ci def test_callback_not_callable(self): 2797db96d56Sopenharmony_ci self.assertOptionError( 2807db96d56Sopenharmony_ci "option -b: callback not callable: 'foo'", 2817db96d56Sopenharmony_ci ["-b"], {'action': 'callback', 2827db96d56Sopenharmony_ci 'callback': 'foo'}) 2837db96d56Sopenharmony_ci 2847db96d56Sopenharmony_ci def dummy(self): 2857db96d56Sopenharmony_ci pass 2867db96d56Sopenharmony_ci 2877db96d56Sopenharmony_ci def test_callback_args_no_tuple(self): 2887db96d56Sopenharmony_ci self.assertOptionError( 2897db96d56Sopenharmony_ci "option -b: callback_args, if supplied, " 2907db96d56Sopenharmony_ci "must be a tuple: not 'foo'", 2917db96d56Sopenharmony_ci ["-b"], {'action': 'callback', 2927db96d56Sopenharmony_ci 'callback': self.dummy, 2937db96d56Sopenharmony_ci 'callback_args': 'foo'}) 2947db96d56Sopenharmony_ci 2957db96d56Sopenharmony_ci def test_callback_kwargs_no_dict(self): 2967db96d56Sopenharmony_ci self.assertOptionError( 2977db96d56Sopenharmony_ci "option -b: callback_kwargs, if supplied, " 2987db96d56Sopenharmony_ci "must be a dict: not 'foo'", 2997db96d56Sopenharmony_ci ["-b"], {'action': 'callback', 3007db96d56Sopenharmony_ci 'callback': self.dummy, 3017db96d56Sopenharmony_ci 'callback_kwargs': 'foo'}) 3027db96d56Sopenharmony_ci 3037db96d56Sopenharmony_ci def test_no_callback_for_action(self): 3047db96d56Sopenharmony_ci self.assertOptionError( 3057db96d56Sopenharmony_ci "option -b: callback supplied ('foo') for non-callback option", 3067db96d56Sopenharmony_ci ["-b"], {'action': 'store', 3077db96d56Sopenharmony_ci 'callback': 'foo'}) 3087db96d56Sopenharmony_ci 3097db96d56Sopenharmony_ci def test_no_callback_args_for_action(self): 3107db96d56Sopenharmony_ci self.assertOptionError( 3117db96d56Sopenharmony_ci "option -b: callback_args supplied for non-callback option", 3127db96d56Sopenharmony_ci ["-b"], {'action': 'store', 3137db96d56Sopenharmony_ci 'callback_args': 'foo'}) 3147db96d56Sopenharmony_ci 3157db96d56Sopenharmony_ci def test_no_callback_kwargs_for_action(self): 3167db96d56Sopenharmony_ci self.assertOptionError( 3177db96d56Sopenharmony_ci "option -b: callback_kwargs supplied for non-callback option", 3187db96d56Sopenharmony_ci ["-b"], {'action': 'store', 3197db96d56Sopenharmony_ci 'callback_kwargs': 'foo'}) 3207db96d56Sopenharmony_ci 3217db96d56Sopenharmony_ci def test_no_single_dash(self): 3227db96d56Sopenharmony_ci self.assertOptionError( 3237db96d56Sopenharmony_ci "invalid long option string '-debug': " 3247db96d56Sopenharmony_ci "must start with --, followed by non-dash", 3257db96d56Sopenharmony_ci ["-debug"]) 3267db96d56Sopenharmony_ci 3277db96d56Sopenharmony_ci self.assertOptionError( 3287db96d56Sopenharmony_ci "option -d: invalid long option string '-debug': must start with" 3297db96d56Sopenharmony_ci " --, followed by non-dash", 3307db96d56Sopenharmony_ci ["-d", "-debug"]) 3317db96d56Sopenharmony_ci 3327db96d56Sopenharmony_ci self.assertOptionError( 3337db96d56Sopenharmony_ci "invalid long option string '-debug': " 3347db96d56Sopenharmony_ci "must start with --, followed by non-dash", 3357db96d56Sopenharmony_ci ["-debug", "--debug"]) 3367db96d56Sopenharmony_ci 3377db96d56Sopenharmony_ciclass TestOptionParser(BaseTest): 3387db96d56Sopenharmony_ci def setUp(self): 3397db96d56Sopenharmony_ci self.parser = OptionParser() 3407db96d56Sopenharmony_ci self.parser.add_option("-v", "--verbose", "-n", "--noisy", 3417db96d56Sopenharmony_ci action="store_true", dest="verbose") 3427db96d56Sopenharmony_ci self.parser.add_option("-q", "--quiet", "--silent", 3437db96d56Sopenharmony_ci action="store_false", dest="verbose") 3447db96d56Sopenharmony_ci 3457db96d56Sopenharmony_ci def test_add_option_no_Option(self): 3467db96d56Sopenharmony_ci self.assertTypeError(self.parser.add_option, 3477db96d56Sopenharmony_ci "not an Option instance: None", None) 3487db96d56Sopenharmony_ci 3497db96d56Sopenharmony_ci def test_add_option_invalid_arguments(self): 3507db96d56Sopenharmony_ci self.assertTypeError(self.parser.add_option, 3517db96d56Sopenharmony_ci "invalid arguments", None, None) 3527db96d56Sopenharmony_ci 3537db96d56Sopenharmony_ci def test_get_option(self): 3547db96d56Sopenharmony_ci opt1 = self.parser.get_option("-v") 3557db96d56Sopenharmony_ci self.assertIsInstance(opt1, Option) 3567db96d56Sopenharmony_ci self.assertEqual(opt1._short_opts, ["-v", "-n"]) 3577db96d56Sopenharmony_ci self.assertEqual(opt1._long_opts, ["--verbose", "--noisy"]) 3587db96d56Sopenharmony_ci self.assertEqual(opt1.action, "store_true") 3597db96d56Sopenharmony_ci self.assertEqual(opt1.dest, "verbose") 3607db96d56Sopenharmony_ci 3617db96d56Sopenharmony_ci def test_get_option_equals(self): 3627db96d56Sopenharmony_ci opt1 = self.parser.get_option("-v") 3637db96d56Sopenharmony_ci opt2 = self.parser.get_option("--verbose") 3647db96d56Sopenharmony_ci opt3 = self.parser.get_option("-n") 3657db96d56Sopenharmony_ci opt4 = self.parser.get_option("--noisy") 3667db96d56Sopenharmony_ci self.assertTrue(opt1 is opt2 is opt3 is opt4) 3677db96d56Sopenharmony_ci 3687db96d56Sopenharmony_ci def test_has_option(self): 3697db96d56Sopenharmony_ci self.assertTrue(self.parser.has_option("-v")) 3707db96d56Sopenharmony_ci self.assertTrue(self.parser.has_option("--verbose")) 3717db96d56Sopenharmony_ci 3727db96d56Sopenharmony_ci def assertTrueremoved(self): 3737db96d56Sopenharmony_ci self.assertTrue(self.parser.get_option("-v") is None) 3747db96d56Sopenharmony_ci self.assertTrue(self.parser.get_option("--verbose") is None) 3757db96d56Sopenharmony_ci self.assertTrue(self.parser.get_option("-n") is None) 3767db96d56Sopenharmony_ci self.assertTrue(self.parser.get_option("--noisy") is None) 3777db96d56Sopenharmony_ci 3787db96d56Sopenharmony_ci self.assertFalse(self.parser.has_option("-v")) 3797db96d56Sopenharmony_ci self.assertFalse(self.parser.has_option("--verbose")) 3807db96d56Sopenharmony_ci self.assertFalse(self.parser.has_option("-n")) 3817db96d56Sopenharmony_ci self.assertFalse(self.parser.has_option("--noisy")) 3827db96d56Sopenharmony_ci 3837db96d56Sopenharmony_ci self.assertTrue(self.parser.has_option("-q")) 3847db96d56Sopenharmony_ci self.assertTrue(self.parser.has_option("--silent")) 3857db96d56Sopenharmony_ci 3867db96d56Sopenharmony_ci def test_remove_short_opt(self): 3877db96d56Sopenharmony_ci self.parser.remove_option("-n") 3887db96d56Sopenharmony_ci self.assertTrueremoved() 3897db96d56Sopenharmony_ci 3907db96d56Sopenharmony_ci def test_remove_long_opt(self): 3917db96d56Sopenharmony_ci self.parser.remove_option("--verbose") 3927db96d56Sopenharmony_ci self.assertTrueremoved() 3937db96d56Sopenharmony_ci 3947db96d56Sopenharmony_ci def test_remove_nonexistent(self): 3957db96d56Sopenharmony_ci self.assertRaises(self.parser.remove_option, ('foo',), None, 3967db96d56Sopenharmony_ci ValueError, "no such option 'foo'") 3977db96d56Sopenharmony_ci 3987db96d56Sopenharmony_ci @support.impl_detail('Relies on sys.getrefcount', cpython=True) 3997db96d56Sopenharmony_ci def test_refleak(self): 4007db96d56Sopenharmony_ci # If an OptionParser is carrying around a reference to a large 4017db96d56Sopenharmony_ci # object, various cycles can prevent it from being GC'd in 4027db96d56Sopenharmony_ci # a timely fashion. destroy() breaks the cycles to ensure stuff 4037db96d56Sopenharmony_ci # can be cleaned up. 4047db96d56Sopenharmony_ci big_thing = [42] 4057db96d56Sopenharmony_ci refcount = sys.getrefcount(big_thing) 4067db96d56Sopenharmony_ci parser = OptionParser() 4077db96d56Sopenharmony_ci parser.add_option("-a", "--aaarggh") 4087db96d56Sopenharmony_ci parser.big_thing = big_thing 4097db96d56Sopenharmony_ci 4107db96d56Sopenharmony_ci parser.destroy() 4117db96d56Sopenharmony_ci #self.assertEqual(refcount, sys.getrefcount(big_thing)) 4127db96d56Sopenharmony_ci del parser 4137db96d56Sopenharmony_ci self.assertEqual(refcount, sys.getrefcount(big_thing)) 4147db96d56Sopenharmony_ci 4157db96d56Sopenharmony_ci 4167db96d56Sopenharmony_ciclass TestOptionValues(BaseTest): 4177db96d56Sopenharmony_ci def setUp(self): 4187db96d56Sopenharmony_ci pass 4197db96d56Sopenharmony_ci 4207db96d56Sopenharmony_ci def test_basics(self): 4217db96d56Sopenharmony_ci values = Values() 4227db96d56Sopenharmony_ci self.assertEqual(vars(values), {}) 4237db96d56Sopenharmony_ci self.assertEqual(values, {}) 4247db96d56Sopenharmony_ci self.assertNotEqual(values, {"foo": "bar"}) 4257db96d56Sopenharmony_ci self.assertNotEqual(values, "") 4267db96d56Sopenharmony_ci 4277db96d56Sopenharmony_ci dict = {"foo": "bar", "baz": 42} 4287db96d56Sopenharmony_ci values = Values(defaults=dict) 4297db96d56Sopenharmony_ci self.assertEqual(vars(values), dict) 4307db96d56Sopenharmony_ci self.assertEqual(values, dict) 4317db96d56Sopenharmony_ci self.assertNotEqual(values, {"foo": "bar"}) 4327db96d56Sopenharmony_ci self.assertNotEqual(values, {}) 4337db96d56Sopenharmony_ci self.assertNotEqual(values, "") 4347db96d56Sopenharmony_ci self.assertNotEqual(values, []) 4357db96d56Sopenharmony_ci 4367db96d56Sopenharmony_ci 4377db96d56Sopenharmony_ciclass TestTypeAliases(BaseTest): 4387db96d56Sopenharmony_ci def setUp(self): 4397db96d56Sopenharmony_ci self.parser = OptionParser() 4407db96d56Sopenharmony_ci 4417db96d56Sopenharmony_ci def test_str_aliases_string(self): 4427db96d56Sopenharmony_ci self.parser.add_option("-s", type="str") 4437db96d56Sopenharmony_ci self.assertEqual(self.parser.get_option("-s").type, "string") 4447db96d56Sopenharmony_ci 4457db96d56Sopenharmony_ci def test_type_object(self): 4467db96d56Sopenharmony_ci self.parser.add_option("-s", type=str) 4477db96d56Sopenharmony_ci self.assertEqual(self.parser.get_option("-s").type, "string") 4487db96d56Sopenharmony_ci self.parser.add_option("-x", type=int) 4497db96d56Sopenharmony_ci self.assertEqual(self.parser.get_option("-x").type, "int") 4507db96d56Sopenharmony_ci 4517db96d56Sopenharmony_ci 4527db96d56Sopenharmony_ci# Custom type for testing processing of default values. 4537db96d56Sopenharmony_ci_time_units = { 's' : 1, 'm' : 60, 'h' : 60*60, 'd' : 60*60*24 } 4547db96d56Sopenharmony_ci 4557db96d56Sopenharmony_cidef _check_duration(option, opt, value): 4567db96d56Sopenharmony_ci try: 4577db96d56Sopenharmony_ci if value[-1].isdigit(): 4587db96d56Sopenharmony_ci return int(value) 4597db96d56Sopenharmony_ci else: 4607db96d56Sopenharmony_ci return int(value[:-1]) * _time_units[value[-1]] 4617db96d56Sopenharmony_ci except (ValueError, IndexError): 4627db96d56Sopenharmony_ci raise OptionValueError( 4637db96d56Sopenharmony_ci 'option %s: invalid duration: %r' % (opt, value)) 4647db96d56Sopenharmony_ci 4657db96d56Sopenharmony_ciclass DurationOption(Option): 4667db96d56Sopenharmony_ci TYPES = Option.TYPES + ('duration',) 4677db96d56Sopenharmony_ci TYPE_CHECKER = copy.copy(Option.TYPE_CHECKER) 4687db96d56Sopenharmony_ci TYPE_CHECKER['duration'] = _check_duration 4697db96d56Sopenharmony_ci 4707db96d56Sopenharmony_ciclass TestDefaultValues(BaseTest): 4717db96d56Sopenharmony_ci def setUp(self): 4727db96d56Sopenharmony_ci self.parser = OptionParser() 4737db96d56Sopenharmony_ci self.parser.add_option("-v", "--verbose", default=True) 4747db96d56Sopenharmony_ci self.parser.add_option("-q", "--quiet", dest='verbose') 4757db96d56Sopenharmony_ci self.parser.add_option("-n", type="int", default=37) 4767db96d56Sopenharmony_ci self.parser.add_option("-m", type="int") 4777db96d56Sopenharmony_ci self.parser.add_option("-s", default="foo") 4787db96d56Sopenharmony_ci self.parser.add_option("-t") 4797db96d56Sopenharmony_ci self.parser.add_option("-u", default=None) 4807db96d56Sopenharmony_ci self.expected = { 'verbose': True, 4817db96d56Sopenharmony_ci 'n': 37, 4827db96d56Sopenharmony_ci 'm': None, 4837db96d56Sopenharmony_ci 's': "foo", 4847db96d56Sopenharmony_ci 't': None, 4857db96d56Sopenharmony_ci 'u': None } 4867db96d56Sopenharmony_ci 4877db96d56Sopenharmony_ci def test_basic_defaults(self): 4887db96d56Sopenharmony_ci self.assertEqual(self.parser.get_default_values(), self.expected) 4897db96d56Sopenharmony_ci 4907db96d56Sopenharmony_ci def test_mixed_defaults_post(self): 4917db96d56Sopenharmony_ci self.parser.set_defaults(n=42, m=-100) 4927db96d56Sopenharmony_ci self.expected.update({'n': 42, 'm': -100}) 4937db96d56Sopenharmony_ci self.assertEqual(self.parser.get_default_values(), self.expected) 4947db96d56Sopenharmony_ci 4957db96d56Sopenharmony_ci def test_mixed_defaults_pre(self): 4967db96d56Sopenharmony_ci self.parser.set_defaults(x="barf", y="blah") 4977db96d56Sopenharmony_ci self.parser.add_option("-x", default="frob") 4987db96d56Sopenharmony_ci self.parser.add_option("-y") 4997db96d56Sopenharmony_ci 5007db96d56Sopenharmony_ci self.expected.update({'x': "frob", 'y': "blah"}) 5017db96d56Sopenharmony_ci self.assertEqual(self.parser.get_default_values(), self.expected) 5027db96d56Sopenharmony_ci 5037db96d56Sopenharmony_ci self.parser.remove_option("-y") 5047db96d56Sopenharmony_ci self.parser.add_option("-y", default=None) 5057db96d56Sopenharmony_ci self.expected.update({'y': None}) 5067db96d56Sopenharmony_ci self.assertEqual(self.parser.get_default_values(), self.expected) 5077db96d56Sopenharmony_ci 5087db96d56Sopenharmony_ci def test_process_default(self): 5097db96d56Sopenharmony_ci self.parser.option_class = DurationOption 5107db96d56Sopenharmony_ci self.parser.add_option("-d", type="duration", default=300) 5117db96d56Sopenharmony_ci self.parser.add_option("-e", type="duration", default="6m") 5127db96d56Sopenharmony_ci self.parser.set_defaults(n="42") 5137db96d56Sopenharmony_ci self.expected.update({'d': 300, 'e': 360, 'n': 42}) 5147db96d56Sopenharmony_ci self.assertEqual(self.parser.get_default_values(), self.expected) 5157db96d56Sopenharmony_ci 5167db96d56Sopenharmony_ci self.parser.set_process_default_values(False) 5177db96d56Sopenharmony_ci self.expected.update({'d': 300, 'e': "6m", 'n': "42"}) 5187db96d56Sopenharmony_ci self.assertEqual(self.parser.get_default_values(), self.expected) 5197db96d56Sopenharmony_ci 5207db96d56Sopenharmony_ci 5217db96d56Sopenharmony_ciclass TestProgName(BaseTest): 5227db96d56Sopenharmony_ci """ 5237db96d56Sopenharmony_ci Test that %prog expands to the right thing in usage, version, 5247db96d56Sopenharmony_ci and help strings. 5257db96d56Sopenharmony_ci """ 5267db96d56Sopenharmony_ci 5277db96d56Sopenharmony_ci def assertUsage(self, parser, expected_usage): 5287db96d56Sopenharmony_ci self.assertEqual(parser.get_usage(), expected_usage) 5297db96d56Sopenharmony_ci 5307db96d56Sopenharmony_ci def assertVersion(self, parser, expected_version): 5317db96d56Sopenharmony_ci self.assertEqual(parser.get_version(), expected_version) 5327db96d56Sopenharmony_ci 5337db96d56Sopenharmony_ci 5347db96d56Sopenharmony_ci def test_default_progname(self): 5357db96d56Sopenharmony_ci # Make sure that program name taken from sys.argv[0] by default. 5367db96d56Sopenharmony_ci save_argv = sys.argv[:] 5377db96d56Sopenharmony_ci try: 5387db96d56Sopenharmony_ci sys.argv[0] = os.path.join("foo", "bar", "baz.py") 5397db96d56Sopenharmony_ci parser = OptionParser("%prog ...", version="%prog 1.2") 5407db96d56Sopenharmony_ci expected_usage = "Usage: baz.py ...\n" 5417db96d56Sopenharmony_ci self.assertUsage(parser, expected_usage) 5427db96d56Sopenharmony_ci self.assertVersion(parser, "baz.py 1.2") 5437db96d56Sopenharmony_ci self.assertHelp(parser, 5447db96d56Sopenharmony_ci expected_usage + "\n" + 5457db96d56Sopenharmony_ci "Options:\n" 5467db96d56Sopenharmony_ci " --version show program's version number and exit\n" 5477db96d56Sopenharmony_ci " -h, --help show this help message and exit\n") 5487db96d56Sopenharmony_ci finally: 5497db96d56Sopenharmony_ci sys.argv[:] = save_argv 5507db96d56Sopenharmony_ci 5517db96d56Sopenharmony_ci def test_custom_progname(self): 5527db96d56Sopenharmony_ci parser = OptionParser(prog="thingy", 5537db96d56Sopenharmony_ci version="%prog 0.1", 5547db96d56Sopenharmony_ci usage="%prog arg arg") 5557db96d56Sopenharmony_ci parser.remove_option("-h") 5567db96d56Sopenharmony_ci parser.remove_option("--version") 5577db96d56Sopenharmony_ci expected_usage = "Usage: thingy arg arg\n" 5587db96d56Sopenharmony_ci self.assertUsage(parser, expected_usage) 5597db96d56Sopenharmony_ci self.assertVersion(parser, "thingy 0.1") 5607db96d56Sopenharmony_ci self.assertHelp(parser, expected_usage + "\n") 5617db96d56Sopenharmony_ci 5627db96d56Sopenharmony_ci 5637db96d56Sopenharmony_ciclass TestExpandDefaults(BaseTest): 5647db96d56Sopenharmony_ci def setUp(self): 5657db96d56Sopenharmony_ci self.parser = OptionParser(prog="test") 5667db96d56Sopenharmony_ci self.help_prefix = """\ 5677db96d56Sopenharmony_ciUsage: test [options] 5687db96d56Sopenharmony_ci 5697db96d56Sopenharmony_ciOptions: 5707db96d56Sopenharmony_ci -h, --help show this help message and exit 5717db96d56Sopenharmony_ci""" 5727db96d56Sopenharmony_ci self.file_help = "read from FILE [default: %default]" 5737db96d56Sopenharmony_ci self.expected_help_file = self.help_prefix + \ 5747db96d56Sopenharmony_ci " -f FILE, --file=FILE read from FILE [default: foo.txt]\n" 5757db96d56Sopenharmony_ci self.expected_help_none = self.help_prefix + \ 5767db96d56Sopenharmony_ci " -f FILE, --file=FILE read from FILE [default: none]\n" 5777db96d56Sopenharmony_ci 5787db96d56Sopenharmony_ci def test_option_default(self): 5797db96d56Sopenharmony_ci self.parser.add_option("-f", "--file", 5807db96d56Sopenharmony_ci default="foo.txt", 5817db96d56Sopenharmony_ci help=self.file_help) 5827db96d56Sopenharmony_ci self.assertHelp(self.parser, self.expected_help_file) 5837db96d56Sopenharmony_ci 5847db96d56Sopenharmony_ci def test_parser_default_1(self): 5857db96d56Sopenharmony_ci self.parser.add_option("-f", "--file", 5867db96d56Sopenharmony_ci help=self.file_help) 5877db96d56Sopenharmony_ci self.parser.set_default('file', "foo.txt") 5887db96d56Sopenharmony_ci self.assertHelp(self.parser, self.expected_help_file) 5897db96d56Sopenharmony_ci 5907db96d56Sopenharmony_ci def test_parser_default_2(self): 5917db96d56Sopenharmony_ci self.parser.add_option("-f", "--file", 5927db96d56Sopenharmony_ci help=self.file_help) 5937db96d56Sopenharmony_ci self.parser.set_defaults(file="foo.txt") 5947db96d56Sopenharmony_ci self.assertHelp(self.parser, self.expected_help_file) 5957db96d56Sopenharmony_ci 5967db96d56Sopenharmony_ci def test_no_default(self): 5977db96d56Sopenharmony_ci self.parser.add_option("-f", "--file", 5987db96d56Sopenharmony_ci help=self.file_help) 5997db96d56Sopenharmony_ci self.assertHelp(self.parser, self.expected_help_none) 6007db96d56Sopenharmony_ci 6017db96d56Sopenharmony_ci def test_default_none_1(self): 6027db96d56Sopenharmony_ci self.parser.add_option("-f", "--file", 6037db96d56Sopenharmony_ci default=None, 6047db96d56Sopenharmony_ci help=self.file_help) 6057db96d56Sopenharmony_ci self.assertHelp(self.parser, self.expected_help_none) 6067db96d56Sopenharmony_ci 6077db96d56Sopenharmony_ci def test_default_none_2(self): 6087db96d56Sopenharmony_ci self.parser.add_option("-f", "--file", 6097db96d56Sopenharmony_ci help=self.file_help) 6107db96d56Sopenharmony_ci self.parser.set_defaults(file=None) 6117db96d56Sopenharmony_ci self.assertHelp(self.parser, self.expected_help_none) 6127db96d56Sopenharmony_ci 6137db96d56Sopenharmony_ci def test_float_default(self): 6147db96d56Sopenharmony_ci self.parser.add_option( 6157db96d56Sopenharmony_ci "-p", "--prob", 6167db96d56Sopenharmony_ci help="blow up with probability PROB [default: %default]") 6177db96d56Sopenharmony_ci self.parser.set_defaults(prob=0.43) 6187db96d56Sopenharmony_ci expected_help = self.help_prefix + \ 6197db96d56Sopenharmony_ci " -p PROB, --prob=PROB blow up with probability PROB [default: 0.43]\n" 6207db96d56Sopenharmony_ci self.assertHelp(self.parser, expected_help) 6217db96d56Sopenharmony_ci 6227db96d56Sopenharmony_ci def test_alt_expand(self): 6237db96d56Sopenharmony_ci self.parser.add_option("-f", "--file", 6247db96d56Sopenharmony_ci default="foo.txt", 6257db96d56Sopenharmony_ci help="read from FILE [default: *DEFAULT*]") 6267db96d56Sopenharmony_ci self.parser.formatter.default_tag = "*DEFAULT*" 6277db96d56Sopenharmony_ci self.assertHelp(self.parser, self.expected_help_file) 6287db96d56Sopenharmony_ci 6297db96d56Sopenharmony_ci def test_no_expand(self): 6307db96d56Sopenharmony_ci self.parser.add_option("-f", "--file", 6317db96d56Sopenharmony_ci default="foo.txt", 6327db96d56Sopenharmony_ci help="read from %default file") 6337db96d56Sopenharmony_ci self.parser.formatter.default_tag = None 6347db96d56Sopenharmony_ci expected_help = self.help_prefix + \ 6357db96d56Sopenharmony_ci " -f FILE, --file=FILE read from %default file\n" 6367db96d56Sopenharmony_ci self.assertHelp(self.parser, expected_help) 6377db96d56Sopenharmony_ci 6387db96d56Sopenharmony_ci 6397db96d56Sopenharmony_ci# -- Test parser.parse_args() ------------------------------------------ 6407db96d56Sopenharmony_ci 6417db96d56Sopenharmony_ciclass TestStandard(BaseTest): 6427db96d56Sopenharmony_ci def setUp(self): 6437db96d56Sopenharmony_ci options = [make_option("-a", type="string"), 6447db96d56Sopenharmony_ci make_option("-b", "--boo", type="int", dest='boo'), 6457db96d56Sopenharmony_ci make_option("--foo", action="append")] 6467db96d56Sopenharmony_ci 6477db96d56Sopenharmony_ci self.parser = InterceptingOptionParser(usage=SUPPRESS_USAGE, 6487db96d56Sopenharmony_ci option_list=options) 6497db96d56Sopenharmony_ci 6507db96d56Sopenharmony_ci def test_required_value(self): 6517db96d56Sopenharmony_ci self.assertParseFail(["-a"], "-a option requires 1 argument") 6527db96d56Sopenharmony_ci 6537db96d56Sopenharmony_ci def test_invalid_integer(self): 6547db96d56Sopenharmony_ci self.assertParseFail(["-b", "5x"], 6557db96d56Sopenharmony_ci "option -b: invalid integer value: '5x'") 6567db96d56Sopenharmony_ci 6577db96d56Sopenharmony_ci def test_no_such_option(self): 6587db96d56Sopenharmony_ci self.assertParseFail(["--boo13"], "no such option: --boo13") 6597db96d56Sopenharmony_ci 6607db96d56Sopenharmony_ci def test_long_invalid_integer(self): 6617db96d56Sopenharmony_ci self.assertParseFail(["--boo=x5"], 6627db96d56Sopenharmony_ci "option --boo: invalid integer value: 'x5'") 6637db96d56Sopenharmony_ci 6647db96d56Sopenharmony_ci def test_empty(self): 6657db96d56Sopenharmony_ci self.assertParseOK([], {'a': None, 'boo': None, 'foo': None}, []) 6667db96d56Sopenharmony_ci 6677db96d56Sopenharmony_ci def test_shortopt_empty_longopt_append(self): 6687db96d56Sopenharmony_ci self.assertParseOK(["-a", "", "--foo=blah", "--foo="], 6697db96d56Sopenharmony_ci {'a': "", 'boo': None, 'foo': ["blah", ""]}, 6707db96d56Sopenharmony_ci []) 6717db96d56Sopenharmony_ci 6727db96d56Sopenharmony_ci def test_long_option_append(self): 6737db96d56Sopenharmony_ci self.assertParseOK(["--foo", "bar", "--foo", "", "--foo=x"], 6747db96d56Sopenharmony_ci {'a': None, 6757db96d56Sopenharmony_ci 'boo': None, 6767db96d56Sopenharmony_ci 'foo': ["bar", "", "x"]}, 6777db96d56Sopenharmony_ci []) 6787db96d56Sopenharmony_ci 6797db96d56Sopenharmony_ci def test_option_argument_joined(self): 6807db96d56Sopenharmony_ci self.assertParseOK(["-abc"], 6817db96d56Sopenharmony_ci {'a': "bc", 'boo': None, 'foo': None}, 6827db96d56Sopenharmony_ci []) 6837db96d56Sopenharmony_ci 6847db96d56Sopenharmony_ci def test_option_argument_split(self): 6857db96d56Sopenharmony_ci self.assertParseOK(["-a", "34"], 6867db96d56Sopenharmony_ci {'a': "34", 'boo': None, 'foo': None}, 6877db96d56Sopenharmony_ci []) 6887db96d56Sopenharmony_ci 6897db96d56Sopenharmony_ci def test_option_argument_joined_integer(self): 6907db96d56Sopenharmony_ci self.assertParseOK(["-b34"], 6917db96d56Sopenharmony_ci {'a': None, 'boo': 34, 'foo': None}, 6927db96d56Sopenharmony_ci []) 6937db96d56Sopenharmony_ci 6947db96d56Sopenharmony_ci def test_option_argument_split_negative_integer(self): 6957db96d56Sopenharmony_ci self.assertParseOK(["-b", "-5"], 6967db96d56Sopenharmony_ci {'a': None, 'boo': -5, 'foo': None}, 6977db96d56Sopenharmony_ci []) 6987db96d56Sopenharmony_ci 6997db96d56Sopenharmony_ci def test_long_option_argument_joined(self): 7007db96d56Sopenharmony_ci self.assertParseOK(["--boo=13"], 7017db96d56Sopenharmony_ci {'a': None, 'boo': 13, 'foo': None}, 7027db96d56Sopenharmony_ci []) 7037db96d56Sopenharmony_ci 7047db96d56Sopenharmony_ci def test_long_option_argument_split(self): 7057db96d56Sopenharmony_ci self.assertParseOK(["--boo", "111"], 7067db96d56Sopenharmony_ci {'a': None, 'boo': 111, 'foo': None}, 7077db96d56Sopenharmony_ci []) 7087db96d56Sopenharmony_ci 7097db96d56Sopenharmony_ci def test_long_option_short_option(self): 7107db96d56Sopenharmony_ci self.assertParseOK(["--foo=bar", "-axyz"], 7117db96d56Sopenharmony_ci {'a': 'xyz', 'boo': None, 'foo': ["bar"]}, 7127db96d56Sopenharmony_ci []) 7137db96d56Sopenharmony_ci 7147db96d56Sopenharmony_ci def test_abbrev_long_option(self): 7157db96d56Sopenharmony_ci self.assertParseOK(["--f=bar", "-axyz"], 7167db96d56Sopenharmony_ci {'a': 'xyz', 'boo': None, 'foo': ["bar"]}, 7177db96d56Sopenharmony_ci []) 7187db96d56Sopenharmony_ci 7197db96d56Sopenharmony_ci def test_defaults(self): 7207db96d56Sopenharmony_ci (options, args) = self.parser.parse_args([]) 7217db96d56Sopenharmony_ci defaults = self.parser.get_default_values() 7227db96d56Sopenharmony_ci self.assertEqual(vars(defaults), vars(options)) 7237db96d56Sopenharmony_ci 7247db96d56Sopenharmony_ci def test_ambiguous_option(self): 7257db96d56Sopenharmony_ci self.parser.add_option("--foz", action="store", 7267db96d56Sopenharmony_ci type="string", dest="foo") 7277db96d56Sopenharmony_ci self.assertParseFail(["--f=bar"], 7287db96d56Sopenharmony_ci "ambiguous option: --f (--foo, --foz?)") 7297db96d56Sopenharmony_ci 7307db96d56Sopenharmony_ci 7317db96d56Sopenharmony_ci def test_short_and_long_option_split(self): 7327db96d56Sopenharmony_ci self.assertParseOK(["-a", "xyz", "--foo", "bar"], 7337db96d56Sopenharmony_ci {'a': 'xyz', 'boo': None, 'foo': ["bar"]}, 7347db96d56Sopenharmony_ci []) 7357db96d56Sopenharmony_ci 7367db96d56Sopenharmony_ci def test_short_option_split_long_option_append(self): 7377db96d56Sopenharmony_ci self.assertParseOK(["--foo=bar", "-b", "123", "--foo", "baz"], 7387db96d56Sopenharmony_ci {'a': None, 'boo': 123, 'foo': ["bar", "baz"]}, 7397db96d56Sopenharmony_ci []) 7407db96d56Sopenharmony_ci 7417db96d56Sopenharmony_ci def test_short_option_split_one_positional_arg(self): 7427db96d56Sopenharmony_ci self.assertParseOK(["-a", "foo", "bar"], 7437db96d56Sopenharmony_ci {'a': "foo", 'boo': None, 'foo': None}, 7447db96d56Sopenharmony_ci ["bar"]) 7457db96d56Sopenharmony_ci 7467db96d56Sopenharmony_ci def test_short_option_consumes_separator(self): 7477db96d56Sopenharmony_ci self.assertParseOK(["-a", "--", "foo", "bar"], 7487db96d56Sopenharmony_ci {'a': "--", 'boo': None, 'foo': None}, 7497db96d56Sopenharmony_ci ["foo", "bar"]) 7507db96d56Sopenharmony_ci self.assertParseOK(["-a", "--", "--foo", "bar"], 7517db96d56Sopenharmony_ci {'a': "--", 'boo': None, 'foo': ["bar"]}, 7527db96d56Sopenharmony_ci []) 7537db96d56Sopenharmony_ci 7547db96d56Sopenharmony_ci def test_short_option_joined_and_separator(self): 7557db96d56Sopenharmony_ci self.assertParseOK(["-ab", "--", "--foo", "bar"], 7567db96d56Sopenharmony_ci {'a': "b", 'boo': None, 'foo': None}, 7577db96d56Sopenharmony_ci ["--foo", "bar"]), 7587db96d56Sopenharmony_ci 7597db96d56Sopenharmony_ci def test_hyphen_becomes_positional_arg(self): 7607db96d56Sopenharmony_ci self.assertParseOK(["-ab", "-", "--foo", "bar"], 7617db96d56Sopenharmony_ci {'a': "b", 'boo': None, 'foo': ["bar"]}, 7627db96d56Sopenharmony_ci ["-"]) 7637db96d56Sopenharmony_ci 7647db96d56Sopenharmony_ci def test_no_append_versus_append(self): 7657db96d56Sopenharmony_ci self.assertParseOK(["-b3", "-b", "5", "--foo=bar", "--foo", "baz"], 7667db96d56Sopenharmony_ci {'a': None, 'boo': 5, 'foo': ["bar", "baz"]}, 7677db96d56Sopenharmony_ci []) 7687db96d56Sopenharmony_ci 7697db96d56Sopenharmony_ci def test_option_consumes_optionlike_string(self): 7707db96d56Sopenharmony_ci self.assertParseOK(["-a", "-b3"], 7717db96d56Sopenharmony_ci {'a': "-b3", 'boo': None, 'foo': None}, 7727db96d56Sopenharmony_ci []) 7737db96d56Sopenharmony_ci 7747db96d56Sopenharmony_ci def test_combined_single_invalid_option(self): 7757db96d56Sopenharmony_ci self.parser.add_option("-t", action="store_true") 7767db96d56Sopenharmony_ci self.assertParseFail(["-test"], 7777db96d56Sopenharmony_ci "no such option: -e") 7787db96d56Sopenharmony_ci 7797db96d56Sopenharmony_ciclass TestBool(BaseTest): 7807db96d56Sopenharmony_ci def setUp(self): 7817db96d56Sopenharmony_ci options = [make_option("-v", 7827db96d56Sopenharmony_ci "--verbose", 7837db96d56Sopenharmony_ci action="store_true", 7847db96d56Sopenharmony_ci dest="verbose", 7857db96d56Sopenharmony_ci default=''), 7867db96d56Sopenharmony_ci make_option("-q", 7877db96d56Sopenharmony_ci "--quiet", 7887db96d56Sopenharmony_ci action="store_false", 7897db96d56Sopenharmony_ci dest="verbose")] 7907db96d56Sopenharmony_ci self.parser = OptionParser(option_list = options) 7917db96d56Sopenharmony_ci 7927db96d56Sopenharmony_ci def test_bool_default(self): 7937db96d56Sopenharmony_ci self.assertParseOK([], 7947db96d56Sopenharmony_ci {'verbose': ''}, 7957db96d56Sopenharmony_ci []) 7967db96d56Sopenharmony_ci 7977db96d56Sopenharmony_ci def test_bool_false(self): 7987db96d56Sopenharmony_ci (options, args) = self.assertParseOK(["-q"], 7997db96d56Sopenharmony_ci {'verbose': 0}, 8007db96d56Sopenharmony_ci []) 8017db96d56Sopenharmony_ci self.assertTrue(options.verbose is False) 8027db96d56Sopenharmony_ci 8037db96d56Sopenharmony_ci def test_bool_true(self): 8047db96d56Sopenharmony_ci (options, args) = self.assertParseOK(["-v"], 8057db96d56Sopenharmony_ci {'verbose': 1}, 8067db96d56Sopenharmony_ci []) 8077db96d56Sopenharmony_ci self.assertTrue(options.verbose is True) 8087db96d56Sopenharmony_ci 8097db96d56Sopenharmony_ci def test_bool_flicker_on_and_off(self): 8107db96d56Sopenharmony_ci self.assertParseOK(["-qvq", "-q", "-v"], 8117db96d56Sopenharmony_ci {'verbose': 1}, 8127db96d56Sopenharmony_ci []) 8137db96d56Sopenharmony_ci 8147db96d56Sopenharmony_ciclass TestChoice(BaseTest): 8157db96d56Sopenharmony_ci def setUp(self): 8167db96d56Sopenharmony_ci self.parser = InterceptingOptionParser(usage=SUPPRESS_USAGE) 8177db96d56Sopenharmony_ci self.parser.add_option("-c", action="store", type="choice", 8187db96d56Sopenharmony_ci dest="choice", choices=["one", "two", "three"]) 8197db96d56Sopenharmony_ci 8207db96d56Sopenharmony_ci def test_valid_choice(self): 8217db96d56Sopenharmony_ci self.assertParseOK(["-c", "one", "xyz"], 8227db96d56Sopenharmony_ci {'choice': 'one'}, 8237db96d56Sopenharmony_ci ["xyz"]) 8247db96d56Sopenharmony_ci 8257db96d56Sopenharmony_ci def test_invalid_choice(self): 8267db96d56Sopenharmony_ci self.assertParseFail(["-c", "four", "abc"], 8277db96d56Sopenharmony_ci "option -c: invalid choice: 'four' " 8287db96d56Sopenharmony_ci "(choose from 'one', 'two', 'three')") 8297db96d56Sopenharmony_ci 8307db96d56Sopenharmony_ci def test_add_choice_option(self): 8317db96d56Sopenharmony_ci self.parser.add_option("-d", "--default", 8327db96d56Sopenharmony_ci choices=["four", "five", "six"]) 8337db96d56Sopenharmony_ci opt = self.parser.get_option("-d") 8347db96d56Sopenharmony_ci self.assertEqual(opt.type, "choice") 8357db96d56Sopenharmony_ci self.assertEqual(opt.action, "store") 8367db96d56Sopenharmony_ci 8377db96d56Sopenharmony_ciclass TestCount(BaseTest): 8387db96d56Sopenharmony_ci def setUp(self): 8397db96d56Sopenharmony_ci self.parser = InterceptingOptionParser(usage=SUPPRESS_USAGE) 8407db96d56Sopenharmony_ci self.v_opt = make_option("-v", action="count", dest="verbose") 8417db96d56Sopenharmony_ci self.parser.add_option(self.v_opt) 8427db96d56Sopenharmony_ci self.parser.add_option("--verbose", type="int", dest="verbose") 8437db96d56Sopenharmony_ci self.parser.add_option("-q", "--quiet", 8447db96d56Sopenharmony_ci action="store_const", dest="verbose", const=0) 8457db96d56Sopenharmony_ci 8467db96d56Sopenharmony_ci def test_empty(self): 8477db96d56Sopenharmony_ci self.assertParseOK([], {'verbose': None}, []) 8487db96d56Sopenharmony_ci 8497db96d56Sopenharmony_ci def test_count_one(self): 8507db96d56Sopenharmony_ci self.assertParseOK(["-v"], {'verbose': 1}, []) 8517db96d56Sopenharmony_ci 8527db96d56Sopenharmony_ci def test_count_three(self): 8537db96d56Sopenharmony_ci self.assertParseOK(["-vvv"], {'verbose': 3}, []) 8547db96d56Sopenharmony_ci 8557db96d56Sopenharmony_ci def test_count_three_apart(self): 8567db96d56Sopenharmony_ci self.assertParseOK(["-v", "-v", "-v"], {'verbose': 3}, []) 8577db96d56Sopenharmony_ci 8587db96d56Sopenharmony_ci def test_count_override_amount(self): 8597db96d56Sopenharmony_ci self.assertParseOK(["-vvv", "--verbose=2"], {'verbose': 2}, []) 8607db96d56Sopenharmony_ci 8617db96d56Sopenharmony_ci def test_count_override_quiet(self): 8627db96d56Sopenharmony_ci self.assertParseOK(["-vvv", "--verbose=2", "-q"], {'verbose': 0}, []) 8637db96d56Sopenharmony_ci 8647db96d56Sopenharmony_ci def test_count_overriding(self): 8657db96d56Sopenharmony_ci self.assertParseOK(["-vvv", "--verbose=2", "-q", "-v"], 8667db96d56Sopenharmony_ci {'verbose': 1}, []) 8677db96d56Sopenharmony_ci 8687db96d56Sopenharmony_ci def test_count_interspersed_args(self): 8697db96d56Sopenharmony_ci self.assertParseOK(["--quiet", "3", "-v"], 8707db96d56Sopenharmony_ci {'verbose': 1}, 8717db96d56Sopenharmony_ci ["3"]) 8727db96d56Sopenharmony_ci 8737db96d56Sopenharmony_ci def test_count_no_interspersed_args(self): 8747db96d56Sopenharmony_ci self.parser.disable_interspersed_args() 8757db96d56Sopenharmony_ci self.assertParseOK(["--quiet", "3", "-v"], 8767db96d56Sopenharmony_ci {'verbose': 0}, 8777db96d56Sopenharmony_ci ["3", "-v"]) 8787db96d56Sopenharmony_ci 8797db96d56Sopenharmony_ci def test_count_no_such_option(self): 8807db96d56Sopenharmony_ci self.assertParseFail(["-q3", "-v"], "no such option: -3") 8817db96d56Sopenharmony_ci 8827db96d56Sopenharmony_ci def test_count_option_no_value(self): 8837db96d56Sopenharmony_ci self.assertParseFail(["--quiet=3", "-v"], 8847db96d56Sopenharmony_ci "--quiet option does not take a value") 8857db96d56Sopenharmony_ci 8867db96d56Sopenharmony_ci def test_count_with_default(self): 8877db96d56Sopenharmony_ci self.parser.set_default('verbose', 0) 8887db96d56Sopenharmony_ci self.assertParseOK([], {'verbose':0}, []) 8897db96d56Sopenharmony_ci 8907db96d56Sopenharmony_ci def test_count_overriding_default(self): 8917db96d56Sopenharmony_ci self.parser.set_default('verbose', 0) 8927db96d56Sopenharmony_ci self.assertParseOK(["-vvv", "--verbose=2", "-q", "-v"], 8937db96d56Sopenharmony_ci {'verbose': 1}, []) 8947db96d56Sopenharmony_ci 8957db96d56Sopenharmony_ciclass TestMultipleArgs(BaseTest): 8967db96d56Sopenharmony_ci def setUp(self): 8977db96d56Sopenharmony_ci self.parser = InterceptingOptionParser(usage=SUPPRESS_USAGE) 8987db96d56Sopenharmony_ci self.parser.add_option("-p", "--point", 8997db96d56Sopenharmony_ci action="store", nargs=3, type="float", dest="point") 9007db96d56Sopenharmony_ci 9017db96d56Sopenharmony_ci def test_nargs_with_positional_args(self): 9027db96d56Sopenharmony_ci self.assertParseOK(["foo", "-p", "1", "2.5", "-4.3", "xyz"], 9037db96d56Sopenharmony_ci {'point': (1.0, 2.5, -4.3)}, 9047db96d56Sopenharmony_ci ["foo", "xyz"]) 9057db96d56Sopenharmony_ci 9067db96d56Sopenharmony_ci def test_nargs_long_opt(self): 9077db96d56Sopenharmony_ci self.assertParseOK(["--point", "-1", "2.5", "-0", "xyz"], 9087db96d56Sopenharmony_ci {'point': (-1.0, 2.5, -0.0)}, 9097db96d56Sopenharmony_ci ["xyz"]) 9107db96d56Sopenharmony_ci 9117db96d56Sopenharmony_ci def test_nargs_invalid_float_value(self): 9127db96d56Sopenharmony_ci self.assertParseFail(["-p", "1.0", "2x", "3.5"], 9137db96d56Sopenharmony_ci "option -p: " 9147db96d56Sopenharmony_ci "invalid floating-point value: '2x'") 9157db96d56Sopenharmony_ci 9167db96d56Sopenharmony_ci def test_nargs_required_values(self): 9177db96d56Sopenharmony_ci self.assertParseFail(["--point", "1.0", "3.5"], 9187db96d56Sopenharmony_ci "--point option requires 3 arguments") 9197db96d56Sopenharmony_ci 9207db96d56Sopenharmony_ciclass TestMultipleArgsAppend(BaseTest): 9217db96d56Sopenharmony_ci def setUp(self): 9227db96d56Sopenharmony_ci self.parser = InterceptingOptionParser(usage=SUPPRESS_USAGE) 9237db96d56Sopenharmony_ci self.parser.add_option("-p", "--point", action="store", nargs=3, 9247db96d56Sopenharmony_ci type="float", dest="point") 9257db96d56Sopenharmony_ci self.parser.add_option("-f", "--foo", action="append", nargs=2, 9267db96d56Sopenharmony_ci type="int", dest="foo") 9277db96d56Sopenharmony_ci self.parser.add_option("-z", "--zero", action="append_const", 9287db96d56Sopenharmony_ci dest="foo", const=(0, 0)) 9297db96d56Sopenharmony_ci 9307db96d56Sopenharmony_ci def test_nargs_append(self): 9317db96d56Sopenharmony_ci self.assertParseOK(["-f", "4", "-3", "blah", "--foo", "1", "666"], 9327db96d56Sopenharmony_ci {'point': None, 'foo': [(4, -3), (1, 666)]}, 9337db96d56Sopenharmony_ci ["blah"]) 9347db96d56Sopenharmony_ci 9357db96d56Sopenharmony_ci def test_nargs_append_required_values(self): 9367db96d56Sopenharmony_ci self.assertParseFail(["-f4,3"], 9377db96d56Sopenharmony_ci "-f option requires 2 arguments") 9387db96d56Sopenharmony_ci 9397db96d56Sopenharmony_ci def test_nargs_append_simple(self): 9407db96d56Sopenharmony_ci self.assertParseOK(["--foo=3", "4"], 9417db96d56Sopenharmony_ci {'point': None, 'foo':[(3, 4)]}, 9427db96d56Sopenharmony_ci []) 9437db96d56Sopenharmony_ci 9447db96d56Sopenharmony_ci def test_nargs_append_const(self): 9457db96d56Sopenharmony_ci self.assertParseOK(["--zero", "--foo", "3", "4", "-z"], 9467db96d56Sopenharmony_ci {'point': None, 'foo':[(0, 0), (3, 4), (0, 0)]}, 9477db96d56Sopenharmony_ci []) 9487db96d56Sopenharmony_ci 9497db96d56Sopenharmony_ciclass TestVersion(BaseTest): 9507db96d56Sopenharmony_ci def test_version(self): 9517db96d56Sopenharmony_ci self.parser = InterceptingOptionParser(usage=SUPPRESS_USAGE, 9527db96d56Sopenharmony_ci version="%prog 0.1") 9537db96d56Sopenharmony_ci save_argv = sys.argv[:] 9547db96d56Sopenharmony_ci try: 9557db96d56Sopenharmony_ci sys.argv[0] = os.path.join(os.curdir, "foo", "bar") 9567db96d56Sopenharmony_ci self.assertOutput(["--version"], "bar 0.1\n") 9577db96d56Sopenharmony_ci finally: 9587db96d56Sopenharmony_ci sys.argv[:] = save_argv 9597db96d56Sopenharmony_ci 9607db96d56Sopenharmony_ci def test_no_version(self): 9617db96d56Sopenharmony_ci self.parser = InterceptingOptionParser(usage=SUPPRESS_USAGE) 9627db96d56Sopenharmony_ci self.assertParseFail(["--version"], 9637db96d56Sopenharmony_ci "no such option: --version") 9647db96d56Sopenharmony_ci 9657db96d56Sopenharmony_ci# -- Test conflicting default values and parser.parse_args() ----------- 9667db96d56Sopenharmony_ci 9677db96d56Sopenharmony_ciclass TestConflictingDefaults(BaseTest): 9687db96d56Sopenharmony_ci """Conflicting default values: the last one should win.""" 9697db96d56Sopenharmony_ci def setUp(self): 9707db96d56Sopenharmony_ci self.parser = OptionParser(option_list=[ 9717db96d56Sopenharmony_ci make_option("-v", action="store_true", dest="verbose", default=1)]) 9727db96d56Sopenharmony_ci 9737db96d56Sopenharmony_ci def test_conflict_default(self): 9747db96d56Sopenharmony_ci self.parser.add_option("-q", action="store_false", dest="verbose", 9757db96d56Sopenharmony_ci default=0) 9767db96d56Sopenharmony_ci self.assertParseOK([], {'verbose': 0}, []) 9777db96d56Sopenharmony_ci 9787db96d56Sopenharmony_ci def test_conflict_default_none(self): 9797db96d56Sopenharmony_ci self.parser.add_option("-q", action="store_false", dest="verbose", 9807db96d56Sopenharmony_ci default=None) 9817db96d56Sopenharmony_ci self.assertParseOK([], {'verbose': None}, []) 9827db96d56Sopenharmony_ci 9837db96d56Sopenharmony_ciclass TestOptionGroup(BaseTest): 9847db96d56Sopenharmony_ci def setUp(self): 9857db96d56Sopenharmony_ci self.parser = OptionParser(usage=SUPPRESS_USAGE) 9867db96d56Sopenharmony_ci 9877db96d56Sopenharmony_ci def test_option_group_create_instance(self): 9887db96d56Sopenharmony_ci group = OptionGroup(self.parser, "Spam") 9897db96d56Sopenharmony_ci self.parser.add_option_group(group) 9907db96d56Sopenharmony_ci group.add_option("--spam", action="store_true", 9917db96d56Sopenharmony_ci help="spam spam spam spam") 9927db96d56Sopenharmony_ci self.assertParseOK(["--spam"], {'spam': 1}, []) 9937db96d56Sopenharmony_ci 9947db96d56Sopenharmony_ci def test_add_group_no_group(self): 9957db96d56Sopenharmony_ci self.assertTypeError(self.parser.add_option_group, 9967db96d56Sopenharmony_ci "not an OptionGroup instance: None", None) 9977db96d56Sopenharmony_ci 9987db96d56Sopenharmony_ci def test_add_group_invalid_arguments(self): 9997db96d56Sopenharmony_ci self.assertTypeError(self.parser.add_option_group, 10007db96d56Sopenharmony_ci "invalid arguments", None, None) 10017db96d56Sopenharmony_ci 10027db96d56Sopenharmony_ci def test_add_group_wrong_parser(self): 10037db96d56Sopenharmony_ci group = OptionGroup(self.parser, "Spam") 10047db96d56Sopenharmony_ci group.parser = OptionParser() 10057db96d56Sopenharmony_ci self.assertRaises(self.parser.add_option_group, (group,), None, 10067db96d56Sopenharmony_ci ValueError, "invalid OptionGroup (wrong parser)") 10077db96d56Sopenharmony_ci 10087db96d56Sopenharmony_ci def test_group_manipulate(self): 10097db96d56Sopenharmony_ci group = self.parser.add_option_group("Group 2", 10107db96d56Sopenharmony_ci description="Some more options") 10117db96d56Sopenharmony_ci group.set_title("Bacon") 10127db96d56Sopenharmony_ci group.add_option("--bacon", type="int") 10137db96d56Sopenharmony_ci self.assertTrue(self.parser.get_option_group("--bacon"), group) 10147db96d56Sopenharmony_ci 10157db96d56Sopenharmony_ci# -- Test extending and parser.parse_args() ---------------------------- 10167db96d56Sopenharmony_ci 10177db96d56Sopenharmony_ciclass TestExtendAddTypes(BaseTest): 10187db96d56Sopenharmony_ci def setUp(self): 10197db96d56Sopenharmony_ci self.parser = InterceptingOptionParser(usage=SUPPRESS_USAGE, 10207db96d56Sopenharmony_ci option_class=self.MyOption) 10217db96d56Sopenharmony_ci self.parser.add_option("-a", None, type="string", dest="a") 10227db96d56Sopenharmony_ci self.parser.add_option("-f", "--file", type="file", dest="file") 10237db96d56Sopenharmony_ci 10247db96d56Sopenharmony_ci def tearDown(self): 10257db96d56Sopenharmony_ci if os.path.isdir(os_helper.TESTFN): 10267db96d56Sopenharmony_ci os.rmdir(os_helper.TESTFN) 10277db96d56Sopenharmony_ci elif os.path.isfile(os_helper.TESTFN): 10287db96d56Sopenharmony_ci os.unlink(os_helper.TESTFN) 10297db96d56Sopenharmony_ci 10307db96d56Sopenharmony_ci class MyOption (Option): 10317db96d56Sopenharmony_ci def check_file(option, opt, value): 10327db96d56Sopenharmony_ci if not os.path.exists(value): 10337db96d56Sopenharmony_ci raise OptionValueError("%s: file does not exist" % value) 10347db96d56Sopenharmony_ci elif not os.path.isfile(value): 10357db96d56Sopenharmony_ci raise OptionValueError("%s: not a regular file" % value) 10367db96d56Sopenharmony_ci return value 10377db96d56Sopenharmony_ci 10387db96d56Sopenharmony_ci TYPES = Option.TYPES + ("file",) 10397db96d56Sopenharmony_ci TYPE_CHECKER = copy.copy(Option.TYPE_CHECKER) 10407db96d56Sopenharmony_ci TYPE_CHECKER["file"] = check_file 10417db96d56Sopenharmony_ci 10427db96d56Sopenharmony_ci def test_filetype_ok(self): 10437db96d56Sopenharmony_ci os_helper.create_empty_file(os_helper.TESTFN) 10447db96d56Sopenharmony_ci self.assertParseOK(["--file", os_helper.TESTFN, "-afoo"], 10457db96d56Sopenharmony_ci {'file': os_helper.TESTFN, 'a': 'foo'}, 10467db96d56Sopenharmony_ci []) 10477db96d56Sopenharmony_ci 10487db96d56Sopenharmony_ci def test_filetype_noexist(self): 10497db96d56Sopenharmony_ci self.assertParseFail(["--file", os_helper.TESTFN, "-afoo"], 10507db96d56Sopenharmony_ci "%s: file does not exist" % 10517db96d56Sopenharmony_ci os_helper.TESTFN) 10527db96d56Sopenharmony_ci 10537db96d56Sopenharmony_ci def test_filetype_notfile(self): 10547db96d56Sopenharmony_ci os.mkdir(os_helper.TESTFN) 10557db96d56Sopenharmony_ci self.assertParseFail(["--file", os_helper.TESTFN, "-afoo"], 10567db96d56Sopenharmony_ci "%s: not a regular file" % 10577db96d56Sopenharmony_ci os_helper.TESTFN) 10587db96d56Sopenharmony_ci 10597db96d56Sopenharmony_ci 10607db96d56Sopenharmony_ciclass TestExtendAddActions(BaseTest): 10617db96d56Sopenharmony_ci def setUp(self): 10627db96d56Sopenharmony_ci options = [self.MyOption("-a", "--apple", action="extend", 10637db96d56Sopenharmony_ci type="string", dest="apple")] 10647db96d56Sopenharmony_ci self.parser = OptionParser(option_list=options) 10657db96d56Sopenharmony_ci 10667db96d56Sopenharmony_ci class MyOption (Option): 10677db96d56Sopenharmony_ci ACTIONS = Option.ACTIONS + ("extend",) 10687db96d56Sopenharmony_ci STORE_ACTIONS = Option.STORE_ACTIONS + ("extend",) 10697db96d56Sopenharmony_ci TYPED_ACTIONS = Option.TYPED_ACTIONS + ("extend",) 10707db96d56Sopenharmony_ci 10717db96d56Sopenharmony_ci def take_action(self, action, dest, opt, value, values, parser): 10727db96d56Sopenharmony_ci if action == "extend": 10737db96d56Sopenharmony_ci lvalue = value.split(",") 10747db96d56Sopenharmony_ci values.ensure_value(dest, []).extend(lvalue) 10757db96d56Sopenharmony_ci else: 10767db96d56Sopenharmony_ci Option.take_action(self, action, dest, opt, parser, value, 10777db96d56Sopenharmony_ci values) 10787db96d56Sopenharmony_ci 10797db96d56Sopenharmony_ci def test_extend_add_action(self): 10807db96d56Sopenharmony_ci self.assertParseOK(["-afoo,bar", "--apple=blah"], 10817db96d56Sopenharmony_ci {'apple': ["foo", "bar", "blah"]}, 10827db96d56Sopenharmony_ci []) 10837db96d56Sopenharmony_ci 10847db96d56Sopenharmony_ci def test_extend_add_action_normal(self): 10857db96d56Sopenharmony_ci self.assertParseOK(["-a", "foo", "-abar", "--apple=x,y"], 10867db96d56Sopenharmony_ci {'apple': ["foo", "bar", "x", "y"]}, 10877db96d56Sopenharmony_ci []) 10887db96d56Sopenharmony_ci 10897db96d56Sopenharmony_ci# -- Test callbacks and parser.parse_args() ---------------------------- 10907db96d56Sopenharmony_ci 10917db96d56Sopenharmony_ciclass TestCallback(BaseTest): 10927db96d56Sopenharmony_ci def setUp(self): 10937db96d56Sopenharmony_ci options = [make_option("-x", 10947db96d56Sopenharmony_ci None, 10957db96d56Sopenharmony_ci action="callback", 10967db96d56Sopenharmony_ci callback=self.process_opt), 10977db96d56Sopenharmony_ci make_option("-f", 10987db96d56Sopenharmony_ci "--file", 10997db96d56Sopenharmony_ci action="callback", 11007db96d56Sopenharmony_ci callback=self.process_opt, 11017db96d56Sopenharmony_ci type="string", 11027db96d56Sopenharmony_ci dest="filename")] 11037db96d56Sopenharmony_ci self.parser = OptionParser(option_list=options) 11047db96d56Sopenharmony_ci 11057db96d56Sopenharmony_ci def process_opt(self, option, opt, value, parser_): 11067db96d56Sopenharmony_ci if opt == "-x": 11077db96d56Sopenharmony_ci self.assertEqual(option._short_opts, ["-x"]) 11087db96d56Sopenharmony_ci self.assertEqual(option._long_opts, []) 11097db96d56Sopenharmony_ci self.assertTrue(parser_ is self.parser) 11107db96d56Sopenharmony_ci self.assertTrue(value is None) 11117db96d56Sopenharmony_ci self.assertEqual(vars(parser_.values), {'filename': None}) 11127db96d56Sopenharmony_ci 11137db96d56Sopenharmony_ci parser_.values.x = 42 11147db96d56Sopenharmony_ci elif opt == "--file": 11157db96d56Sopenharmony_ci self.assertEqual(option._short_opts, ["-f"]) 11167db96d56Sopenharmony_ci self.assertEqual(option._long_opts, ["--file"]) 11177db96d56Sopenharmony_ci self.assertTrue(parser_ is self.parser) 11187db96d56Sopenharmony_ci self.assertEqual(value, "foo") 11197db96d56Sopenharmony_ci self.assertEqual(vars(parser_.values), {'filename': None, 'x': 42}) 11207db96d56Sopenharmony_ci 11217db96d56Sopenharmony_ci setattr(parser_.values, option.dest, value) 11227db96d56Sopenharmony_ci else: 11237db96d56Sopenharmony_ci self.fail("Unknown option %r in process_opt." % opt) 11247db96d56Sopenharmony_ci 11257db96d56Sopenharmony_ci def test_callback(self): 11267db96d56Sopenharmony_ci self.assertParseOK(["-x", "--file=foo"], 11277db96d56Sopenharmony_ci {'filename': "foo", 'x': 42}, 11287db96d56Sopenharmony_ci []) 11297db96d56Sopenharmony_ci 11307db96d56Sopenharmony_ci def test_callback_help(self): 11317db96d56Sopenharmony_ci # This test was prompted by SF bug #960515 -- the point is 11327db96d56Sopenharmony_ci # not to inspect the help text, just to make sure that 11337db96d56Sopenharmony_ci # format_help() doesn't crash. 11347db96d56Sopenharmony_ci parser = OptionParser(usage=SUPPRESS_USAGE) 11357db96d56Sopenharmony_ci parser.remove_option("-h") 11367db96d56Sopenharmony_ci parser.add_option("-t", "--test", action="callback", 11377db96d56Sopenharmony_ci callback=lambda: None, type="string", 11387db96d56Sopenharmony_ci help="foo") 11397db96d56Sopenharmony_ci 11407db96d56Sopenharmony_ci expected_help = ("Options:\n" 11417db96d56Sopenharmony_ci " -t TEST, --test=TEST foo\n") 11427db96d56Sopenharmony_ci self.assertHelp(parser, expected_help) 11437db96d56Sopenharmony_ci 11447db96d56Sopenharmony_ci 11457db96d56Sopenharmony_ciclass TestCallbackExtraArgs(BaseTest): 11467db96d56Sopenharmony_ci def setUp(self): 11477db96d56Sopenharmony_ci options = [make_option("-p", "--point", action="callback", 11487db96d56Sopenharmony_ci callback=self.process_tuple, 11497db96d56Sopenharmony_ci callback_args=(3, int), type="string", 11507db96d56Sopenharmony_ci dest="points", default=[])] 11517db96d56Sopenharmony_ci self.parser = OptionParser(option_list=options) 11527db96d56Sopenharmony_ci 11537db96d56Sopenharmony_ci def process_tuple(self, option, opt, value, parser_, len, type): 11547db96d56Sopenharmony_ci self.assertEqual(len, 3) 11557db96d56Sopenharmony_ci self.assertTrue(type is int) 11567db96d56Sopenharmony_ci 11577db96d56Sopenharmony_ci if opt == "-p": 11587db96d56Sopenharmony_ci self.assertEqual(value, "1,2,3") 11597db96d56Sopenharmony_ci elif opt == "--point": 11607db96d56Sopenharmony_ci self.assertEqual(value, "4,5,6") 11617db96d56Sopenharmony_ci 11627db96d56Sopenharmony_ci value = tuple(map(type, value.split(","))) 11637db96d56Sopenharmony_ci getattr(parser_.values, option.dest).append(value) 11647db96d56Sopenharmony_ci 11657db96d56Sopenharmony_ci def test_callback_extra_args(self): 11667db96d56Sopenharmony_ci self.assertParseOK(["-p1,2,3", "--point", "4,5,6"], 11677db96d56Sopenharmony_ci {'points': [(1,2,3), (4,5,6)]}, 11687db96d56Sopenharmony_ci []) 11697db96d56Sopenharmony_ci 11707db96d56Sopenharmony_ciclass TestCallbackMeddleArgs(BaseTest): 11717db96d56Sopenharmony_ci def setUp(self): 11727db96d56Sopenharmony_ci options = [make_option(str(x), action="callback", 11737db96d56Sopenharmony_ci callback=self.process_n, dest='things') 11747db96d56Sopenharmony_ci for x in range(-1, -6, -1)] 11757db96d56Sopenharmony_ci self.parser = OptionParser(option_list=options) 11767db96d56Sopenharmony_ci 11777db96d56Sopenharmony_ci # Callback that meddles in rargs, largs 11787db96d56Sopenharmony_ci def process_n(self, option, opt, value, parser_): 11797db96d56Sopenharmony_ci # option is -3, -5, etc. 11807db96d56Sopenharmony_ci nargs = int(opt[1:]) 11817db96d56Sopenharmony_ci rargs = parser_.rargs 11827db96d56Sopenharmony_ci if len(rargs) < nargs: 11837db96d56Sopenharmony_ci self.fail("Expected %d arguments for %s option." % (nargs, opt)) 11847db96d56Sopenharmony_ci dest = parser_.values.ensure_value(option.dest, []) 11857db96d56Sopenharmony_ci dest.append(tuple(rargs[0:nargs])) 11867db96d56Sopenharmony_ci parser_.largs.append(nargs) 11877db96d56Sopenharmony_ci del rargs[0:nargs] 11887db96d56Sopenharmony_ci 11897db96d56Sopenharmony_ci def test_callback_meddle_args(self): 11907db96d56Sopenharmony_ci self.assertParseOK(["-1", "foo", "-3", "bar", "baz", "qux"], 11917db96d56Sopenharmony_ci {'things': [("foo",), ("bar", "baz", "qux")]}, 11927db96d56Sopenharmony_ci [1, 3]) 11937db96d56Sopenharmony_ci 11947db96d56Sopenharmony_ci def test_callback_meddle_args_separator(self): 11957db96d56Sopenharmony_ci self.assertParseOK(["-2", "foo", "--"], 11967db96d56Sopenharmony_ci {'things': [('foo', '--')]}, 11977db96d56Sopenharmony_ci [2]) 11987db96d56Sopenharmony_ci 11997db96d56Sopenharmony_ciclass TestCallbackManyArgs(BaseTest): 12007db96d56Sopenharmony_ci def setUp(self): 12017db96d56Sopenharmony_ci options = [make_option("-a", "--apple", action="callback", nargs=2, 12027db96d56Sopenharmony_ci callback=self.process_many, type="string"), 12037db96d56Sopenharmony_ci make_option("-b", "--bob", action="callback", nargs=3, 12047db96d56Sopenharmony_ci callback=self.process_many, type="int")] 12057db96d56Sopenharmony_ci self.parser = OptionParser(option_list=options) 12067db96d56Sopenharmony_ci 12077db96d56Sopenharmony_ci def process_many(self, option, opt, value, parser_): 12087db96d56Sopenharmony_ci if opt == "-a": 12097db96d56Sopenharmony_ci self.assertEqual(value, ("foo", "bar")) 12107db96d56Sopenharmony_ci elif opt == "--apple": 12117db96d56Sopenharmony_ci self.assertEqual(value, ("ding", "dong")) 12127db96d56Sopenharmony_ci elif opt == "-b": 12137db96d56Sopenharmony_ci self.assertEqual(value, (1, 2, 3)) 12147db96d56Sopenharmony_ci elif opt == "--bob": 12157db96d56Sopenharmony_ci self.assertEqual(value, (-666, 42, 0)) 12167db96d56Sopenharmony_ci 12177db96d56Sopenharmony_ci def test_many_args(self): 12187db96d56Sopenharmony_ci self.assertParseOK(["-a", "foo", "bar", "--apple", "ding", "dong", 12197db96d56Sopenharmony_ci "-b", "1", "2", "3", "--bob", "-666", "42", 12207db96d56Sopenharmony_ci "0"], 12217db96d56Sopenharmony_ci {"apple": None, "bob": None}, 12227db96d56Sopenharmony_ci []) 12237db96d56Sopenharmony_ci 12247db96d56Sopenharmony_ciclass TestCallbackCheckAbbrev(BaseTest): 12257db96d56Sopenharmony_ci def setUp(self): 12267db96d56Sopenharmony_ci self.parser = OptionParser() 12277db96d56Sopenharmony_ci self.parser.add_option("--foo-bar", action="callback", 12287db96d56Sopenharmony_ci callback=self.check_abbrev) 12297db96d56Sopenharmony_ci 12307db96d56Sopenharmony_ci def check_abbrev(self, option, opt, value, parser): 12317db96d56Sopenharmony_ci self.assertEqual(opt, "--foo-bar") 12327db96d56Sopenharmony_ci 12337db96d56Sopenharmony_ci def test_abbrev_callback_expansion(self): 12347db96d56Sopenharmony_ci self.assertParseOK(["--foo"], {}, []) 12357db96d56Sopenharmony_ci 12367db96d56Sopenharmony_ciclass TestCallbackVarArgs(BaseTest): 12377db96d56Sopenharmony_ci def setUp(self): 12387db96d56Sopenharmony_ci options = [make_option("-a", type="int", nargs=2, dest="a"), 12397db96d56Sopenharmony_ci make_option("-b", action="store_true", dest="b"), 12407db96d56Sopenharmony_ci make_option("-c", "--callback", action="callback", 12417db96d56Sopenharmony_ci callback=self.variable_args, dest="c")] 12427db96d56Sopenharmony_ci self.parser = InterceptingOptionParser(usage=SUPPRESS_USAGE, 12437db96d56Sopenharmony_ci option_list=options) 12447db96d56Sopenharmony_ci 12457db96d56Sopenharmony_ci def variable_args(self, option, opt, value, parser): 12467db96d56Sopenharmony_ci self.assertTrue(value is None) 12477db96d56Sopenharmony_ci value = [] 12487db96d56Sopenharmony_ci rargs = parser.rargs 12497db96d56Sopenharmony_ci while rargs: 12507db96d56Sopenharmony_ci arg = rargs[0] 12517db96d56Sopenharmony_ci if ((arg[:2] == "--" and len(arg) > 2) or 12527db96d56Sopenharmony_ci (arg[:1] == "-" and len(arg) > 1 and arg[1] != "-")): 12537db96d56Sopenharmony_ci break 12547db96d56Sopenharmony_ci else: 12557db96d56Sopenharmony_ci value.append(arg) 12567db96d56Sopenharmony_ci del rargs[0] 12577db96d56Sopenharmony_ci setattr(parser.values, option.dest, value) 12587db96d56Sopenharmony_ci 12597db96d56Sopenharmony_ci def test_variable_args(self): 12607db96d56Sopenharmony_ci self.assertParseOK(["-a3", "-5", "--callback", "foo", "bar"], 12617db96d56Sopenharmony_ci {'a': (3, -5), 'b': None, 'c': ["foo", "bar"]}, 12627db96d56Sopenharmony_ci []) 12637db96d56Sopenharmony_ci 12647db96d56Sopenharmony_ci def test_consume_separator_stop_at_option(self): 12657db96d56Sopenharmony_ci self.assertParseOK(["-c", "37", "--", "xxx", "-b", "hello"], 12667db96d56Sopenharmony_ci {'a': None, 12677db96d56Sopenharmony_ci 'b': True, 12687db96d56Sopenharmony_ci 'c': ["37", "--", "xxx"]}, 12697db96d56Sopenharmony_ci ["hello"]) 12707db96d56Sopenharmony_ci 12717db96d56Sopenharmony_ci def test_positional_arg_and_variable_args(self): 12727db96d56Sopenharmony_ci self.assertParseOK(["hello", "-c", "foo", "-", "bar"], 12737db96d56Sopenharmony_ci {'a': None, 12747db96d56Sopenharmony_ci 'b': None, 12757db96d56Sopenharmony_ci 'c':["foo", "-", "bar"]}, 12767db96d56Sopenharmony_ci ["hello"]) 12777db96d56Sopenharmony_ci 12787db96d56Sopenharmony_ci def test_stop_at_option(self): 12797db96d56Sopenharmony_ci self.assertParseOK(["-c", "foo", "-b"], 12807db96d56Sopenharmony_ci {'a': None, 'b': True, 'c': ["foo"]}, 12817db96d56Sopenharmony_ci []) 12827db96d56Sopenharmony_ci 12837db96d56Sopenharmony_ci def test_stop_at_invalid_option(self): 12847db96d56Sopenharmony_ci self.assertParseFail(["-c", "3", "-5", "-a"], "no such option: -5") 12857db96d56Sopenharmony_ci 12867db96d56Sopenharmony_ci 12877db96d56Sopenharmony_ci# -- Test conflict handling and parser.parse_args() -------------------- 12887db96d56Sopenharmony_ci 12897db96d56Sopenharmony_ciclass ConflictBase(BaseTest): 12907db96d56Sopenharmony_ci def setUp(self): 12917db96d56Sopenharmony_ci options = [make_option("-v", "--verbose", action="count", 12927db96d56Sopenharmony_ci dest="verbose", help="increment verbosity")] 12937db96d56Sopenharmony_ci self.parser = InterceptingOptionParser(usage=SUPPRESS_USAGE, 12947db96d56Sopenharmony_ci option_list=options) 12957db96d56Sopenharmony_ci 12967db96d56Sopenharmony_ci def show_version(self, option, opt, value, parser): 12977db96d56Sopenharmony_ci parser.values.show_version = 1 12987db96d56Sopenharmony_ci 12997db96d56Sopenharmony_ciclass TestConflict(ConflictBase): 13007db96d56Sopenharmony_ci """Use the default conflict resolution for Optik 1.2: error.""" 13017db96d56Sopenharmony_ci def assertTrueconflict_error(self, func): 13027db96d56Sopenharmony_ci err = self.assertRaises( 13037db96d56Sopenharmony_ci func, ("-v", "--version"), {'action' : "callback", 13047db96d56Sopenharmony_ci 'callback' : self.show_version, 13057db96d56Sopenharmony_ci 'help' : "show version"}, 13067db96d56Sopenharmony_ci OptionConflictError, 13077db96d56Sopenharmony_ci "option -v/--version: conflicting option string(s): -v") 13087db96d56Sopenharmony_ci 13097db96d56Sopenharmony_ci self.assertEqual(err.msg, "conflicting option string(s): -v") 13107db96d56Sopenharmony_ci self.assertEqual(err.option_id, "-v/--version") 13117db96d56Sopenharmony_ci 13127db96d56Sopenharmony_ci def test_conflict_error(self): 13137db96d56Sopenharmony_ci self.assertTrueconflict_error(self.parser.add_option) 13147db96d56Sopenharmony_ci 13157db96d56Sopenharmony_ci def test_conflict_error_group(self): 13167db96d56Sopenharmony_ci group = OptionGroup(self.parser, "Group 1") 13177db96d56Sopenharmony_ci self.assertTrueconflict_error(group.add_option) 13187db96d56Sopenharmony_ci 13197db96d56Sopenharmony_ci def test_no_such_conflict_handler(self): 13207db96d56Sopenharmony_ci self.assertRaises( 13217db96d56Sopenharmony_ci self.parser.set_conflict_handler, ('foo',), None, 13227db96d56Sopenharmony_ci ValueError, "invalid conflict_resolution value 'foo'") 13237db96d56Sopenharmony_ci 13247db96d56Sopenharmony_ci 13257db96d56Sopenharmony_ciclass TestConflictResolve(ConflictBase): 13267db96d56Sopenharmony_ci def setUp(self): 13277db96d56Sopenharmony_ci ConflictBase.setUp(self) 13287db96d56Sopenharmony_ci self.parser.set_conflict_handler("resolve") 13297db96d56Sopenharmony_ci self.parser.add_option("-v", "--version", action="callback", 13307db96d56Sopenharmony_ci callback=self.show_version, help="show version") 13317db96d56Sopenharmony_ci 13327db96d56Sopenharmony_ci def test_conflict_resolve(self): 13337db96d56Sopenharmony_ci v_opt = self.parser.get_option("-v") 13347db96d56Sopenharmony_ci verbose_opt = self.parser.get_option("--verbose") 13357db96d56Sopenharmony_ci version_opt = self.parser.get_option("--version") 13367db96d56Sopenharmony_ci 13377db96d56Sopenharmony_ci self.assertTrue(v_opt is version_opt) 13387db96d56Sopenharmony_ci self.assertTrue(v_opt is not verbose_opt) 13397db96d56Sopenharmony_ci self.assertEqual(v_opt._long_opts, ["--version"]) 13407db96d56Sopenharmony_ci self.assertEqual(version_opt._short_opts, ["-v"]) 13417db96d56Sopenharmony_ci self.assertEqual(version_opt._long_opts, ["--version"]) 13427db96d56Sopenharmony_ci self.assertEqual(verbose_opt._short_opts, []) 13437db96d56Sopenharmony_ci self.assertEqual(verbose_opt._long_opts, ["--verbose"]) 13447db96d56Sopenharmony_ci 13457db96d56Sopenharmony_ci def test_conflict_resolve_help(self): 13467db96d56Sopenharmony_ci self.assertOutput(["-h"], """\ 13477db96d56Sopenharmony_ciOptions: 13487db96d56Sopenharmony_ci --verbose increment verbosity 13497db96d56Sopenharmony_ci -h, --help show this help message and exit 13507db96d56Sopenharmony_ci -v, --version show version 13517db96d56Sopenharmony_ci""") 13527db96d56Sopenharmony_ci 13537db96d56Sopenharmony_ci def test_conflict_resolve_short_opt(self): 13547db96d56Sopenharmony_ci self.assertParseOK(["-v"], 13557db96d56Sopenharmony_ci {'verbose': None, 'show_version': 1}, 13567db96d56Sopenharmony_ci []) 13577db96d56Sopenharmony_ci 13587db96d56Sopenharmony_ci def test_conflict_resolve_long_opt(self): 13597db96d56Sopenharmony_ci self.assertParseOK(["--verbose"], 13607db96d56Sopenharmony_ci {'verbose': 1}, 13617db96d56Sopenharmony_ci []) 13627db96d56Sopenharmony_ci 13637db96d56Sopenharmony_ci def test_conflict_resolve_long_opts(self): 13647db96d56Sopenharmony_ci self.assertParseOK(["--verbose", "--version"], 13657db96d56Sopenharmony_ci {'verbose': 1, 'show_version': 1}, 13667db96d56Sopenharmony_ci []) 13677db96d56Sopenharmony_ci 13687db96d56Sopenharmony_ciclass TestConflictOverride(BaseTest): 13697db96d56Sopenharmony_ci def setUp(self): 13707db96d56Sopenharmony_ci self.parser = InterceptingOptionParser(usage=SUPPRESS_USAGE) 13717db96d56Sopenharmony_ci self.parser.set_conflict_handler("resolve") 13727db96d56Sopenharmony_ci self.parser.add_option("-n", "--dry-run", 13737db96d56Sopenharmony_ci action="store_true", dest="dry_run", 13747db96d56Sopenharmony_ci help="don't do anything") 13757db96d56Sopenharmony_ci self.parser.add_option("--dry-run", "-n", 13767db96d56Sopenharmony_ci action="store_const", const=42, dest="dry_run", 13777db96d56Sopenharmony_ci help="dry run mode") 13787db96d56Sopenharmony_ci 13797db96d56Sopenharmony_ci def test_conflict_override_opts(self): 13807db96d56Sopenharmony_ci opt = self.parser.get_option("--dry-run") 13817db96d56Sopenharmony_ci self.assertEqual(opt._short_opts, ["-n"]) 13827db96d56Sopenharmony_ci self.assertEqual(opt._long_opts, ["--dry-run"]) 13837db96d56Sopenharmony_ci 13847db96d56Sopenharmony_ci def test_conflict_override_help(self): 13857db96d56Sopenharmony_ci self.assertOutput(["-h"], """\ 13867db96d56Sopenharmony_ciOptions: 13877db96d56Sopenharmony_ci -h, --help show this help message and exit 13887db96d56Sopenharmony_ci -n, --dry-run dry run mode 13897db96d56Sopenharmony_ci""") 13907db96d56Sopenharmony_ci 13917db96d56Sopenharmony_ci def test_conflict_override_args(self): 13927db96d56Sopenharmony_ci self.assertParseOK(["-n"], 13937db96d56Sopenharmony_ci {'dry_run': 42}, 13947db96d56Sopenharmony_ci []) 13957db96d56Sopenharmony_ci 13967db96d56Sopenharmony_ci# -- Other testing. ---------------------------------------------------- 13977db96d56Sopenharmony_ci 13987db96d56Sopenharmony_ci_expected_help_basic = """\ 13997db96d56Sopenharmony_ciUsage: bar.py [options] 14007db96d56Sopenharmony_ci 14017db96d56Sopenharmony_ciOptions: 14027db96d56Sopenharmony_ci -a APPLE throw APPLEs at basket 14037db96d56Sopenharmony_ci -b NUM, --boo=NUM shout "boo!" NUM times (in order to frighten away all the 14047db96d56Sopenharmony_ci evil spirits that cause trouble and mayhem) 14057db96d56Sopenharmony_ci --foo=FOO store FOO in the foo list for later fooing 14067db96d56Sopenharmony_ci -h, --help show this help message and exit 14077db96d56Sopenharmony_ci""" 14087db96d56Sopenharmony_ci 14097db96d56Sopenharmony_ci_expected_help_long_opts_first = """\ 14107db96d56Sopenharmony_ciUsage: bar.py [options] 14117db96d56Sopenharmony_ci 14127db96d56Sopenharmony_ciOptions: 14137db96d56Sopenharmony_ci -a APPLE throw APPLEs at basket 14147db96d56Sopenharmony_ci --boo=NUM, -b NUM shout "boo!" NUM times (in order to frighten away all the 14157db96d56Sopenharmony_ci evil spirits that cause trouble and mayhem) 14167db96d56Sopenharmony_ci --foo=FOO store FOO in the foo list for later fooing 14177db96d56Sopenharmony_ci --help, -h show this help message and exit 14187db96d56Sopenharmony_ci""" 14197db96d56Sopenharmony_ci 14207db96d56Sopenharmony_ci_expected_help_title_formatter = """\ 14217db96d56Sopenharmony_ciUsage 14227db96d56Sopenharmony_ci===== 14237db96d56Sopenharmony_ci bar.py [options] 14247db96d56Sopenharmony_ci 14257db96d56Sopenharmony_ciOptions 14267db96d56Sopenharmony_ci======= 14277db96d56Sopenharmony_ci-a APPLE throw APPLEs at basket 14287db96d56Sopenharmony_ci--boo=NUM, -b NUM shout "boo!" NUM times (in order to frighten away all the 14297db96d56Sopenharmony_ci evil spirits that cause trouble and mayhem) 14307db96d56Sopenharmony_ci--foo=FOO store FOO in the foo list for later fooing 14317db96d56Sopenharmony_ci--help, -h show this help message and exit 14327db96d56Sopenharmony_ci""" 14337db96d56Sopenharmony_ci 14347db96d56Sopenharmony_ci_expected_help_short_lines = """\ 14357db96d56Sopenharmony_ciUsage: bar.py [options] 14367db96d56Sopenharmony_ci 14377db96d56Sopenharmony_ciOptions: 14387db96d56Sopenharmony_ci -a APPLE throw APPLEs at basket 14397db96d56Sopenharmony_ci -b NUM, --boo=NUM shout "boo!" NUM times (in order to 14407db96d56Sopenharmony_ci frighten away all the evil spirits 14417db96d56Sopenharmony_ci that cause trouble and mayhem) 14427db96d56Sopenharmony_ci --foo=FOO store FOO in the foo list for later 14437db96d56Sopenharmony_ci fooing 14447db96d56Sopenharmony_ci -h, --help show this help message and exit 14457db96d56Sopenharmony_ci""" 14467db96d56Sopenharmony_ci 14477db96d56Sopenharmony_ci_expected_very_help_short_lines = """\ 14487db96d56Sopenharmony_ciUsage: bar.py [options] 14497db96d56Sopenharmony_ci 14507db96d56Sopenharmony_ciOptions: 14517db96d56Sopenharmony_ci -a APPLE 14527db96d56Sopenharmony_ci throw 14537db96d56Sopenharmony_ci APPLEs at 14547db96d56Sopenharmony_ci basket 14557db96d56Sopenharmony_ci -b NUM, --boo=NUM 14567db96d56Sopenharmony_ci shout 14577db96d56Sopenharmony_ci "boo!" NUM 14587db96d56Sopenharmony_ci times (in 14597db96d56Sopenharmony_ci order to 14607db96d56Sopenharmony_ci frighten 14617db96d56Sopenharmony_ci away all 14627db96d56Sopenharmony_ci the evil 14637db96d56Sopenharmony_ci spirits 14647db96d56Sopenharmony_ci that cause 14657db96d56Sopenharmony_ci trouble and 14667db96d56Sopenharmony_ci mayhem) 14677db96d56Sopenharmony_ci --foo=FOO 14687db96d56Sopenharmony_ci store FOO 14697db96d56Sopenharmony_ci in the foo 14707db96d56Sopenharmony_ci list for 14717db96d56Sopenharmony_ci later 14727db96d56Sopenharmony_ci fooing 14737db96d56Sopenharmony_ci -h, --help 14747db96d56Sopenharmony_ci show this 14757db96d56Sopenharmony_ci help 14767db96d56Sopenharmony_ci message and 14777db96d56Sopenharmony_ci exit 14787db96d56Sopenharmony_ci""" 14797db96d56Sopenharmony_ci 14807db96d56Sopenharmony_ciclass TestHelp(BaseTest): 14817db96d56Sopenharmony_ci def setUp(self): 14827db96d56Sopenharmony_ci self.parser = self.make_parser(80) 14837db96d56Sopenharmony_ci 14847db96d56Sopenharmony_ci def make_parser(self, columns): 14857db96d56Sopenharmony_ci options = [ 14867db96d56Sopenharmony_ci make_option("-a", type="string", dest='a', 14877db96d56Sopenharmony_ci metavar="APPLE", help="throw APPLEs at basket"), 14887db96d56Sopenharmony_ci make_option("-b", "--boo", type="int", dest='boo', 14897db96d56Sopenharmony_ci metavar="NUM", 14907db96d56Sopenharmony_ci help= 14917db96d56Sopenharmony_ci "shout \"boo!\" NUM times (in order to frighten away " 14927db96d56Sopenharmony_ci "all the evil spirits that cause trouble and mayhem)"), 14937db96d56Sopenharmony_ci make_option("--foo", action="append", type="string", dest='foo', 14947db96d56Sopenharmony_ci help="store FOO in the foo list for later fooing"), 14957db96d56Sopenharmony_ci ] 14967db96d56Sopenharmony_ci 14977db96d56Sopenharmony_ci # We need to set COLUMNS for the OptionParser constructor, but 14987db96d56Sopenharmony_ci # we must restore its original value -- otherwise, this test 14997db96d56Sopenharmony_ci # screws things up for other tests when it's part of the Python 15007db96d56Sopenharmony_ci # test suite. 15017db96d56Sopenharmony_ci with os_helper.EnvironmentVarGuard() as env: 15027db96d56Sopenharmony_ci env['COLUMNS'] = str(columns) 15037db96d56Sopenharmony_ci return InterceptingOptionParser(option_list=options) 15047db96d56Sopenharmony_ci 15057db96d56Sopenharmony_ci def assertHelpEquals(self, expected_output): 15067db96d56Sopenharmony_ci save_argv = sys.argv[:] 15077db96d56Sopenharmony_ci try: 15087db96d56Sopenharmony_ci # Make optparse believe bar.py is being executed. 15097db96d56Sopenharmony_ci sys.argv[0] = os.path.join("foo", "bar.py") 15107db96d56Sopenharmony_ci self.assertOutput(["-h"], expected_output) 15117db96d56Sopenharmony_ci finally: 15127db96d56Sopenharmony_ci sys.argv[:] = save_argv 15137db96d56Sopenharmony_ci 15147db96d56Sopenharmony_ci def test_help(self): 15157db96d56Sopenharmony_ci self.assertHelpEquals(_expected_help_basic) 15167db96d56Sopenharmony_ci 15177db96d56Sopenharmony_ci def test_help_old_usage(self): 15187db96d56Sopenharmony_ci self.parser.set_usage("Usage: %prog [options]") 15197db96d56Sopenharmony_ci self.assertHelpEquals(_expected_help_basic) 15207db96d56Sopenharmony_ci 15217db96d56Sopenharmony_ci def test_help_long_opts_first(self): 15227db96d56Sopenharmony_ci self.parser.formatter.short_first = 0 15237db96d56Sopenharmony_ci self.assertHelpEquals(_expected_help_long_opts_first) 15247db96d56Sopenharmony_ci 15257db96d56Sopenharmony_ci def test_help_title_formatter(self): 15267db96d56Sopenharmony_ci with os_helper.EnvironmentVarGuard() as env: 15277db96d56Sopenharmony_ci env["COLUMNS"] = "80" 15287db96d56Sopenharmony_ci self.parser.formatter = TitledHelpFormatter() 15297db96d56Sopenharmony_ci self.assertHelpEquals(_expected_help_title_formatter) 15307db96d56Sopenharmony_ci 15317db96d56Sopenharmony_ci def test_wrap_columns(self): 15327db96d56Sopenharmony_ci # Ensure that wrapping respects $COLUMNS environment variable. 15337db96d56Sopenharmony_ci # Need to reconstruct the parser, since that's the only time 15347db96d56Sopenharmony_ci # we look at $COLUMNS. 15357db96d56Sopenharmony_ci self.parser = self.make_parser(60) 15367db96d56Sopenharmony_ci self.assertHelpEquals(_expected_help_short_lines) 15377db96d56Sopenharmony_ci self.parser = self.make_parser(0) 15387db96d56Sopenharmony_ci self.assertHelpEquals(_expected_very_help_short_lines) 15397db96d56Sopenharmony_ci 15407db96d56Sopenharmony_ci def test_help_unicode(self): 15417db96d56Sopenharmony_ci self.parser = InterceptingOptionParser(usage=SUPPRESS_USAGE) 15427db96d56Sopenharmony_ci self.parser.add_option("-a", action="store_true", help="ol\u00E9!") 15437db96d56Sopenharmony_ci expect = """\ 15447db96d56Sopenharmony_ciOptions: 15457db96d56Sopenharmony_ci -h, --help show this help message and exit 15467db96d56Sopenharmony_ci -a ol\u00E9! 15477db96d56Sopenharmony_ci""" 15487db96d56Sopenharmony_ci self.assertHelpEquals(expect) 15497db96d56Sopenharmony_ci 15507db96d56Sopenharmony_ci def test_help_unicode_description(self): 15517db96d56Sopenharmony_ci self.parser = InterceptingOptionParser(usage=SUPPRESS_USAGE, 15527db96d56Sopenharmony_ci description="ol\u00E9!") 15537db96d56Sopenharmony_ci expect = """\ 15547db96d56Sopenharmony_ciol\u00E9! 15557db96d56Sopenharmony_ci 15567db96d56Sopenharmony_ciOptions: 15577db96d56Sopenharmony_ci -h, --help show this help message and exit 15587db96d56Sopenharmony_ci""" 15597db96d56Sopenharmony_ci self.assertHelpEquals(expect) 15607db96d56Sopenharmony_ci 15617db96d56Sopenharmony_ci def test_help_description_groups(self): 15627db96d56Sopenharmony_ci self.parser.set_description( 15637db96d56Sopenharmony_ci "This is the program description for %prog. %prog has " 15647db96d56Sopenharmony_ci "an option group as well as single options.") 15657db96d56Sopenharmony_ci 15667db96d56Sopenharmony_ci group = OptionGroup( 15677db96d56Sopenharmony_ci self.parser, "Dangerous Options", 15687db96d56Sopenharmony_ci "Caution: use of these options is at your own risk. " 15697db96d56Sopenharmony_ci "It is believed that some of them bite.") 15707db96d56Sopenharmony_ci group.add_option("-g", action="store_true", help="Group option.") 15717db96d56Sopenharmony_ci self.parser.add_option_group(group) 15727db96d56Sopenharmony_ci 15737db96d56Sopenharmony_ci expect = """\ 15747db96d56Sopenharmony_ciUsage: bar.py [options] 15757db96d56Sopenharmony_ci 15767db96d56Sopenharmony_ciThis is the program description for bar.py. bar.py has an option group as 15777db96d56Sopenharmony_ciwell as single options. 15787db96d56Sopenharmony_ci 15797db96d56Sopenharmony_ciOptions: 15807db96d56Sopenharmony_ci -a APPLE throw APPLEs at basket 15817db96d56Sopenharmony_ci -b NUM, --boo=NUM shout "boo!" NUM times (in order to frighten away all the 15827db96d56Sopenharmony_ci evil spirits that cause trouble and mayhem) 15837db96d56Sopenharmony_ci --foo=FOO store FOO in the foo list for later fooing 15847db96d56Sopenharmony_ci -h, --help show this help message and exit 15857db96d56Sopenharmony_ci 15867db96d56Sopenharmony_ci Dangerous Options: 15877db96d56Sopenharmony_ci Caution: use of these options is at your own risk. It is believed 15887db96d56Sopenharmony_ci that some of them bite. 15897db96d56Sopenharmony_ci 15907db96d56Sopenharmony_ci -g Group option. 15917db96d56Sopenharmony_ci""" 15927db96d56Sopenharmony_ci 15937db96d56Sopenharmony_ci self.assertHelpEquals(expect) 15947db96d56Sopenharmony_ci 15957db96d56Sopenharmony_ci self.parser.epilog = "Please report bugs to /dev/null." 15967db96d56Sopenharmony_ci self.assertHelpEquals(expect + "\nPlease report bugs to /dev/null.\n") 15977db96d56Sopenharmony_ci 15987db96d56Sopenharmony_ci 15997db96d56Sopenharmony_ciclass TestMatchAbbrev(BaseTest): 16007db96d56Sopenharmony_ci def test_match_abbrev(self): 16017db96d56Sopenharmony_ci self.assertEqual(_match_abbrev("--f", 16027db96d56Sopenharmony_ci {"--foz": None, 16037db96d56Sopenharmony_ci "--foo": None, 16047db96d56Sopenharmony_ci "--fie": None, 16057db96d56Sopenharmony_ci "--f": None}), 16067db96d56Sopenharmony_ci "--f") 16077db96d56Sopenharmony_ci 16087db96d56Sopenharmony_ci def test_match_abbrev_error(self): 16097db96d56Sopenharmony_ci s = "--f" 16107db96d56Sopenharmony_ci wordmap = {"--foz": None, "--foo": None, "--fie": None} 16117db96d56Sopenharmony_ci self.assertRaises( 16127db96d56Sopenharmony_ci _match_abbrev, (s, wordmap), None, 16137db96d56Sopenharmony_ci BadOptionError, "ambiguous option: --f (--fie, --foo, --foz?)") 16147db96d56Sopenharmony_ci 16157db96d56Sopenharmony_ci 16167db96d56Sopenharmony_ciclass TestParseNumber(BaseTest): 16177db96d56Sopenharmony_ci def setUp(self): 16187db96d56Sopenharmony_ci self.parser = InterceptingOptionParser() 16197db96d56Sopenharmony_ci self.parser.add_option("-n", type=int) 16207db96d56Sopenharmony_ci self.parser.add_option("-l", type=int) 16217db96d56Sopenharmony_ci 16227db96d56Sopenharmony_ci def test_parse_num_fail(self): 16237db96d56Sopenharmony_ci self.assertRaises( 16247db96d56Sopenharmony_ci _parse_num, ("", int), {}, 16257db96d56Sopenharmony_ci ValueError, 16267db96d56Sopenharmony_ci re.compile(r"invalid literal for int().*: '?'?")) 16277db96d56Sopenharmony_ci self.assertRaises( 16287db96d56Sopenharmony_ci _parse_num, ("0xOoops", int), {}, 16297db96d56Sopenharmony_ci ValueError, 16307db96d56Sopenharmony_ci re.compile(r"invalid literal for int().*: s?'?0xOoops'?")) 16317db96d56Sopenharmony_ci 16327db96d56Sopenharmony_ci def test_parse_num_ok(self): 16337db96d56Sopenharmony_ci self.assertEqual(_parse_num("0", int), 0) 16347db96d56Sopenharmony_ci self.assertEqual(_parse_num("0x10", int), 16) 16357db96d56Sopenharmony_ci self.assertEqual(_parse_num("0XA", int), 10) 16367db96d56Sopenharmony_ci self.assertEqual(_parse_num("010", int), 8) 16377db96d56Sopenharmony_ci self.assertEqual(_parse_num("0b11", int), 3) 16387db96d56Sopenharmony_ci self.assertEqual(_parse_num("0b", int), 0) 16397db96d56Sopenharmony_ci 16407db96d56Sopenharmony_ci def test_numeric_options(self): 16417db96d56Sopenharmony_ci self.assertParseOK(["-n", "42", "-l", "0x20"], 16427db96d56Sopenharmony_ci { "n": 42, "l": 0x20 }, []) 16437db96d56Sopenharmony_ci self.assertParseOK(["-n", "0b0101", "-l010"], 16447db96d56Sopenharmony_ci { "n": 5, "l": 8 }, []) 16457db96d56Sopenharmony_ci self.assertParseFail(["-n008"], 16467db96d56Sopenharmony_ci "option -n: invalid integer value: '008'") 16477db96d56Sopenharmony_ci self.assertParseFail(["-l0b0123"], 16487db96d56Sopenharmony_ci "option -l: invalid integer value: '0b0123'") 16497db96d56Sopenharmony_ci self.assertParseFail(["-l", "0x12x"], 16507db96d56Sopenharmony_ci "option -l: invalid integer value: '0x12x'") 16517db96d56Sopenharmony_ci 16527db96d56Sopenharmony_ci 16537db96d56Sopenharmony_ciclass MiscTestCase(unittest.TestCase): 16547db96d56Sopenharmony_ci def test__all__(self): 16557db96d56Sopenharmony_ci not_exported = {'check_builtin', 'AmbiguousOptionError', 'NO_DEFAULT'} 16567db96d56Sopenharmony_ci support.check__all__(self, optparse, not_exported=not_exported) 16577db96d56Sopenharmony_ci 16587db96d56Sopenharmony_ci 16597db96d56Sopenharmony_ciif __name__ == '__main__': 16607db96d56Sopenharmony_ci unittest.main() 1661