Skip to content

Commit

Permalink
docs(tutorial): deploy jupyterlite
Browse files Browse the repository at this point in the history
  • Loading branch information
cpcloud committed Apr 21, 2024
1 parent a687ec1 commit 3c2e96c
Show file tree
Hide file tree
Showing 12 changed files with 953 additions and 58 deletions.
3 changes: 3 additions & 0 deletions .github/workflows/ibis-docs-main.yml
Original file line number Diff line number Diff line change
Expand Up @@ -45,6 +45,9 @@ jobs:
- name: build docs
run: nix develop --ignore-environment --keep HOME -c just docs-render

- name: build jupyterlite
run: nix develop --ignore-environment --keep HOME -c just build-jupyterlite

- name: check that all frozen computations were done before push
run: git diff --exit-code --stat

Expand Down
3 changes: 3 additions & 0 deletions .github/workflows/ibis-docs-pr.yml
Original file line number Diff line number Diff line change
Expand Up @@ -47,6 +47,9 @@ jobs:
- name: build docs
run: nix develop --ignore-environment --keep HOME -c just docs-render

- name: build jupyterlite
run: nix develop --ignore-environment --keep HOME -c just build-jupyterlite

- name: check that all frozen computations were done before push
run: git diff --exit-code --stat

Expand Down
6 changes: 6 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -147,3 +147,9 @@ docs/**/.jupyter_cache
# quarto generated files
docs/posts-listing.json
docs/posts.feed-full-staged
docs/**/*.html

# jupyterlite stuff
.jupyterlite.doit.db
!content/runtime.txt
content/
8 changes: 8 additions & 0 deletions docs/ibis-wasm-wheels_cors_config.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
[
{
"origin": ["*"],
"method": ["GET"],
"responseHeader": ["Content-Type"],
"maxAgeSeconds": 3600
}
]
3 changes: 3 additions & 0 deletions docs/index.qmd
Original file line number Diff line number Diff line change
Expand Up @@ -35,6 +35,9 @@ about:
- icon: rss
text: RSS
href: https://ibis-project.org/posts.xml
- icon: keyboard
text: Try Ibis!
href: repl.qmd
---

::: {#about}
Expand Down
8 changes: 8 additions & 0 deletions docs/jupyter_lite_config.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
{
"PipliteAddon": {
"piplite_urls": [
"https://duckdb.github.io/duckdb-pyodide/wheels/duckdb-0.10.2-cp311-cp311-emscripten_3_1_46_wasm32.whl",
"dist/ibis_framework-8.0.0-py3-none-any.whl"
]
}
}
49 changes: 49 additions & 0 deletions docs/repl.qmd
Original file line number Diff line number Diff line change
@@ -0,0 +1,49 @@
---
title: "Ibis in the browser"
format:
html:
toc: false
page-layout: full
---

## Try Ibis!

::: {.callout-warning}
## Ibis-in-the-browser is experimental.

iOS is known to cause crashes on this page.

Mobile Firefox may also not work (the page won't crash though).

Please [open an issue on GitHub](https://github.com/ibis-project/ibis/issues/new/choose) if you encounter problems.
:::

```{python}
#| echo: false
#| output: asis
from urllib.parse import urlencode
lines = """
%pip install numpy pandas tzdata
import pyodide_js
await pyodide_js.loadPackage("https://storage.googleapis.com/ibis-wasm-wheels/pyarrow-16.0.0.dev2661%2Bg9bddb87fd-cp311-cp311-emscripten_3_1_46_wasm32.whl")
del pyodide_js
%clear
%pip install 'ibis-framework[duckdb]'
from ibis.interactive import *
penguins = ibis.read_csv("penguins.csv")
penguins.head()
"""
params = [
("toolbar", "1"),
("theme", "JupyterLab Night"),
("kernel", "python"),
]
params.extend(("code", line) for line in lines.splitlines() if line)
query = urlencode(params)
jupyterlite = f"./jupyterlite/repl/?{query}"
iframe = f'<iframe src="{jupyterlite}" id="jupyterlite-console"></iframe>'
print(iframe)
```
7 changes: 7 additions & 0 deletions docs/styles.css
Original file line number Diff line number Diff line change
Expand Up @@ -14,3 +14,10 @@ section[id^="parameters-"] {
vertical-align: -0.125em;
width: 1em;
}

#jupyterlite-console {
width: 100%;
height: 500px;
margin: auto;
display: block;
}
46 changes: 45 additions & 1 deletion justfile
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,8 @@ clean:
# lock dependencies without updating existing versions
lock:
#!/usr/bin/env bash
set -euo pipefail
required_version="1.8.2"
version="$(poetry --version)"
if ! grep -qF "${required_version}" <<< "${version}"; then
Expand Down Expand Up @@ -39,7 +41,7 @@ ci-check *args:
# lint code
lint:
ruff format -q . --check
ruff .
ruff check .

# run the test suite for one or more backends
test +backends:
Expand All @@ -56,6 +58,7 @@ test +backends:

_doctest runner *args:
#!/usr/bin/env bash
set -euo pipefail
# TODO(cpcloud): why doesn't pytest --ignore-glob=test_*.py work?
{{ runner }} pytest --doctest-modules {{ args }} $(
Expand All @@ -80,6 +83,8 @@ ci-doctest *args:
# download testing data
download-data owner="ibis-project" repo="testing-data" rev="master":
#!/usr/bin/env bash
set -euo pipefail
outdir="{{ justfile_directory() }}/ci/ibis-testing-data"
rm -rf "$outdir"
url="https://github.com/{{ owner }}/{{ repo }}"
Expand Down Expand Up @@ -109,6 +114,8 @@ reup *backends:
# stop and remove containers; clean up networks and volumes
down *backends:
#!/usr/bin/env bash
set -euo pipefail
if [ -z "{{ backends }}" ]; then
docker compose down --volumes --remove-orphans
else
Expand All @@ -130,11 +137,15 @@ benchcmp number *args:
# check for invalid links in a locally built version of the docs
checklinks *args:
#!/usr/bin/env bash
set -euo pipefail
lychee --base docs/_output $(find docs/_output -name '*.html') {{ args }}

# view the changelog for upcoming release (use --pretty to format with glow)
view-changelog flags="":
#!/usr/bin/env bash
set -euo pipefail
npx -y -p conventional-changelog-cli \
-- conventional-changelog --config ./.conventionalcommits.js \
| ([ "{{ flags }}" = "--pretty" ] && glow -p - || cat -)
Expand Down Expand Up @@ -169,10 +180,43 @@ docs-api-preview:
docs-deploy:
quarto publish --no-prompt --no-browser --no-render netlify docs

# build an ibis_framework wheel that works with pyodide
build-ibis-for-pyodide:
#!/usr/bin/env bash
set -euo pipefail
# TODO(cpcloud): remove when:
# 1. pyarrow release contains pyodide
# 2. ibis supports this version of pyarrow
rm -rf dist/
poetry add 'pyarrow>=10.0.1' --allow-prereleases
poetry build --format wheel
git checkout poetry.lock pyproject.toml

# build the jupyterlite deployment
build-jupyterlite: build-ibis-for-pyodide
#!/usr/bin/env bash
set -euo pipefail
mkdir -p docs/_output/jupyterlite
mkdir -p content
curl -L https://storage.googleapis.com/ibis-tutorial-data/penguins.csv > content/penguins.csv
jupyter lite build \
--debug \
--no-libarchive \
--config docs/jupyter_lite_config.json \
--output-dir docs/_output/jupyterlite \
--contents content
# jupyter lite build can copy from the nix store, and preserves the
# original write bit; without this the next run of this rule will result in
# a permission error when the build tries to remove existing files
chmod -R u+w docs/_output/jupyterlite

# run the entire docs build pipeline
docs-build-all:
just docs-apigen --verbose
just docs-render
just build-jupyterlite
just checklinks docs/_output --offline --no-progress

# open chat
Expand Down
Loading

0 comments on commit 3c2e96c

Please sign in to comment.