Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
P
pyodide
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Boxiang Sun
pyodide
Commits
65817abc
Commit
65817abc
authored
Sep 12, 2018
by
Michael Droettboom
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Add test
parent
bf68705e
Changes
6
Hide whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
84 additions
and
12 deletions
+84
-12
Makefile
Makefile
+1
-6
test/conftest.py
test/conftest.py
+18
-5
test/data.cgi
test/data.cgi
+4
-0
test/largish.json.cgi
test/largish.json.cgi
+33
-0
test/test_pandas.py
test/test_pandas.py
+19
-0
test/test_python.py
test/test_python.py
+9
-1
No files found.
Makefile
View file @
65817abc
...
@@ -21,7 +21,7 @@ LDFLAGS=\
...
@@ -21,7 +21,7 @@ LDFLAGS=\
-s
MODULARIZE
=
1
\
-s
MODULARIZE
=
1
\
$(CPYTHONROOT)
/installs/python-
$(PYVERSION)
/lib/libpython
$(PYMINOR)
.a
\
$(CPYTHONROOT)
/installs/python-
$(PYVERSION)
/lib/libpython
$(PYMINOR)
.a
\
-s
"BINARYEN_METHOD='native-wasm'"
\
-s
"BINARYEN_METHOD='native-wasm'"
\
-s
TOTAL_MEMORY
=
536870912
\
-s
TOTAL_MEMORY
=
1073741824
\
-s
ALLOW_MEMORY_GROWTH
=
1
\
-s
ALLOW_MEMORY_GROWTH
=
1
\
-s
MAIN_MODULE
=
1
\
-s
MAIN_MODULE
=
1
\
-s
EMULATED_FUNCTION_POINTERS
=
1
\
-s
EMULATED_FUNCTION_POINTERS
=
1
\
...
@@ -51,7 +51,6 @@ all: build/pyodide.asm.js \
...
@@ -51,7 +51,6 @@ all: build/pyodide.asm.js \
build/renderedhtml.css
\
build/renderedhtml.css
\
build/test.data
\
build/test.data
\
build/packages.json
\
build/packages.json
\
build/test_data.txt
\
build/test.html
build/test.html
...
@@ -108,10 +107,6 @@ test: all
...
@@ -108,10 +107,6 @@ test: all
pytest
test
/
-v
pytest
test
/
-v
build/test_data.txt
:
test/data.txt
cp test
/data.txt build/test_data.txt
lint
:
lint
:
flake8 src
flake8 src
flake8
test
flake8
test
...
...
test/conftest.py
View file @
65817abc
...
@@ -214,16 +214,29 @@ def run_web_server(q):
...
@@ -214,16 +214,29 @@ def run_web_server(q):
print
(
"Running webserver..."
)
print
(
"Running webserver..."
)
os
.
chdir
(
BUILD_PATH
)
os
.
chdir
(
BUILD_PATH
)
Handler
=
http
.
server
.
SimpleHTTPRequestHandler
Handler
.
extensions_map
[
'.wasm'
]
=
'application/wasm'
def
dummy_log
(
*
args
,
**
kwargs
):
class
Handler
(
http
.
server
.
CGIHTTPRequestHandler
):
pass
def
translate_path
(
self
,
path
):
Handler
.
log_message
=
dummy_log
if
path
.
startswith
(
'/test/'
):
return
TEST_PATH
/
path
[
6
:]
return
super
(
Handler
,
self
).
translate_path
(
path
)
def
is_cgi
(
self
):
if
self
.
path
.
startswith
(
'/test/'
)
and
self
.
path
.
endswith
(
'.cgi'
):
self
.
cgi_info
=
'/test'
,
self
.
path
[
6
:]
return
True
return
False
def
log_message
(
self
,
*
args
,
**
kwargs
):
pass
Handler
.
extensions_map
[
'.wasm'
]
=
'application/wasm'
with
socketserver
.
TCPServer
((
""
,
0
),
Handler
)
as
httpd
:
with
socketserver
.
TCPServer
((
""
,
0
),
Handler
)
as
httpd
:
host
,
port
=
httpd
.
server_address
host
,
port
=
httpd
.
server_address
print
(
"serving at port"
,
port
)
print
(
"serving at port"
,
port
)
httpd
.
server_name
=
'test-server'
httpd
.
server_port
=
port
q
.
put
(
port
)
q
.
put
(
port
)
def
service_actions
():
def
service_actions
():
...
...
test/data.cgi
0 → 100755
View file @
65817abc
#!/usr/bin/env python
print
(
"Content-Type: text/text"
)
print
()
print
(
"HELLO"
)
test/largish.json.cgi
0 → 100755
View file @
65817abc
#!/usr/bin/env python
import
json
import
random
import
sys
random
.
seed
(
0
)
print
(
"Content-Type: application/json"
)
print
()
columns
=
[
(
'column0'
,
lambda
:
'XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX'
),
(
'column1'
,
lambda
:
random
.
choice
([
'notification-interval-longer'
,
'notification-interval-short'
,
'control'
])),
(
'column2'
,
lambda
:
random
.
choice
([
True
,
False
])),
(
'column3'
,
lambda
:
random
.
randint
(
0
,
4
)),
(
'column4'
,
lambda
:
random
.
randint
(
0
,
4
)),
(
'column5'
,
lambda
:
random
.
randint
(
0
,
4
)),
(
'column6'
,
lambda
:
random
.
randint
(
0
,
4
)),
(
'column7'
,
lambda
:
random
.
randint
(
0
,
4
))
]
N_ROWS
=
91746
data
=
{}
for
name
,
generator
in
columns
:
column
=
{}
for
i
in
range
(
N_ROWS
):
column
[
str
(
i
)]
=
generator
()
data
[
name
]
=
column
json
.
dump
(
data
,
sys
.
stdout
)
test/test_pandas.py
View file @
65817abc
...
@@ -16,3 +16,22 @@ def test_extra_import(selenium, request):
...
@@ -16,3 +16,22 @@ def test_extra_import(selenium, request):
selenium
.
load_package
(
"pandas"
)
selenium
.
load_package
(
"pandas"
)
selenium
.
run
(
"from pandas import Series, DataFrame, Panel"
)
selenium
.
run
(
"from pandas import Series, DataFrame, Panel"
)
def
test_load_largish_file
(
selenium_standalone
,
request
):
selenium
=
selenium_standalone
if
selenium
.
browser
==
'chrome'
:
request
.
applymarker
(
pytest
.
mark
.
xfail
(
run
=
False
,
reason
=
'chrome not supported'
))
selenium
.
load_package
(
"pandas"
)
selenium
.
load_package
(
"matplotlib"
)
selenium
.
run
(
"""
import pyodide
import matplotlib.pyplot as plt
import pandas as pd
pd.read_json(pyodide.open_url('test/largish.json.cgi'))
"""
)
test/test_python.py
View file @
65817abc
...
@@ -317,7 +317,15 @@ def test_open_url(selenium):
...
@@ -317,7 +317,15 @@ def test_open_url(selenium):
assert
selenium
.
run
(
assert
selenium
.
run
(
"""
"""
import pyodide
import pyodide
pyodide.open_url('test_data.txt').read()
pyodide.open_url('test/data.txt').read()
"""
)
==
'HELLO
\
n
'
def
test_open_url_cgi
(
selenium
):
assert
selenium
.
run
(
"""
import pyodide
pyodide.open_url('test/data.cgi').read()
"""
)
==
'HELLO
\
n
'
"""
)
==
'HELLO
\
n
'
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment