Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(37)

Side by Side Diff: components/test/data/password_manager/run_tests.py

Issue 403323002: Automatic password manager tests now rely on being killed by the bot on timeout (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 6 years, 5 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « no previous file | components/test/data/password_manager/tests.py » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
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
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()
OLDNEW
« no previous file with comments | « no previous file | components/test/data/password_manager/tests.py » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698