apache-beam-jupyterlab-sidepanel v3.0.0
apache-beam-jupyterlab-sidepanel
Includes two different side panels:
- The Inspector side panel provides information and controls to run Apache Beam notebooks interactively.
- The Clusters side panel displays all Dataproc clusters managed by Interactive Beam and provides controls to configure cluster usage.
Requirements
| JupyterLab version | Extension version |
|---|---|
| v3 | v2.0.0 |
| v2 | v1.0.0 |
Install
jupyter labextension install apache-beam-jupyterlab-sidepanelContributing
Install
The jlpm command is JupyterLab's pinned version of
yarn that is installed with JupyterLab. You may use
yarn or npm in lieu of jlpm below.
# Clone the repo to your local environment
# Move to apache-beam-jupyterlab-sidepanel directory
# Install dependencies
jlpm
# Build Typescript source
jlpm build
# Link your development version of the extension with JupyterLab
jupyter labextension link .
# Rebuild Typescript source after making changes
jlpm build
# Rebuild JupyterLab after making any changes
jupyter lab buildYou can watch the source directory and run JupyterLab in watch mode to watch for changes in the extension's source and automatically rebuild the extension and application.
# Watch the source directory in another terminal tab
jlpm watch
# Run jupyterlab in watch mode in one terminal tab
jupyter lab --watchNow every change will be built locally and bundled into JupyterLab. Be sure to refresh your browser page after saving file changes to reload the extension (note: you'll need to wait for webpack to finish, which can take 10s+ at times).
Test
To run all tests, under apache-beam-jupyterlab-sidepanel directory, simply do:
# Make sure all dependencies are installed.
jlpm
# Run all tests.
jlpm jestThis project uses ts-jest to test all ts/tsx files under src/__tests__ directory.
To run a single test, find out the name of a test in the source code that looks like:
it('does ABC', () => {...})Then run:
jlpm jest -t 'does ABC'Format and lint
The project uses prettier for formatting and eslint for lint. Prettier is configured as a plugin used by eslint. There are pre-configured yarn scripts to execute them.
# Under apache-beam-jupyterlab-sidepanel directory.
# Make sure dependencies are installed.
# Prettier and eslint are both installed as dev dependencies.
jlpm
# Check format and lint issues.
jlpm eslint:check
# Check then fix in place format and lint issues.
jlpm eslintUninstall
jupyter labextension uninstall apache-beam-jupyterlab-sidepanel