OLD | NEW |
---|---|
1 #!/usr/bin/env python | 1 #!/usr/bin/env python |
2 # Copyright 2016 The Chromium Authors. All rights reserved. | 2 # Copyright 2016 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 """Wrapper for adding logdog streaming support to swarming tasks.""" | 6 """Wrapper for adding logdog streaming support to swarming tasks.""" |
7 | 7 |
8 import argparse | 8 import argparse |
9 import logging | 9 import logging |
10 import os | 10 import os |
11 import signal | |
11 import subprocess | 12 import subprocess |
12 import sys | 13 import sys |
13 import urllib | 14 import urllib |
14 | 15 |
15 | 16 |
16 def CommandParser(): | 17 def CommandParser(): |
17 # Parses the command line arguments being passed in | 18 # Parses the command line arguments being passed in |
18 parser = argparse.ArgumentParser() | 19 parser = argparse.ArgumentParser() |
19 parser.add_argument('--logdog-bin-cmd', required=True, | 20 parser.add_argument('--logdog-bin-cmd', required=True, |
20 help='Command for running logdog butler binary') | 21 help='Command for running logdog butler binary') |
(...skipping 11 matching lines...) Expand all Loading... | |
32 parser.add_argument('--name', required=True, | 33 parser.add_argument('--name', required=True, |
33 help='Name to be used for logdog stream') | 34 help='Name to be used for logdog stream') |
34 return parser | 35 return parser |
35 | 36 |
36 | 37 |
37 def CreateUrl(server, project, prefix, name): | 38 def CreateUrl(server, project, prefix, name): |
38 stream_name = '%s/%s/+/%s' % (project, prefix, name) | 39 stream_name = '%s/%s/+/%s' % (project, prefix, name) |
39 return 'https://%s/v/?s=%s' % (server, urllib.quote_plus(stream_name)) | 40 return 'https://%s/v/?s=%s' % (server, urllib.quote_plus(stream_name)) |
40 | 41 |
41 | 42 |
43 def CreateSignalForwarder(proc): | |
44 def handler(signum, _frame): | |
45 proc.send_signal(signum) | |
bpastene
2016/10/27 17:46:14
Not sure where this logs to, but maybe log that it
jbudorick
2016/10/27 18:09:07
stdout (e.g. see the "Logcats are located at:" lin
| |
46 | |
47 return handler | |
48 | |
49 | |
42 def main(): | 50 def main(): |
43 parser = CommandParser() | 51 parser = CommandParser() |
44 args, test_cmd = parser.parse_known_args(sys.argv[1:]) | 52 args, test_cmd = parser.parse_known_args(sys.argv[1:]) |
45 logging.basicConfig(level=logging.INFO) | 53 logging.basicConfig(level=logging.INFO) |
46 if not test_cmd: | 54 if not test_cmd: |
47 parser.error('Must specify command to run after the logdog flags') | 55 parser.error('Must specify command to run after the logdog flags') |
48 result = subprocess.call(test_cmd) | 56 test_proc = subprocess.Popen(test_cmd) |
57 original_sigterm_handler = signal.signal( | |
58 signal.SIGTERM, CreateSignalForwarder(test_proc)) | |
59 try: | |
60 result = test_proc.wait() | |
61 finally: | |
62 signal.signal(signal.SIGTERM, original_sigterm_handler) | |
49 if '${SWARMING_TASK_ID}' in args.prefix: | 63 if '${SWARMING_TASK_ID}' in args.prefix: |
50 args.prefix = args.prefix.replace('${SWARMING_TASK_ID}', | 64 args.prefix = args.prefix.replace('${SWARMING_TASK_ID}', |
51 os.environ.get('SWARMING_TASK_ID')) | 65 os.environ.get('SWARMING_TASK_ID')) |
52 url = CreateUrl('luci-logdog.appspot.com', args.project, args.prefix, | 66 url = CreateUrl('luci-logdog.appspot.com', args.project, args.prefix, |
53 args.name) | 67 args.name) |
54 logdog_cmd = [args.logdog_bin_cmd, '-project', args.project, | 68 logdog_cmd = [args.logdog_bin_cmd, '-project', args.project, |
55 '-output', 'logdog,host=%s' % args.logdog_server, | 69 '-output', 'logdog,host=%s' % args.logdog_server, |
56 '-prefix', args.prefix, | 70 '-prefix', args.prefix, |
57 '-service-account-json', args.service_account_json, | 71 '-service-account-json', args.service_account_json, |
58 'stream', '-source', args.source, | 72 'stream', '-source', args.source, |
59 '-stream', '-name=%s' % args.name] | 73 '-stream', '-name=%s' % args.name] |
60 if os.path.exists(args.logdog_bin_cmd): | 74 if os.path.exists(args.logdog_bin_cmd): |
61 subprocess.call(logdog_cmd) | 75 subprocess.call(logdog_cmd) |
62 logging.info('Logcats are located at: %s', url) | 76 logging.info('Logcats are located at: %s', url) |
63 return result | 77 return result |
64 | 78 |
65 | 79 |
66 if __name__ == '__main__': | 80 if __name__ == '__main__': |
67 sys.exit(main()) | 81 sys.exit(main()) |
OLD | NEW |