Commit 8b99405d authored by Jason Madden's avatar Jason Madden

Let PyPy fail on Appveyor for now. Also bump Travis PyPy to 5.9.0 because I...

Let PyPy fail on Appveyor for now. Also bump Travis PyPy to 5.9.0 because I can't reproduce the test__makefile_ref failure locally on 5.9.0. Fixes #1029.
parent 45c5c39f
...@@ -117,8 +117,8 @@ PY27=$(BUILD_RUNTIMES)/snakepit/python2.7.14 ...@@ -117,8 +117,8 @@ PY27=$(BUILD_RUNTIMES)/snakepit/python2.7.14
PY34=$(BUILD_RUNTIMES)/snakepit/python3.4.7 PY34=$(BUILD_RUNTIMES)/snakepit/python3.4.7
PY35=$(BUILD_RUNTIMES)/snakepit/python3.5.4 PY35=$(BUILD_RUNTIMES)/snakepit/python3.5.4
PY36=$(BUILD_RUNTIMES)/snakepit/python3.6.2 PY36=$(BUILD_RUNTIMES)/snakepit/python3.6.2
PYPY=$(BUILD_RUNTIMES)/snakepit/pypy580 PYPY=$(BUILD_RUNTIMES)/snakepit/pypy590
PYPY3=$(BUILD_RUNTIMES)/snakepit/pypy3.5_580 PYPY3=$(BUILD_RUNTIMES)/snakepit/pypy3.5_590
TOOLS=$(BUILD_RUNTIMES)/tools TOOLS=$(BUILD_RUNTIMES)/tools
...@@ -189,10 +189,10 @@ test-py36-libuv: $(PY36) ...@@ -189,10 +189,10 @@ test-py36-libuv: $(PY36)
GEVENT_CORE_CFFI_ONLY=libuv make test-py36 GEVENT_CORE_CFFI_ONLY=libuv make test-py36
test-pypy: $(PYPY) test-pypy: $(PYPY)
PYTHON=$(PYPY) PIP=pip PATH=$(BUILD_RUNTIMES)/versions/pypy580/bin:$(PATH) make develop toxtest PYTHON=$(PYPY) PIP=pip PATH=$(BUILD_RUNTIMES)/versions/pypy590/bin:$(PATH) make develop toxtest
test-pypy3: $(PYPY3) test-pypy3: $(PYPY3)
PYTHON=$(PYPY3) PIP=pip PATH=$(BUILD_RUNTIMES)/versions/pypy3.5_580/bin:$(PATH) make develop toxtest PYTHON=$(PYPY3) PIP=pip PATH=$(BUILD_RUNTIMES)/versions/pypy3.5_590/bin:$(PATH) make develop toxtest
test-py27-cffi: $(PY27) test-py27-cffi: $(PY27)
GEVENT_CORE_CFFI_ONLY=1 PYTHON=python2.7.14 PATH=$(BUILD_RUNTIMES)/versions/python2.7.14/bin:$(PATH) make develop toxtest GEVENT_CORE_CFFI_ONLY=1 PYTHON=python2.7.14 PATH=$(BUILD_RUNTIMES)/versions/python2.7.14/bin:$(PATH) make develop toxtest
......
...@@ -65,6 +65,10 @@ environment: ...@@ -65,6 +65,10 @@ environment:
# PYTHON_ARCH: "32" # PYTHON_ARCH: "32"
# PYTHON_EXE: python # PYTHON_EXE: python
matrix:
allow_failures:
- PYTHON_ID: "pypy"
install: install:
# If there is a newer build queued for the same PR, cancel this one. # If there is a newer build queued for the same PR, cancel this one.
# The AppVeyor 'rollout builds' option is supposed to serve the same # The AppVeyor 'rollout builds' option is supposed to serve the same
......
...@@ -97,10 +97,10 @@ for var in "$@"; do ...@@ -97,10 +97,10 @@ for var in "$@"; do
install 3.6.2 python3.6.2 install 3.6.2 python3.6.2
;; ;;
pypy) pypy)
install pypy2.7-5.8.0 pypy580 install pypy2.7-5.9.0 pypy590
;; ;;
pypy3) pypy3)
install pypy3.5-5.8.0 pypy3.5_580 install pypy3.5-5.9.0 pypy3.5_590
;; ;;
esac esac
done done
...@@ -324,13 +324,13 @@ class io(_base.IoMixin, watcher): ...@@ -324,13 +324,13 @@ class io(_base.IoMixin, watcher):
# See test__makefile_ref.TestSSL for examples. # See test__makefile_ref.TestSSL for examples.
# return # return
_dbg("Callback event for watcher", self._fd, "event", events) #_dbg("Callback event for watcher", self._fd, "event", events)
for watcher_ref in self._multiplex_watchers: for watcher_ref in self._multiplex_watchers:
watcher = watcher_ref() watcher = watcher_ref()
if not watcher or not watcher.callback: if not watcher or not watcher.callback:
continue continue
_dbg("Event for watcher", self._fd, events, watcher.events, events & watcher.events) #_dbg("Event for watcher", self._fd, events, watcher.events, events & watcher.events)
send_event = (events & watcher.events) or events < 0 send_event = (events & watcher.events) or events < 0
if send_event: if send_event:
......
...@@ -803,23 +803,24 @@ def disabled_gc(): ...@@ -803,23 +803,24 @@ def disabled_gc():
import re import re
# Linux/OS X/BSD platforms can implement this by calling out to lsof # Linux/OS X/BSD platforms can implement this by calling out to lsof
def _run_lsof():
import tempfile
pid = os.getpid()
fd, tmpname = tempfile.mkstemp('get_open_files')
os.close(fd)
lsof_command = 'lsof -p %s > %s' % (pid, tmpname)
if os.system(lsof_command):
# XXX: This prints to the console an annoying message: 'lsof is not recognized'
raise unittest.SkipTest("lsof failed")
with open(tmpname) as fobj:
data = fobj.read().strip()
os.remove(tmpname)
return data
if WIN: if WIN:
def _run_lsof(): def _run_lsof():
raise unittest.SkipTest("lsof not expected on Windows") raise unittest.SkipTest("lsof not expected on Windows")
else:
def _run_lsof():
import tempfile
pid = os.getpid()
fd, tmpname = tempfile.mkstemp('get_open_files')
os.close(fd)
lsof_command = 'lsof -p %s > %s' % (pid, tmpname)
if os.system(lsof_command):
# XXX: This prints to the console an annoying message: 'lsof is not recognized'
raise unittest.SkipTest("lsof failed")
with open(tmpname) as fobj:
data = fobj.read().strip()
os.remove(tmpname)
return data
def default_get_open_files(pipes=False): def default_get_open_files(pipes=False):
data = _run_lsof() data = _run_lsof()
......
...@@ -235,9 +235,13 @@ if LIBUV: ...@@ -235,9 +235,13 @@ if LIBUV:
'test_asyncore.DispatcherWithSendTests_UsePoll.test_send', 'test_asyncore.DispatcherWithSendTests_UsePoll.test_send',
'test_asyncore.DispatcherWithSendTests.test_send', 'test_asyncore.DispatcherWithSendTests.test_send',
# These, which use asyncore, faile with # These, which use asyncore, fail with
# 'NoneType is not iterable' on 'conn, addr = self.accept()' # 'NoneType is not iterable' on 'conn, addr = self.accept()'
# How could that be returning None? # That returns None when the underlying socket raises
# EWOULDBLOCK, which it will do because it's set to non-blocking
# both by gevent and by libuv (at the level below python's knowledge)
# I can *sometimes* reproduce these locally; it seems to be some sort
# of race condition.
'test_ftplib.TestFTPClass.test_acct', 'test_ftplib.TestFTPClass.test_acct',
'test_ftplib.TestFTPClass.test_all_errors', 'test_ftplib.TestFTPClass.test_all_errors',
'test_ftplib.TestFTPClass.test_cwd', 'test_ftplib.TestFTPClass.test_cwd',
...@@ -253,6 +257,20 @@ if LIBUV: ...@@ -253,6 +257,20 @@ if LIBUV:
'test_ftplib.TestFTPClass.test_pwd', 'test_ftplib.TestFTPClass.test_pwd',
'test_ftplib.TestFTPClass.test_quit', 'test_ftplib.TestFTPClass.test_quit',
'test_ftplib.TestFTPClass.test_makepasv', 'test_ftplib.TestFTPClass.test_makepasv',
'test_ftplib.TestFTPClass.test_rename',
'test_ftplib.TestFTPClass.test_retrbinary',
'test_ftplib.TestFTPClass.test_retrbinary_rest',
'test_ftplib.TestFTPClass.test_retrlines',
'test_ftplib.TestFTPClass.test_retrlines_too_long',
'test_ftplib.TestFTPClass.test_rmd',
'test_ftplib.TestFTPClass.test_sanitize',
'test_ftplib.TestFTPClass.test_set_pasv',
'test_ftplib.TestFTPClass.test_size',
'test_ftplib.TestFTPClass.test_storbinary',
'test_ftplib.TestFTPClass.test_storbinary_rest',
'test_ftplib.TestFTPClass.test_storlines',
'test_ftplib.TestFTPClass.test_storlines_too_long',
'test_ftplib.TestFTPClass.test_voidcmd',
# This one times out # This one times out
'test_ftplib.TestFTPClass.test_makeport', 'test_ftplib.TestFTPClass.test_makeport',
......
...@@ -54,7 +54,7 @@ def run_many(tests, expected=(), failfast=False, quiet=False): ...@@ -54,7 +54,7 @@ def run_many(tests, expected=(), failfast=False, quiet=False):
passed = {} passed = {}
NWORKERS = min(len(tests), NWORKERS) or 1 NWORKERS = min(len(tests), NWORKERS) or 1
print('thread pool size: %s' % NWORKERS) print('thread pool size:', NWORKERS, '\n')
pool = ThreadPool(NWORKERS) pool = ThreadPool(NWORKERS)
util.BUFFER_OUTPUT = NWORKERS > 1 util.BUFFER_OUTPUT = NWORKERS > 1
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment