Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
G
go
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
go
Commits
7db2c799
Commit
7db2c799
authored
Nov 17, 2009
by
Russ Cox
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
codereview: more attempts at robustness in the face of unexpected exceptions
R=r
https://golang.org/cl/156062
parent
01677dab
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
39 additions
and
36 deletions
+39
-36
lib/codereview/codereview.py
lib/codereview/codereview.py
+39
-36
No files found.
lib/codereview/codereview.py
View file @
7db2c799
...
...
@@ -38,7 +38,7 @@ For example, if change 123456 contains the files x.go and y.go,
from
mercurial
import
cmdutil
,
commands
,
hg
,
util
,
error
,
match
from
mercurial.node
import
nullrev
,
hex
,
nullid
,
short
import
os
,
re
import
os
,
re
,
time
import
stat
import
subprocess
import
threading
...
...
@@ -1031,24 +1031,28 @@ def submit(ui, repo, *pats, **opts):
if
not
node
:
return
"nothing changed"
log
=
repo
.
changelog
rev
=
log
.
rev
(
node
)
parents
=
log
.
parentrevs
(
rev
)
if
(
rev
-
1
not
in
parents
and
(
parents
==
(
nullrev
,
nullrev
)
or
len
(
log
.
heads
(
log
.
node
(
parents
[
0
])))
>
1
and
(
parents
[
1
]
==
nullrev
or
len
(
log
.
heads
(
log
.
node
(
parents
[
1
])))
>
1
))):
repo
.
rollback
()
return
"local repository out of date (created new head); must sync before submit"
# push changes to remote.
# if it works, we're committed.
# if not, roll back
other
=
getremote
(
ui
,
repo
,
opts
)
r
=
repo
.
push
(
other
,
False
,
None
)
if
r
==
0
:
# push to remote; if it fails for any reason, roll back
try
:
log
=
repo
.
changelog
rev
=
log
.
rev
(
node
)
parents
=
log
.
parentrevs
(
rev
)
if
(
rev
-
1
not
in
parents
and
(
parents
==
(
nullrev
,
nullrev
)
or
len
(
log
.
heads
(
log
.
node
(
parents
[
0
])))
>
1
and
(
parents
[
1
]
==
nullrev
or
len
(
log
.
heads
(
log
.
node
(
parents
[
1
])))
>
1
))):
# created new head
raise
util
.
Abort
(
"local repository out of date; must sync before submit"
)
# push changes to remote.
# if it works, we're committed.
# if not, roll back
other
=
getremote
(
ui
,
repo
,
opts
)
r
=
repo
.
push
(
other
,
False
,
None
)
if
r
==
0
:
raise
util
.
Abort
(
"local repository out of date; must sync before submit"
)
except
:
repo
.
rollback
()
r
eturn
"local repository out of date; must sync before submit"
r
aise
# we're committed. upload final patch, close review, add commit message
changeURL
=
short
(
node
)
...
...
@@ -1376,10 +1380,25 @@ def DownloadCL(ui, repo, clname):
return cl, diffdata, ""
def MySend(request_path, payload=None,
content_type="application/octet-stream",
timeout=None, force_auth=True,
**kwargs):
"""Run MySend1 maybe twice, because Rietveld is unreliable."""
try:
return MySend1(request_path, payload, content_type, timeout, force_auth, **kwargs)
except Exception, e:
if type(e) == urllib2.HTTPError and e.code == 403: # forbidden, it happens
raise
print >>sys.stderr, "Loading "+request_path+": "+ExceptionDetail()+"; trying again in 2 seconds."
time.sleep(2)
return MySend1(request_path, payload, content_type, timeout, force_auth, **kwargs)
# Like upload.py Send but only authenticates when the
# redirect is to www.google.com/accounts. This keeps
# unnecessary redirects from happening during testing.
def MySend(request_path, payload=None,
def MySend
1
(request_path, payload=None,
content_type="application/octet-stream",
timeout=None, force_auth=True,
**kwargs):
...
...
@@ -1523,23 +1542,7 @@ def PostMessage1(issue, message, reviewers=None, cc=None, send_mail=None, subjec
sys.exit(2)
def PostMessage(ui, issue, message, reviewers=None, cc=None, send_mail=None, subject=None):
# When Rietveld is busy, it seems to throw off a lot of HTTP Error 500: Internal Server Error.
# Rather than abort, sleep and try again.
# Even if the second time fails, let the overall hg command keep going.
try:
PostMessage1(issue, message, reviewers, cc, send_mail, subject)
return
except:
pass
ui.warn("error posting to "+server+" log; sleep 2 and try again.")
os.sleep(2)
try:
PostMessage1(issue, message, reviewers, cc, send_mail, subject)
return
except:
pass
ui.warn("error posting to "+server+" twice; log not updated.")
PostMessage1(issue, message, reviewers, cc, send_mail, subject)
class opt(object):
pass
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment