Você deve refatorar seu código e mover a análise para uma função:
def parse_args(args):
parser = argparse.ArgumentParser(...)
parser.add_argument...
# ...Create your parser as you like...
return parser.parse_args(args)
Em sua main
função, basta chamá-lo com:
parser = parse_args(sys.argv[1:])
(onde o primeiro elemento sys.argv
que representa o nome do script é removido para não enviá-lo como uma opção adicional durante a operação da CLI.)
Em seus testes, você pode chamar a função analisador com qualquer lista de argumentos com a qual deseja testá-la:
def test_parser(self):
parser = parse_args(['-l', '-m'])
self.assertTrue(parser.long)
# ...and so on.
Dessa forma, você nunca precisará executar o código do seu aplicativo apenas para testar o analisador.
Se você precisar alterar e / ou adicionar opções ao seu analisador posteriormente no seu aplicativo, crie um método de fábrica:
def create_parser():
parser = argparse.ArgumentParser(...)
parser.add_argument...
# ...Create your parser as you like...
return parser
Posteriormente, você pode manipulá-lo, se quiser, e um teste pode se parecer com:
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')