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

Exhibition widget and a more sane repr for closed UniverseWidget #200

Closed
wants to merge 93 commits into from
Closed
Show file tree
Hide file tree
Changes from 2 commits
Commits
Show all changes
93 commits
Select commit Hold shift + click to select a range
34f0b9f
adds a sudo widget
tjduigna Jul 14, 2020
b2d5c2a
trajectory first
tjduigna Jul 14, 2020
cf48423
disclaimer about tensor
tjduigna Jul 14, 2020
15ca9af
dont spam notebook with closed widget repr
tjduigna Jul 14, 2020
79d8618
typo and order
tjduigna Jul 14, 2020
932171d
some poc files and better tsconfig
tjduigna Jul 16, 2020
f69e007
more direct approach
tjduigna Jul 17, 2020
643e8a4
minimal not working example
tjduigna Jul 18, 2020
31328df
typescript scene more or less works
tjduigna Jul 18, 2020
47f0127
a functional scene
tjduigna Jul 18, 2020
9d379d8
hud supports longer text, setup for hud banner updates on selected
tjduigna Jul 19, 2020
ef755a9
stop scope creep
tjduigna Jul 19, 2020
401170c
no sticky banner
tjduigna Jul 19, 2020
ee7bf3c
need references to lights
tjduigna Jul 19, 2020
4f9af09
removes promise chaining
tjduigna Jul 23, 2020
e7d1591
revise resize and selenium script
tjduigna Jul 25, 2020
13d20be
remove logging es module
tjduigna Jul 25, 2020
02d5b5d
Merge branch 'issue-192' of https://github.com/exa-analytics/exatomic…
tjduigna Jul 25, 2020
599cb6e
no test in selenium file
tjduigna Jul 25, 2020
8124029
codacy pls
tjduigna Jul 25, 2020
1d4d787
tuck selenium into func def
tjduigna Jul 25, 2020
dbe7ec7
codacy pls
tjduigna Jul 25, 2020
6a2727b
setup and teardown for selenium script
tjduigna Jul 26, 2020
a904d8a
what about ci
tjduigna Jul 26, 2020
66a2fdc
quotes
tjduigna Jul 26, 2020
d7d01fb
simple case
tjduigna Jul 26, 2020
8753780
install chrome driver in CI
tjduigna Jul 26, 2020
345609d
towards chrome driver
tjduigna Jul 26, 2020
9fcda1f
which where
tjduigna Jul 26, 2020
507e5ce
could it be easy
tjduigna Jul 26, 2020
656fda5
pick up by pytest
tjduigna Jul 26, 2020
9e75c76
guh /usr
tjduigna Jul 26, 2020
1c636df
cleanup
tjduigna Jul 26, 2020
3b0d44d
back to manual chromedriver
tjduigna Jul 26, 2020
3b3005b
maybe a timeout issue
tjduigna Jul 26, 2020
6f66b4e
add xvfb
tjduigna Jul 26, 2020
29dfb47
tidy chromedriver installer
tjduigna Oct 31, 2020
4620524
Merge branch 'issue-206' of https://github.com/exa-analytics/exatomic…
tjduigna Oct 31, 2020
6ed594c
Merge branch 'issue-206' of https://github.com/exa-analytics/exatomic…
tjduigna Oct 31, 2020
7cc37d1
re-vamp test_widget for extensibility
tjduigna Nov 1, 2020
11ccd58
pleasing codacy
tjduigna Nov 1, 2020
790688a
less indent
tjduigna Nov 1, 2020
66e3dee
more flexible driver support
tjduigna Nov 1, 2020
ddf711f
occam pls
tjduigna Nov 1, 2020
bd44f3b
try firefox
tjduigna Nov 1, 2020
9766997
firefox addon
tjduigna Nov 1, 2020
be850ff
tidy travis for both browsers
tjduigna Nov 1, 2020
4b2af6d
firefox latest
tjduigna Nov 1, 2020
792bc1d
dont delete the driver
tjduigna Nov 1, 2020
47705a0
firefox pls
tjduigna Nov 1, 2020
1f289bf
headless pls
tjduigna Nov 7, 2020
a9144b1
Merge branch 'master' of https://github.com/exa-analytics/exatomic in…
tjduigna Nov 7, 2020
9644051
listen to travis docs
tjduigna Nov 7, 2020
da54cbf
escape ampersand
tjduigna Nov 7, 2020
3ec06d5
semi bois
tjduigna Nov 7, 2020
b8be85c
travis pls
tjduigna Nov 7, 2020
3a3c7a3
mac before install debug
tjduigna Nov 7, 2020
d4dea18
double quotes
tjduigna Nov 7, 2020
1c1fcf7
or some double quotes maybe
tjduigna Nov 7, 2020
8a459cc
re-organize before install
tjduigna Nov 7, 2020
b677d30
hold off xvfb to see if progress for mac
tjduigna Nov 7, 2020
fd968cd
single escape space
tjduigna Nov 8, 2020
06435d8
fixes scene growing out of bounds
tjduigna Dec 23, 2020
c3bc7db
handle the exceptions
tjduigna Dec 23, 2020
dcbbdb4
Merge remote-tracking branch 'org/master' into issue-192
tjduigna Dec 23, 2020
88f8028
update mac chrome path and tidy for codacy
tjduigna Dec 23, 2020
ff1d653
more work on mac chrome
tjduigna Dec 23, 2020
d0e1519
try local
tjduigna Dec 23, 2020
949533f
simpler driver approach
tjduigna Dec 23, 2020
3551487
mac pls
tjduigna Dec 23, 2020
6cc52e0
remove xvfb
tjduigna Dec 23, 2020
04ce628
browser path
tjduigna Dec 23, 2020
62475e6
put drivers in PATH
tjduigna Dec 23, 2020
1a164d1
debug the build server
tjduigna Dec 23, 2020
856a547
chrome stable on linux
tjduigna Dec 23, 2020
fe41b2d
handle debug exception and tidy travis
tjduigna Dec 23, 2020
176179b
proper use of browser path
tjduigna Dec 23, 2020
d6f06ad
opps
tjduigna Dec 23, 2020
363b05f
cache miniconda
tjduigna Dec 23, 2020
ebc4359
paths pls
tjduigna Dec 23, 2020
2f7cf9e
hope it doesn't unravel
tjduigna Dec 23, 2020
321cbcb
quotes pls
tjduigna Dec 23, 2020
105c28e
and then
tjduigna Dec 23, 2020
b210723
remove caching
tjduigna Dec 23, 2020
6e1a4e7
really try to find chrome
tjduigna Dec 23, 2020
c7bce5a
spaces...
tjduigna Dec 23, 2020
5e6045b
try pinning node
tjduigna Dec 23, 2020
1371a52
all in on block if syntax in travis
tjduigna Dec 23, 2020
720a33f
collapse after_success logic
tjduigna Dec 23, 2020
fc3a2c0
add selenium to windows build
tjduigna Dec 26, 2020
35d8575
skip test on windows
tjduigna Jan 4, 2021
08b8003
Merge branch 'issue-192' of https://github.com/exa-analytics/exatomic…
tjduigna Jan 4, 2021
dee98ea
pin pandas for now
tjduigna Jan 4, 2021
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
12 changes: 11 additions & 1 deletion .travis.yml
Original file line number Diff line number Diff line change
Expand Up @@ -32,6 +32,16 @@ matrix:
python: 3.8
env: PYTHONVER=3.8

addons:
chrome: stable

before_install:
- if [[ $TRAVIS_OS_NAME == "osx" ]]; then
/Applications/Google\\ Chrome.app/Contents/MacOS/Google\\ Chrome --headless --disable-gpu --no-sandbox --remote-debugging-port=9222 http://localhost &;
else
google-chrome-stable --headless --disable-gpu --no-sandbox --remote-debugging-port=9222 http://localhost &;
fi;

install:
- if [[ $TRAVIS_OS_NAME == "osx" ]]; then
wget https://repo.continuum.io/miniconda/Miniconda3-latest-MacOSX-x86_64.sh -O miniconda.sh;
Expand All @@ -52,7 +62,7 @@ install:
- conda install -q -c exaanalytics exa>=0.5.24
- conda install -q -c conda-forge six>=1.0 numexpr>=2.0 ipywidgets>=7.0 bokeh scipy>=1.4
- conda install -q -c conda-forge coveralls coverage pytest pytest-cov
- conda install -q -c anaconda h5py
- conda install -q -c anaconda h5py selenium
- if [[ ${TRAVIS_OS_NAME} == "linux" ]] && [[ ${TRAVIS_PULL_REQUEST} == false ]] && [[ ${TRAVIS_PULL_REQUEST_BRANCH} == "" ]] && [[ ${TRAVIS_BRANCH} == "master" ]]; then
conda install -q -c conda-forge sphinx sphinx_rtd_theme ply pandoc pypandoc nbsphinx ipython;
conda install -q conda-build conda-verify anaconda-client twine;
Expand Down
30 changes: 14 additions & 16 deletions auto_widget.py
Original file line number Diff line number Diff line change
Expand Up @@ -17,8 +17,8 @@

"""
import os
import uuid
import shutil
from uuid import uuid4
from time import sleep
import subprocess as sp

Expand All @@ -32,12 +32,14 @@


PORT = 8889
TOKEN = str(uuid.uuid4())
CONSOLE_PORT = 9222
TOKEN = str(uuid4())
TIMEOUT = 30


def start_notebook_server():
os.makedirs(TOKEN, exist_ok=True)
return sp.Popen(['jupyter', 'notebook',
return sp.Popen(['jupyter', 'notebook', '--no-browser',
f'--NotebookApp.port={PORT}',
f'--NotebookApp.token={TOKEN}'],
stdout=sp.PIPE, stderr=sp.PIPE,
Expand All @@ -55,26 +57,20 @@ def click_by_css(driver, wait, css):
def run_notebook_widget():
options = Options()

options.binary_location = os.getenv('BROWSER')
options.binary_location = os.getenv('BROWSER', 'usr/bin/google-chrome-stable')
options.headless = True
options.add_argument('--no-sandbox')
options.add_argument('--disable-gpu')
options.add_argument('--disable-extensions')
options.add_argument('--disable-dev-shm-usage')

capabilities = {
'browserName': 'chrome',
'chromeOptions': {
'useAutomationExtension': False,
'args': ['--disable-extensions'],
}
}
options.add_argument(f'--remote-debugging-port={CONSOLE_PORT}')

notebook = f'http://localhost:{PORT}/?token={TOKEN}'
print(notebook)

with webdriver.Chrome(options=options, desired_capabilities=capabilities) as driver:
wait = WebDriverWait(driver, 10)
with webdriver.Chrome(options=options) as driver:
wait = WebDriverWait(driver, TIMEOUT)
driver.get(notebook)
print("hack to get around failed to load extension window")
ActionChains(driver).key_down(Keys.ENTER).key_up(Keys.ENTER).perform()

# click on new notebook dropdown
click_by_css(driver, wait, '#new-dropdown-button')
Expand Down Expand Up @@ -109,6 +105,8 @@ def run_notebook_widget():
'> div.output > div > div.output_subarea.jupyter-widgets-view > div > canvas')
click_by_css(driver, wait, scene)

driver.get_screenshot_as_file(f'{TOKEN}/widget.png')

print('interacted with scene')

# shut down the new notebook
Expand Down
56 changes: 38 additions & 18 deletions install-chromedriver.sh
Original file line number Diff line number Diff line change
@@ -1,38 +1,58 @@
#!/usr/bin/env bash

echo """
Installer script to set up chromedriver for selenium
on WSL. This allows for running selenium automated
browser tests.
Installer script to set up chromedriver for selenium.
First installs some linux dependencies for this script.
Then installs google-chrome-stable from google repository.
Uses that version of chrome to install chromedriver into PATH.
This should work for linux systems to run headless selenium
tests against chrome.

Needs approximately the following in the bash environment:
On WSL, however, installing chrome this way does not work in
headless mode. You can still run the selenium tests by pointing
to the chrome executable path from Windows.

Note:
WSL environment should look something like:
tjduigna marked this conversation as resolved.
Show resolved Hide resolved

export DISPLAY=:0
export BROWSER=/mnt/c/Program\ Files\ \(x86\)/Google/Chrome/Application/chrome.exe

Depending on chrome version, please update CHROME_SUFFIX.
If on latest, CHROME_SUFFIX can be "".
"""

CHROME_WINDOWS_MAJOR_VER=84
CHROME_SUFFIX="_${CHROME_WINDOWS_MAJOR_VER}"
ON_WSL=1 # 1 if on WSL
CHROME_WINDOWS_MAJOR_VER=84 # check your chrome version

# ======

CHROME_DRIVER_VERSION=$(curl -sS https://chromedriver.storage.googleapis.com/LATEST_RELEASE${CHROME_SUFFIX})
CHROME_DRIVER_ARTIFACT=chromedriver_linux64.zip
CHROME_DRIVER_DEST=/usr/local/bin/chromedriver
CHROME_DEB=google-chrome-stable_current_amd64.deb

# Clean workspace
rm ./$CHROME_DRIVER_ARTIFACT
sudo rm $CHROME_DRIVER_DEST
rm ./${CHROME_DRIVER_ARTIFACT}
sudo rm ${CHROME_DRIVER_DEST}
rm ./${CHROME_DEB}

# Install dependencies
sudo apt-get install -y openjdk-8-jre-headless xvfb libxi6 libgconf-2-4

if [[ "${ON_WSL}" == 0 ]]; then
# Download chrome if normal linux
wget -q -O - https://dl.google.com/linux/linux_signing_key.pub | sudo apt-key add -
wget https://dl.google.com/linux/direct/${CHROME_DEB}
sudo dpkg -i ${CHROME_DEB}
sudo apt -f install
sudo dpkg -i ${CHROME_DEB}
CHROME_DRIVER_VERSION=$(google-chrome-stable --version | cut -d ' ' -f 3)
else
CHROME_SUFFIX="_${CHROME_WINDOWS_MAJOR_VER}"
CHROME_DRIVER_VERSION=$(curl -sS https://chromedriver.storage.googleapis.com/LATEST_RELEASE${CHROME_SUFFIX})
fi

# Install chromedriver
wget -N https://chromedriver.storage.googleapis.com/$CHROME_DRIVER_VERSION/$CHROME_DRIVER_ARTIFACT -P ./
unzip ./$CHROME_DRIVER_ARTIFACT -d ./
rm ./$CHROME_DRIVER_ARTIFACT
sudo mv -f ./chromedriver $CHROME_DRIVER_DEST
sudo chown root:root $CHROME_DRIVER_DEST
sudo chmod 0755 $CHROME_DRIVER_DEST
wget -N https://chromedriver.storage.googleapis.com/${CHROME_DRIVER_VERSION}/${CHROME_DRIVER_ARTIFACT} -P ./
unzip ./${CHROME_DRIVER_ARTIFACT} -d ./
rm ./${CHROME_DRIVER_ARTIFACT}
sudo mv -f ./chromedriver ${CHROME_DRIVER_DEST}
sudo chown root:root ${CHROME_DRIVER_DEST}
sudo chmod 0755 ${CHROME_DRIVER_DEST}
4 changes: 2 additions & 2 deletions js/src/scene.ts
Original file line number Diff line number Diff line change
Expand Up @@ -21,14 +21,14 @@ export class SceneModel extends DOMWidgetModel {
defaults(): any {
return {
...super.defaults(),
// eslint-disable naming-convention
// eslint-disable
_model_name: 'SceneModel',
_view_name: 'SceneView',
_model_module_version: semver,
_view_module_version: semver,
_model_module: 'exatomic',
_view_module: 'exatomic',
// eslint-enable naming-convention
// eslint-enable
width: 200,
height: 200,
}
Expand Down