Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Build spontaneously broken (involving vega-lite) #122

Closed
benjimin opened this issue Sep 14, 2021 · 3 comments
Closed

Build spontaneously broken (involving vega-lite) #122

benjimin opened this issue Sep 14, 2021 · 3 comments

Comments

@benjimin
Copy link
Collaborator

The most recent commit that passed all tests (955fbe6) seems to no longer pass those same unit tests.

The problem involves test_s3_svg_chart_upload (in module test_s3) failing.

From the trace: the test causes altair.Chart.save to be invoked, which tries to run an external node.js script "vl2vg" (apparently part of vega-lite) that fails. (Note altair is basically a python API for vega-lite, a higher level wrapper of vega, which wraps the javascript data-visualisation library D3. The failure specifically presents as a SyntaxError seeming to involve a recent javascript language feature, the "nullish coalescing operator", which may require node v14.)

The dockerfile line RUN npm install vega-lite elicits a warning npm WARN notsup Unsupported engine for [email protected]: wanted: {"node":">=12"} (current: {"node":"10.19.0","npm":"6.14.4"}). Thanks @emmaai for reporting. The automatic build usually hides this because of docker cache.

@benjimin
Copy link
Collaborator Author

Apparently vega-lite 5.1.1 (released 9 days ago) raised their node engine requirement while updating to D3 v7. This conflicted with the engine distributed by the last ubuntu LTS, breaking our build. (Note vega-lite did declare this properly but, as one of the few non-python dependencies, the compatibility is not automated by pip.)

We should probably enforce --engine-strict to the node package manager, to prevent the default silent completion of broken builds. Probably also ought stay up to date with at least the node.js LTS, rather than installing ubuntu default.

If wps processes saved altair charts in html rather than svg format, then we wouldn't need node. That is, the javascript for translating the data into drawing directions could be executed in the browser rather than the WPS; I think svg format also forfeits user-interactivity.

@emmaai
Copy link
Contributor

emmaai commented Sep 15, 2021

Agree with charts in html rather than svg

benjimin added a commit that referenced this issue Sep 16, 2021
Addressing #122
@benjimin
Copy link
Collaborator Author

I think this is resolved. Observed a remaining intermittent build test failure, where test_api.py::test_wit elicits a UnicodeDecodeError (invalid start bytes for utf8) from pyproj (and the trace involves witprocess cal_area, dask core, and datacube geometry __hash__ and to_wkt).

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants