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 |