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

Change jupyterlab version and add yarn dependency #1149

Merged
merged 20 commits into from
Dec 11, 2023
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
25 changes: 4 additions & 21 deletions .github/workflows/ui-tests.yml
Original file line number Diff line number Diff line change
Expand Up @@ -19,13 +19,10 @@ jobs:
steps:
- uses: actions/checkout@v2

- name: Setup conda
uses: conda-incubator/setup-miniconda@v2
- name: Install Conda environment with Micromamba
uses: mamba-org/setup-micromamba@main
with:
environment-file: environment-dev.yml
activate-environment: ipyleaflet-dev
mamba-version: "*"
python-version: ${{ matrix.python-version }}
channels: conda-forge

- name: Install ipyleaflet
Expand All @@ -34,21 +31,11 @@ jobs:
- name: Install browser
run: |
jlpm install
jlpm playwright install chromium
npx playwright install chromium
working-directory: ui-tests

- name: Launch JupyterLab
run: jlpm start:detached > /tmp/jupyterlab_server.log 2>&1
working-directory: ui-tests

- name: Wait for JupyterLab
uses: ifaxity/wait-on-action@v1
with:
resource: http-get://localhost:8888/
timeout: 360000

- name: Widget rendering tests
run: jlpm run test
run: npx playwright test
working-directory: ui-tests

- name: Upload Playwright Test assets
Expand All @@ -75,7 +62,3 @@ jobs:
# generate new snapshots
jlpm run test:update
working-directory: ui-tests

- name: Print JupyterLab logs
if: always()
run: cat /tmp/jupyterlab_server.log
1 change: 1 addition & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@ build/
node_modules/
*package-lock.json
js/.yarn/
ui-tests/.yarn/

# Compiled javascript
ipyleaflet/nbextension/
Expand Down
3 changes: 2 additions & 1 deletion environment-dev.yml
Original file line number Diff line number Diff line change
Expand Up @@ -5,10 +5,11 @@ dependencies:
- pip
- wheel
- flake8
- jupyterlab~=3.6.0
- jupyterlab~=4.0
- jupyter-packaging~=0.12
- ipywidgets
- xyzservices
- branca
- traittypes
- pandas
- yarn~=3.0
2 changes: 2 additions & 0 deletions ui-tests/.yarnrc.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
nodeLinker: node-modules
enableImmutableInstalls: false
51 changes: 51 additions & 0 deletions ui-tests/data/US_Unemployment_Oct2012.csv
Original file line number Diff line number Diff line change
@@ -0,0 +1,51 @@
State,Unemployment
AL,7.1
AK,6.8
AZ,8.1
AR,7.2
CA,10.1
CO,7.7
CT,8.4
DE,7.1
FL,8.2
GA,8.8
HI,5.4
ID,6.6
IL,8.8
IN,8.4
IA,5.1
KS,5.6
KY,8.1
LA,5.9
ME,7.2
MD,6.8
MA,6.7
MI,9.1
MN,5.6
MS,9.1
MO,6.7
MT,5.8
NE,3.9
NV,10.3
NH,5.7
NJ,9.6
NM,6.8
NY,8.4
NC,9.4
ND,3.2
OH,6.9
OK,5.2
OR,8.5
PA,8
RI,10.1
SC,8.8
SD,4.4
TN,7.8
TX,6.4
UT,5.5
VT,5
VA,5.8
WA,7.8
WV,7.5
WI,6.8
WY,5.1
52 changes: 52 additions & 0 deletions ui-tests/data/us-states.json

Large diffs are not rendered by default.

10 changes: 3 additions & 7 deletions ui-tests/jupyter_server_config.py
Original file line number Diff line number Diff line change
@@ -1,7 +1,3 @@
c.ServerApp.port = 8888
c.ServerApp.token = ""
c.ServerApp.password = ""
c.ServerApp.disable_check_xsrf = True
c.ServerApp.open_browser = False
c.LabApp.open_browser = False
c.LabApp.expose_app_in_browser = True
from jupyterlab.galata import configure_jupyter_server

configure_jupyter_server(c) # noqa F821
13 changes: 7 additions & 6 deletions ui-tests/notebooks/Subitems.ipynb
Original file line number Diff line number Diff line change
Expand Up @@ -2,22 +2,23 @@
"cells": [
{
"cell_type": "code",
"execution_count": 1,
"execution_count": null,
"metadata": {},
"outputs": [
{
"data": {
"application/vnd.jupyter.widget-view+json": {
"model_id": "014844f713124f2a873205e61115e65c",
"model_id": "58122d6c27c34d8bb41c7c1f435f45a4",
"version_major": 2,
"version_minor": 0
},
"text/plain": [
"Map(center=[43, -100], controls=(ZoomControl(options=['position', 'zoom_in_text', 'zoom_in_title', 'zoom_out_t…"
]
},
"execution_count": 5,
"metadata": {},
"output_type": "display_data"
"output_type": "execute_result"
}
],
"source": [
Expand All @@ -28,9 +29,9 @@
"center = (43, -100)\n",
"zoom = 4\n",
"\n",
"geo_json_data = json.load(open(\"../../examples/us-states.json\"))\n",
"geo_json_data = json.load(open(\"../us-states.json\"))\n",
"m1 = Map(center=center, zoom=zoom)\n",
"unemployment = pd.read_csv(\"../../examples/US_Unemployment_Oct2012.csv\")\n",
"unemployment = pd.read_csv(\"../US_Unemployment_Oct2012.csv\")\n",
"unemployment = dict(\n",
" zip(unemployment[\"State\"].tolist(), unemployment[\"Unemployment\"].tolist())\n",
")\n",
Expand Down Expand Up @@ -85,7 +86,7 @@
"name": "python",
"nbconvert_exporter": "python",
"pygments_lexer": "ipython3",
"version": "3.9.12"
"version": "3.12.0"
},
"vscode": {
"interpreter": {
Expand Down
12 changes: 6 additions & 6 deletions ui-tests/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -4,17 +4,17 @@
"description": "ipyleaflet UI Tests",
"private": true,
"scripts": {
"start": "jupyter labextension disable '@jupyterlab/apputils-extension:announcements' && jupyter lab --config ./jupyter_server_config.py",
"start:detached": "yarn run start&",
"start": "jupyter lab --config jupyter_server_config.py",
"clean": "rimraf tests/notebooks/.ipynb_checkpoints && rimraf test-output",
"test": "yarn run clean && playwright test",
"test:debug": "yarn run clean && PWDEBUG=1 playwright test",
"test:update": "playwright test --update-snapshots"
"test": "npx playwright test",
"test:debug": "yarn run clean && PWDEBUG=1 npx playwright test",
"test:update": "npx playwright test --update-snapshots"
},
"author": "ipyleaflet",
"license": "MIT",
"dependencies": {
"@jupyterlab/galata": "^4.3.5",
"@jupyterlab/galata": "^5.0.1",
"@playwright/test": "^1.32.0",
"klaw-sync": "^6.0.0",
"rimraf": "^3.0.2"
}
Expand Down
9 changes: 7 additions & 2 deletions ui-tests/playwright.config.js
Original file line number Diff line number Diff line change
@@ -1,11 +1,16 @@
var baseConfig = require('@jupyterlab/galata/lib/playwright-config');
var baseConfig = require("@jupyterlab/galata/lib/playwright-config");

module.exports = {
...baseConfig,
expect: {
toMatchSnapshot: { threshold: 0.33 },
},
preserveOutput: 'failures-only',
webServer: {
command: "jlpm start",
url: "http://localhost:8888/lab",
reuseExistingServer: !process.env.CI,
},
preserveOutput: "failures-only",
retries: 0,
timeout: 600000,
};
70 changes: 42 additions & 28 deletions ui-tests/tests/ipyleaflet.test.ts
Original file line number Diff line number Diff line change
@@ -1,19 +1,33 @@
import { IJupyterLabPageFixture, test } from '@jupyterlab/galata';
import { expect } from '@playwright/test';
import * as path from 'path';
const klaw = require('klaw-sync');
import { expect, IJupyterLabPageFixture, test } from "@jupyterlab/galata";
import * as path from "path";
const klaw = require("klaw-sync");


const filterUpdateNotebooks = item => {
const filterUpdateNotebooks = (item) => {
const basename = path.basename(item.path);
return basename.includes('_update');
}
return basename.includes("_update");
};

const testCellOutputs = async (
page: IJupyterLabPageFixture,
tmpPath: string,
theme: "JupyterLab Light" | "JupyterLab Dark"
) => {
const paths = klaw(path.resolve(__dirname, "../notebooks"), {
filter: (item) => !filterUpdateNotebooks(item),
nodir: true,
});

await page.contents.uploadFile(
path.resolve(__dirname, "../../examples/US_Unemployment_Oct2012.csv")
);

await page.contents.uploadFile(
path.resolve(__dirname, "../../examples/us-states.json")
);

const testCellOutputs = async (page: IJupyterLabPageFixture, tmpPath: string, theme: 'JupyterLab Light' | 'JupyterLab Dark') => {
const paths = klaw(path.resolve(__dirname, '../notebooks'), {filter: item => !filterUpdateNotebooks(item), nodir: true});
const notebooks = paths.map(item => path.basename(item.path));
const notebooks = paths.map((item) => path.basename(item.path));

const contextPrefix = theme == 'JupyterLab Light' ? 'light_' : 'dark_';
const contextPrefix = theme == "JupyterLab Light" ? "light_" : "dark_";
page.theme.setTheme(theme);

for (const notebook of notebooks) {
Expand All @@ -24,7 +38,11 @@ const testCellOutputs = async (page: IJupyterLabPageFixture, tmpPath: string, th

let numCellImages = 0;

const getCaptureImageName = (contextPrefix: string, notebook: string, id: number): string => {
const getCaptureImageName = (
contextPrefix: string,
notebook: string,
id: number
): string => {
return `${contextPrefix}-${notebook}-cell-${id}.png`;
};

Expand All @@ -47,39 +65,35 @@ const testCellOutputs = async (page: IJupyterLabPageFixture, tmpPath: string, th
results.push(await cell.screenshot());
numCellImages++;
}
}
},
});

await page.notebook.save();

for (let c = 0; c < numCellImages; ++c) {
expect(results[c]).toMatchSnapshot(getCaptureImageName(contextPrefix, notebook, c));
expect(results[c]).toMatchSnapshot(
getCaptureImageName(contextPrefix, notebook, c)
);
}

await page.notebook.close(true);
}
}
};

test.describe('ipyleaflet Visual Regression', () => {
test.describe("ipyleaflet Visual Regression", () => {
test.beforeEach(async ({ page, tmpPath }) => {
await page.contents.uploadDirectory(
path.resolve(__dirname, '../notebooks'),
path.resolve(__dirname, "../notebooks"),
tmpPath
);
await page.filebrowser.openDirectory(tmpPath);
});

test('Light theme: Check ipyleaflet renders', async ({
page,
tmpPath,
}) => {
await testCellOutputs(page, tmpPath, 'JupyterLab Light');
test("Light theme: Check ipyleaflet renders", async ({ page, tmpPath }) => {
await testCellOutputs(page, tmpPath, "JupyterLab Light");
});

test('Dark theme: Check ipyleaflet renders', async ({
page,
tmpPath,
}) => {
await testCellOutputs(page, tmpPath, 'JupyterLab Dark');
test("Dark theme: Check ipyleaflet renders", async ({ page, tmpPath }) => {
await testCellOutputs(page, tmpPath, "JupyterLab Dark");
});
});
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Loading