Bug 1793104 - [mozcrash] Retry symbols download on exception; r=jcristau

Differential Revision: https://phabricator.services.mozilla.com/D159525
This commit is contained in:
Geoff Brown 2022-10-18 15:21:37 +00:00
Родитель f81e6797f5
Коммит d7a7f06140
2 изменённых файлов: 44 добавлений и 3 удалений

Просмотреть файл

@ -16,6 +16,8 @@ import sys
import tempfile
import zipfile
from collections import namedtuple
from redo import retriable
import mozfile
import mozinfo
@ -281,6 +283,7 @@ class CrashInfo(object):
self.logger = get_logger()
self._dump_files = None
@retriable(attempts=5, sleeptime=5, sleepscale=2)
def _get_symbols(self):
if not self.symbols_path:
self.logger.warning(

Просмотреть файл

@ -33,11 +33,11 @@ def test_symbols_path_url(check_for_crashes, minidump_files):
data = {"retrieved": False}
def make_zipfile():
data = BytesIO()
z = zipfile.ZipFile(data, "w")
zdata = BytesIO()
z = zipfile.ZipFile(zdata, "w")
z.writestr("symbols.txt", "abc/xyz")
z.close()
return data.getvalue()
return zdata.getvalue()
def get_symbols(req):
data["retrieved"] = True
@ -58,5 +58,43 @@ def test_symbols_path_url(check_for_crashes, minidump_files):
assert data["retrieved"]
def test_symbols_retry(check_for_crashes, minidump_files):
"""Test that passing a URL as symbols_path succeeds on retry after temporary HTTP failure."""
data = {"retrieved": False}
get_symbols_calls = 0
def make_zipfile():
zdata = BytesIO()
z = zipfile.ZipFile(zdata, "w")
z.writestr("symbols.txt", "abc/xyz")
z.close()
return zdata.getvalue()
def get_symbols(req):
nonlocal get_symbols_calls
data["retrieved"] = True
if get_symbols_calls > 0:
ret = 200
else:
ret = 504
get_symbols_calls += 1
headers = {}
return (ret, headers, make_zipfile())
httpd = mozhttpd.MozHttpd(
port=0,
urlhandlers=[{"method": "GET", "path": "/symbols", "function": get_symbols}],
)
httpd.start()
symbol_url = urlunsplit(
("http", "%s:%d" % httpd.httpd.server_address, "/symbols", "", "")
)
assert 1 == check_for_crashes(symbols_path=symbol_url)
assert data["retrieved"]
assert 2 == get_symbols_calls
if __name__ == "__main__":
mozunit.main()