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
30195bfa
Commit
30195bfa
authored
Aug 17, 2018
by
Roman Yurchak
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Marking known failures in test_run_core_python_test
parent
9ad6830e
Changes
2
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
31 additions
and
12 deletions
+31
-12
test/python_tests.txt
test/python_tests.txt
+10
-5
test/test_python.py
test/test_python.py
+21
-7
No files found.
test/python_tests.txt
View file @
30195bfa
# Test modules with a failure reason after their name are skipped.
# Test modules with a failure reason after their name are either skipped
# or marked as a known failure in pytest.
#
#
#
Reason codes are
:
#
Following reason codes are skipped
:
# - platform-specific: This is testing something about a particular platform
# - platform-specific: This is testing something about a particular platform
# that isn't relevant here
# that isn't relevant here
# - audioop: Requires the audioop module
# - audioop: Requires the audioop module
...
@@ -17,11 +18,15 @@
...
@@ -17,11 +18,15 @@
# implementation of date/time formatting in strftime and strptime
# implementation of date/time formatting in strftime and strptime
# - permissions: Issues with the test writing to the virtual filesystem
# - permissions: Issues with the test writing to the virtual filesystem
# - locale: Fails due to include locale implementation.
# - locale: Fails due to include locale implementation.
# - nonsense: This functionality doesn't make sense in this context. Includes
# things like `pip`, `distutils`
#
# While the below reason codes are marked as a known failure:
# - crash: The Python interpreter just stopped without a traceback. Will require
# - crash: The Python interpreter just stopped without a traceback. Will require
# further investigation. This usually seems to be caused by calling into a
# further investigation. This usually seems to be caused by calling into a
# system function that doesn't behave as one would expect.
# system function that doesn't behave as one would expect.
# -
nonsense: This functionality doesn't make sense in this context. Includes
# -
crash_chrome: Same as crash but only affecting Chrome
#
things like `pip`, `distutils`
#
- crash_firefox: Same as crash but only affecting Firefox
test___all__
test___all__
test___future__
test___future__
...
@@ -101,7 +106,7 @@ test_codeop
...
@@ -101,7 +106,7 @@ test_codeop
test_collections
test_collections
test_colorsys
test_colorsys
test_compare
test_compare
test_compile
test_compile
crash-chrome
test_compileall crash
test_compileall crash
test_complex
test_complex
test_concurrent_futures
test_concurrent_futures
...
...
test/test_python.py
View file @
30195bfa
...
@@ -284,12 +284,18 @@ def test_open_url(selenium):
...
@@ -284,12 +284,18 @@ def test_open_url(selenium):
@
pytest
.
mark
.
flaky
(
reruns
=
2
)
@
pytest
.
mark
.
flaky
(
reruns
=
2
)
def
test_run_core_python_test
(
python_test
,
selenium
):
def
test_run_core_python_test
(
python_test
,
selenium
,
request
):
selenium
.
load_package
(
'test'
)
selenium
.
load_package
(
'test'
)
name
,
error_flags
=
python_test
if
error_flags
:
request
.
applymarker
(
pytest
.
mark
.
xfail
(
run
=
False
,
reason
=
'known failure with code "{}"'
.
format
(
error_flags
)))
try
:
try
:
selenium
.
run
(
selenium
.
run
(
"from test.libregrtest import main
\
n
"
"from test.libregrtest import main
\
n
"
"main(['{}'], verbose=True, verbose3=True)"
.
format
(
python_test
))
"main(['{}'], verbose=True, verbose3=True)"
.
format
(
name
))
except
selenium
.
JavascriptException
as
e
:
except
selenium
.
JavascriptException
as
e
:
assert
'SystemExit: 0'
in
str
(
e
)
assert
'SystemExit: 0'
in
str
(
e
)
...
@@ -297,17 +303,25 @@ def test_run_core_python_test(python_test, selenium):
...
@@ -297,17 +303,25 @@ def test_run_core_python_test(python_test, selenium):
def
pytest_generate_tests
(
metafunc
):
def
pytest_generate_tests
(
metafunc
):
if
'python_test'
in
metafunc
.
fixturenames
:
if
'python_test'
in
metafunc
.
fixturenames
:
test_modules
=
[]
test_modules
=
[]
test_modules_ids
=
[]
if
'CIRCLECI'
not
in
os
.
environ
or
True
:
if
'CIRCLECI'
not
in
os
.
environ
or
True
:
with
open
(
with
open
(
Path
(
__file__
).
parent
/
"python_tests.txt"
)
as
fp
:
Path
(
__file__
).
parent
/
"python_tests.txt"
)
as
fp
:
for
line
in
fp
:
for
line
in
fp
:
line
=
line
.
strip
()
line
=
line
.
strip
()
if
line
.
startswith
(
'#'
):
if
line
.
startswith
(
'#'
)
or
not
line
:
continue
continue
parts
=
line
.
split
()
error_flags
=
line
.
split
()
if
len
(
parts
)
==
1
:
name
=
error_flags
.
pop
(
0
)
test_modules
.
append
(
parts
[
0
])
if
(
not
error_flags
metafunc
.
parametrize
(
"python_test"
,
test_modules
)
or
set
(
error_flags
).
intersection
(
{
'crash'
,
'crash-chrome'
,
'crash-firefox'
})):
test_modules
.
append
((
name
,
error_flags
))
# explicitly define test ids to keep
# a human readable test name in pytest
test_modules_ids
.
append
(
name
)
metafunc
.
parametrize
(
"python_test"
,
test_modules
,
ids
=
test_modules_ids
)
def
test_recursive_repr
(
selenium
):
def
test_recursive_repr
(
selenium
):
...
...
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