Commit 2e72bb1c authored by maruel@chromium.org's avatar maruel@chromium.org

Overhaul breakpad to optionally disable output. Add git-cl dcommit unit test.

This required fixing the adhoc mock to be more versatile.

TBR=cmp@chromium.org
BUG=
TEST=


Review URL: http://codereview.chromium.org/9178019

git-svn-id: svn://svn.chromium.org/chrome/trunk/tools/depot_tools@117896 0039d316-1c4b-4281-b951-d872f2087c98
parent eb5edbcf
...@@ -42,13 +42,19 @@ IS_ENABLED = ( ...@@ -42,13 +42,19 @@ IS_ENABLED = (
def post(url, params): def post(url, params):
"""HTTP POST with timeout when it's supported.""" """HTTP POST with timeout when it's supported."""
if not IS_ENABLED:
# Make sure to not send anything for non googler.
return
kwargs = {} kwargs = {}
if (sys.version_info[0] * 10 + sys.version_info[1]) >= 26: if (sys.version_info[0] * 10 + sys.version_info[1]) >= 26:
kwargs['timeout'] = 4 kwargs['timeout'] = 4
try:
request = urllib2.urlopen(url, urllib.urlencode(params), **kwargs) request = urllib2.urlopen(url, urllib.urlencode(params), **kwargs)
out = request.read() out = request.read()
request.close() request.close()
return out return out
except IOError:
return 'There was a failure while trying to send the stack trace. Too bad.'
def FormatException(e): def FormatException(e):
...@@ -79,36 +85,28 @@ def FormatException(e): ...@@ -79,36 +85,28 @@ def FormatException(e):
return out return out
def SendStack(last_tb, stack, url=None, maxlen=50): def SendStack(last_tb, stack, url=None, maxlen=50, verbose=True):
"""Sends the stack trace to the breakpad server.""" """Sends the stack trace to the breakpad server."""
if not IS_ENABLED: if not IS_ENABLED:
# Make sure to not send anything for non googler.
return return
if not url: def p(o):
url = DEFAULT_URL + '/breakpad' if verbose:
print 'Sending crash report ...' print(o)
try: p('Sending crash report ...')
params = { params = {
'args': sys.argv, 'args': sys.argv,
'stack': stack[0:4096], 'cwd': os.getcwd(),
'user': getpass.getuser(),
'exception': FormatException(last_tb), 'exception': FormatException(last_tb),
'host': _HOST_NAME, 'host': _HOST_NAME,
'cwd': os.getcwd(), 'stack': stack[0:4096],
'user': getpass.getuser(),
'version': sys.version, 'version': sys.version,
} }
# pylint: disable=W0702 p('\n'.join(' %s: %s' % (k, params[k][0:maxlen]) for k in sorted(params)))
print('\n'.join(' %s: %s' % (k, params[k][0:maxlen]) p(post(url or DEFAULT_URL + '/breakpad', params))
for k in sorted(params)))
print(post(url, params))
except IOError:
print('There was a failure while trying to send the stack trace. Too bad.')
def SendProfiling(url=None): def SendProfiling(url=None):
try:
if not url:
url = DEFAULT_URL + '/profiling'
params = { params = {
'argv': ' '.join(sys.argv), 'argv': ' '.join(sys.argv),
# Strip the hostname. # Strip the hostname.
...@@ -116,9 +114,7 @@ def SendProfiling(url=None): ...@@ -116,9 +114,7 @@ def SendProfiling(url=None):
'duration': time.time() - _TIME_STARTED, 'duration': time.time() - _TIME_STARTED,
'platform': sys.platform, 'platform': sys.platform,
} }
post(url, params) post(url or DEFAULT_URL + '/profiling', params)
except IOError:
pass
def CheckForException(): def CheckForException():
......
...@@ -747,9 +747,11 @@ def GenerateDiff(files): ...@@ -747,9 +747,11 @@ def GenerateDiff(files):
def OptionallyDoPresubmitChecks(change_info, committing, args): def OptionallyDoPresubmitChecks(change_info, committing, args):
if FilterFlag(args, "--no_presubmit") or FilterFlag(args, "--force"): if FilterFlag(args, "--no_presubmit") or FilterFlag(args, "--force"):
breakpad.SendStack( breakpad.SendStack(
breakpad.DEFAULT_URL + '/breakpad',
'GclHooksBypassedCommit', 'GclHooksBypassedCommit',
'Issue %s/%s bypassed hook when committing' % 'Issue %s/%s bypassed hook when committing' %
(change_info.rietveld, change_info.issue)) (change_info.rietveld, change_info.issue),
verbose=False)
return presubmit_support.PresubmitOutput() return presubmit_support.PresubmitOutput()
return DoPresubmitChecks(change_info, committing, True) return DoPresubmitChecks(change_info, committing, True)
......
...@@ -1090,7 +1090,8 @@ def SendUpstream(parser, args, cmd): ...@@ -1090,7 +1090,8 @@ def SendUpstream(parser, args, cmd):
breakpad.SendStack( breakpad.SendStack(
'GitClHooksBypassedCommit', 'GitClHooksBypassedCommit',
'Issue %s/%s bypassed hook when committing' % 'Issue %s/%s bypassed hook when committing' %
(cl.GetRietveldServer(), cl.GetIssue())) (cl.GetRietveldServer(), cl.GetIssue()),
verbose=False)
description = options.message description = options.message
if not description and cl.GetIssue(): if not description and cl.GetIssue():
......
This diff is collapsed.
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment