Флаг справки модуля python gflags не работает

У меня проблема с использованием модуля python gflags в моем наборе веб-тестов Selenium. Я в основном следую тому, как пример в репозитории gflags github. Новые флаги, которые я определил через DEFINE_string, работают. Но по умолчанию --help не работает.

Вот мой код:

#!/usr/bin/env python
import datetime
import gflags
import sys
import time
import os
import glob
import unittest
from selenium import webdriver
from pageobject.contact_us_page import ContactUsPage
from pageobject.utility import SendEmailNotification
from selenium.webdriver.support.ui import WebDriverWait
from selenium.webdriver.support import expected_conditions as EC
from selenium.webdriver.common.by import By

FLAGS = gflags.FLAGS
gflags.DEFINE_string('sender_addr', '', 'The Sender of email notification')
gflags.DEFINE_list('receivers_addr', '', 'The list of receivers')
gflags.DEFINE_string('sender_password', '', 'The password of sender email box')


class TestContactUsPage(unittest.TestCase):

    @classmethod
    def setUpClass(cls):
        cls.driver = webdriver.Chrome('../chromedriver')
        cls.cu_page = ContactUsPage(cls.driver)

    @classmethod
    def tearDownClass(cls):
        cls.driver.close()

    def tally(self):
        return len(self._resultForDoCleanups.errors) + len(self._resultForDoCleanups.failures)

    def setUp(self):
        self.errors_and_failures = self.tally()

    def tearDown(self):

        # if sys.exc_info()[0]:
        #     message = 'Test fails with expection: %s' % sys.exc_info()[1]
        #     subject = 'Test fails'
        #     utilityLib.SendEmailResult('[email protected]', '[email protected]',)
        if self.tally() > self.errors_and_failures:
            now = datetime.datetime.now().strftime('%Y-%m-%d_%H:%M:%S')
            self.cu_page.TakeScreenShot('error_' + now)

    def testStep01(self):
        self.cu_page.Open()
        time.sleep(3)
        title = self.driver.title
        self.assertEqual(title, 'Parkside Lending LLC')

    def testStep02(self):
        self.cu_page.GotoPage()
        title_element = WebDriverWait(self.driver, 5).until(EC.presence_of_element_located((
            By.XPATH, '//h1[contains(.,"Contact Us")]')))
        self.cu_page.TakeScreenShot('cupage')
        self.assertEqual(title_element.text, 'Contact Us')

    def testStep03(self):
        self.cu_page.FillContactForm()
        submit_button = self.driver.find_element_by_name('submit')
        submit_button.click()
        self.assertTrue(self.cu_page.SubmitVerification(), 'Contact Form submission Fails, Please check out the '
                                                           'output and screen shot.')

if __name__ == '__main__':
    FLAGS(sys.argv)
    suite = unittest.TestLoader().loadTestsFromTestCase(TestContactUsPage)
    testResult = unittest.TextTestRunner(verbosity=2).run(suite)
    now = datetime.datetime.now().strftime('%Y-%m-%d_%H:%M:%S')
    error_file = max((glob.glob('error_*.png')), key=os.path.getmtime)
    sender = FLAGS.sender_addr
    receipts = FLAGS.receivers_addr
    password = FLAGS.sender_password
    with open('test.out', 'w') as f:

        if testResult.wasSuccessful():
            f.write('%s --- All %s test steps are passed, %s failures and %s errors' % (now, testResult.testsRun,
                    testResult.failures, testResult.errors))
        else:
            f.write('%s --- Test steps are failed.\n' % now)
            if len(testResult.failures):
                for failure in testResult.failures:
                    f.write('Test is failing at: %s\n' % failure[0])
                    f.write(failure[1])
            if len(testResult.errors):
                for error in testResult.errors:
                    f.write('Test has error at: %s\n' % error[0])
                    f.write(error[1])
    with open('test.out', 'r') as f:
        message = f.read()
        if testResult.wasSuccessful():
            subject = 'All Contact Us Page test steps are passed'
        else:
            subject = 'Contact Us Page Test steps are failed.'
            SendEmailNotification().SendEmailResult(
            sender, receipts, message, subject,
            ['cupage.png', error_file]
            , password)

Вот результат, если я использую python contact_us_page_test.py --help, чтобы попытаться получить текст справки.

python contact_us_page_test.py --help

Traceback (most recent call last):
  File "contact_us_page_test.py", line 70, in <module>
    FLAGS(sys.argv)
  File "/usr/local/lib/python2.7/dist-packages/gflags/flagvalues.py", line 708, in __call__
    name, value, suggestions=suggestions)
gflags.exceptions.UnrecognizedFlagError: Unknown command line flag 'help'

person Tianheng Zhou    schedule 13.11.2016    source источник


Ответы (2)


gflags Python не предоставляет флаг --help. Однако объект gflags.FLAGS приводит к полной справке. Используйте это так:

try:
  argv = FLAGS(sys.argv)
except gflags.FlagsError as e:
  print "%s\nUsage: %s ARGS\n%s" % (e, sys.argv[0], FLAGS)
  sys.exit(1)
person szym    schedule 28.02.2017

python-gflags был объединен с спуск-py.

absl предоставляет absl/app.py, который определяет флаги справки . Вы можете структурировать свою программу таким образом:

from absl import app
from absl import flags

FLAGS = flags.FLAGS

def main(argv):
    # Your main program starts here.
    # FLAGS is already parsed.
    pass

if __name__ == '__main__':
    # app.run defines help functions and parses flags,
    # then calls `main` with remaining args.
    app.run(main)
person Yilei Yang    schedule 06.11.2017