show actual error when graphData fails

The original reason for the catch-all message was users with bad
data such as decimal intervals, but those get automatically coerced
these days. The common case should now be invalid search strings, which
we can show verbatim.
This commit is contained in:
Damien Elmes 2021-01-29 14:37:29 +10:00
parent 57c53632a6
commit 4ac9ad1407
4 changed files with 11 additions and 8 deletions

View File

@ -172,7 +172,6 @@ statistics-elapsed-time-years = { $amount }y
## ##
statistics-error-fetching = Error searching - please check your search is correct, or use the Check Database feature.
statistics-average-for-days-studied = Average for days studied statistics-average-for-days-studied = Average for days studied
statistics-total = Total statistics-total = Total
statistics-days-studied = Days studied statistics-days-studied = Days studied

View File

@ -287,11 +287,14 @@ def handle_post(path: str) -> Response:
return flask.make_response("Collection not open", HTTPStatus.NOT_FOUND) return flask.make_response("Collection not open", HTTPStatus.NOT_FOUND)
if path in post_handlers: if path in post_handlers:
if data := post_handlers[path](): try:
response = flask.make_response(data) if data := post_handlers[path]():
response.headers["Content-Type"] = "application/binary" response = flask.make_response(data)
else: response.headers["Content-Type"] = "application/binary"
response = flask.make_response("", HTTPStatus.NO_CONTENT) else:
response = flask.make_response("", HTTPStatus.NO_CONTENT)
except Exception as e:
return flask.make_response(str(e), HTTPStatus.INTERNAL_SERVER_ERROR)
else: else:
response = flask.make_response( response = flask.make_response(
f"Unhandled post to {path}", f"Unhandled post to {path}",

View File

@ -37,7 +37,7 @@
revlogRange = daysToRevlogRange(days); revlogRange = daysToRevlogRange(days);
} catch (e) { } catch (e) {
sourceData = null; sourceData = null;
alert(i18n.tr(i18n.TR.STATISTICS_ERROR_FETCHING)); alert(e);
} }
active = false; active = false;
}; };

View File

@ -7,7 +7,8 @@ export async function postRequest(path: string, body: string): Promise<Uint8Arra
body, body,
}); });
if (!resp.ok) { if (!resp.ok) {
throw Error(`unexpected reply: ${resp.statusText}`); const body = await resp.text();
throw Error(`${resp.status}: ${body}`);
} }
// get returned bytes // get returned bytes
const respBlob = await resp.blob(); const respBlob = await resp.blob();