Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 # -*- coding: utf-8 -*- | 1 # -*- coding: utf-8 -*- |
| 2 # Copyright 2014 The Chromium Authors. All rights reserved. | 2 # Copyright 2014 The Chromium Authors. All rights reserved. |
| 3 # Use of this source code is governed by a BSD-style license that can be | 3 # Use of this source code is governed by a BSD-style license that can be |
| 4 # found in the LICENSE file. | 4 # found in the LICENSE file. |
| 5 | 5 |
| 6 """This file allows the bots to be easily configure and run the tests.""" | 6 """This file allows the bots to be easily configure and run the tests.""" |
| 7 | 7 |
| 8 import argparse | 8 import argparse |
| 9 import os | 9 import urllib2 |
|
vabr (Chromium)
2014/07/22 07:54:27
This also needs to be deleted if |response| and }r
rchtara
2014/07/22 12:49:36
Done.
| |
| 10 import tempfile | |
| 11 | 10 |
| 12 from environment import Environment | 11 from environment import Environment |
| 13 import tests | 12 import tests |
| 14 | 13 |
| 15 if __name__ == "__main__": | 14 if __name__ == "__main__": |
| 16 parser = argparse.ArgumentParser( | 15 parser = argparse.ArgumentParser( |
| 17 description="Password Manager automated tests runner help.") | 16 description="Password Manager automated tests runner help.") |
| 18 parser.add_argument( | 17 parser.add_argument( |
| 19 "--chrome-path", action="store", dest="chrome_path", | 18 "--chrome-path", action="store", dest="chrome_path", |
| 20 help="Set the chrome path (required).", nargs=1, required=True) | 19 help="Set the chrome path (required).", nargs=1, required=True) |
| (...skipping 10 matching lines...) Expand all Loading... | |
| 31 "--passwords-path", action="store", dest="passwords_path", | 30 "--passwords-path", action="store", dest="passwords_path", |
| 32 help="Set the usernames/passwords path (required).", nargs=1, | 31 help="Set the usernames/passwords path (required).", nargs=1, |
| 33 required=True) | 32 required=True) |
| 34 parser.add_argument("--save-path", action="store", nargs=1, dest="save_path", | 33 parser.add_argument("--save-path", action="store", nargs=1, dest="save_path", |
| 35 help="Write the results in a file.", required=True) | 34 help="Write the results in a file.", required=True) |
| 36 args = parser.parse_args() | 35 args = parser.parse_args() |
| 37 | 36 |
| 38 environment = Environment('', '', '', None, False) | 37 environment = Environment('', '', '', None, False) |
| 39 tests.Tests(environment) | 38 tests.Tests(environment) |
| 40 | 39 |
| 41 xml = open(args.save_path[0],"w") | 40 xml = "<xml>" |
| 42 xml.write("<xml>") | |
| 43 try: | |
| 44 results = tempfile.NamedTemporaryFile( | |
| 45 dir=os.path.join(tempfile.gettempdir()), delete=False) | |
| 46 results_path = results.name | |
| 47 results.close() | |
| 48 | 41 |
| 49 full_path = os.path.realpath(__file__) | 42 all_successful = True |
| 50 tests_dir = os.path.dirname(full_path) | 43 for websitetest in environment.websitetests: |
| 51 tests_path = os.path.join(tests_dir, "tests.py") | 44 successful = False |
| 45 # The tests can be flaky. This is why we try to rerun up to 3 times. | |
| 46 for x in range(0, 3): | |
| 47 print "Running tests for %s " % websitetest.name | |
|
vabr (Chromium)
2014/07/22 07:54:28
nit: Please add a comment explaining that this mes
rchtara
2014/07/22 12:49:36
Done.
| |
| 52 | 48 |
| 53 for websitetest in environment.websitetests: | 49 # Run the test without enable-automatic-password-saving to check whether |
| 54 # The tests can be flaky. This is why we try to rerun up to 3 times. | 50 # or not the prompt is shown in the way we expected. |
| 55 for x in range(0, 3): | 51 tests_results = tests.RunTests( |
| 56 # TODO(rchtara): Using "pkill" is just temporary until a better, | 52 args.chrome_path[0], |
| 57 # platform-independent solution is found. | 53 args.chromedriver_path[0], |
| 58 os.system("pkill chrome") | 54 args.profile_path[0], |
| 59 try: | 55 args.passwords_path[0], |
| 60 os.remove(results_path) | 56 False, |
| 61 except Exception: | 57 10, # Debug log level. |
| 62 pass | 58 True, |
| 63 # TODO(rchtara): Using "timeout is just temporary until a better, | 59 None, |
| 64 # platform-independent solution is found. | 60 tests.TypeOfTestedWebsites.LIST_OF_TESTS, |
| 61 [websitetest.name]) | |
| 65 | 62 |
| 66 # The website test runs in two passes, each pass has an internal | 63 # Run the test with enable-automatic-password-saving to check whether |
| 67 # timeout of 200s for waiting (see |remaining_time_to_wait| and | 64 # or not the password is stored in the the way we expected. |
| 68 # Wait() in websitetest.py). Accounting for some more time spent on | 65 tests_results += tests.RunTests( |
| 69 # the non-waiting execution, 300 seconds should be the upper bound on | 66 args.chrome_path[0], |
| 70 # the runtime of one pass, thus 600 seconds for the whole test. | 67 args.chromedriver_path[0], |
| 71 os.system("timeout 600 python %s %s --chrome-path %s " | 68 args.profile_path[0], |
| 72 "--chromedriver-path %s --passwords-path %s --profile-path %s " | 69 args.passwords_path[0], |
| 73 "--save-path %s" % | 70 True, |
| 74 (tests_path, websitetest.name, args.chrome_path[0], | 71 10, # Debug log level. |
| 75 args.chromedriver_path[0], args.passwords_path[0], | 72 True, |
| 76 args.profile_path[0], results_path)) | 73 None, |
| 77 if os.path.isfile(results_path): | 74 tests.TypeOfTestedWebsites.LIST_OF_TESTS, |
| 78 results = open(results_path, "r") | 75 [websitetest.name]) |
| 79 count = 0 # Count the number of successful tests. | |
| 80 for line in results: | |
| 81 xml.write(line) | |
| 82 count += line.count("successful='True'") | |
| 83 results.close() | |
| 84 # There is only two tests running for every website: the prompt and | |
| 85 # the normal test. If both of the tests were successful, the tests | |
| 86 # would be stopped for the current website. | |
| 87 if count == 2: | |
| 88 break | |
| 89 else: | |
| 90 xml.write("<result><test name='%s' type='prompt' successful='false'>" | |
| 91 "</test><test name='%s' type='normal' successful='false'></test>" | |
| 92 "</result>" % (websitetest.name, websitetest.name)) | |
| 93 finally: | |
| 94 try: | |
| 95 os.remove(results_path) | |
| 96 except Exception: | |
| 97 pass | |
| 98 | 76 |
| 99 xml.write("</xml>") | 77 if len(tests_results) > 1: |
| 100 xml.close() | 78 xml = xml + tests.resultsToXml(tests_results) |
|
vabr (Chromium)
2014/07/22 07:54:28
xml += ...
(also below)
rchtara
2014/07/22 12:49:36
Done.
| |
| 79 if tests_results[0].successful and tests_results[1].successful: | |
| 80 successful = True | |
| 81 break | |
| 82 else: | |
|
vabr (Chromium)
2014/07/22 07:54:27
The "else" branch scraps the test results, even if
rchtara
2014/07/22 12:49:36
Done.
| |
| 83 xml = xml + ( | |
| 84 "<result><test name='%s' type='prompt' successful='false'>" | |
| 85 "</test><test name='%s' type='normal' successful='false'></test>" | |
| 86 "</result>" % (websitetest.name, websitetest.name)) | |
| 87 | |
| 88 all_successful = all_successful and successful | |
| 89 | |
| 90 xml = xml + "</xml>" | |
| 91 | |
| 92 request = urllib2.Request("http://dashbord", data=xml, | |
|
vabr (Chromium)
2014/07/22 07:54:27
Please do not include code which is not working. U
rchtara
2014/07/22 12:49:36
Done.
| |
| 93 headers={'Content-Type': 'application/xml'}) | |
| 94 response = urllib2.urlopen(request).read() | |
| 95 json = open(args.save_path[0], "w") | |
|
vabr (Chromium)
2014/07/22 07:54:27
When I run a test in Rietveld, and want to see a r
rchtara
2014/07/22 12:49:36
Yes I confirm that.
The new patch allows to print
| |
| 96 json.write("{'successful': '%s'}" % all_successful) | |
| 97 json.close() | |
| OLD | NEW |