Sie sollten Ihren Code umgestalten und die Analyse in eine Funktion verschieben:
def parse_args(args):
parser = argparse.ArgumentParser(...)
parser.add_argument...
# ...Create your parser as you like...
return parser.parse_args(args)
Dann main
sollten Sie es in Ihrer Funktion einfach aufrufen mit:
parser = parse_args(sys.argv[1:])
(wobei das erste Element sys.argv
, das den Skriptnamen darstellt, entfernt wird, um ihn während des CLI-Vorgangs nicht als zusätzlichen Switch zu senden.)
In Ihren Tests können Sie dann die Parser-Funktion mit einer beliebigen Liste von Argumenten aufrufen, mit denen Sie sie testen möchten:
def test_parser(self):
parser = parse_args(['-l', '-m'])
self.assertTrue(parser.long)
# ...and so on.
Auf diese Weise müssen Sie niemals den Code Ihrer Anwendung ausführen, nur um den Parser zu testen.
Wenn Sie später in Ihrer Anwendung Optionen ändern und / oder Optionen zu Ihrem Parser hinzufügen müssen, erstellen Sie eine Factory-Methode:
def create_parser():
parser = argparse.ArgumentParser(...)
parser.add_argument...
# ...Create your parser as you like...
return parser
Sie können es später bearbeiten, wenn Sie möchten, und ein Test könnte folgendermaßen aussehen:
class ParserTest(unittest.TestCase):
def setUp(self):
self.parser = create_parser()
def test_something(self):
parsed = self.parser.parse_args(['--something', 'test'])
self.assertEqual(parsed.something, 'test')