mirror of
https://github.com/explosion/spaCy.git
synced 2025-01-26 09:14:32 +03:00
Skip test that fails on conda-forge on Windows
Our multi-processing test fails on conda-forge on windows, I think due to the way conda-forge executes the tests. It says too many processes open or something. We can add a patch to only skip the test on conda-forge, which is what I'm doing for the v2.2.2 release. It's better to keep the conda-forge and pip versions identical though, as the patches are harder to maintain.
This commit is contained in:
parent
56ad3a3988
commit
b1be2e99e9
|
@ -4,7 +4,7 @@ from __future__ import unicode_literals
|
||||||
import itertools
|
import itertools
|
||||||
|
|
||||||
import pytest
|
import pytest
|
||||||
from spacy.compat import is_python2
|
from spacy.compat import is_python2, is_windows
|
||||||
from spacy.gold import GoldParse
|
from spacy.gold import GoldParse
|
||||||
from spacy.language import Language
|
from spacy.language import Language
|
||||||
from spacy.tokens import Doc, Span
|
from spacy.tokens import Doc, Span
|
||||||
|
@ -110,8 +110,20 @@ def texts():
|
||||||
return data
|
return data
|
||||||
|
|
||||||
|
|
||||||
@pytest.mark.parametrize("n_process", [1, 2])
|
def test_language_pipe(nlp2, texts):
|
||||||
def test_language_pipe(nlp2, n_process, texts):
|
texts = texts * 10
|
||||||
|
expecteds = [nlp2(text) for text in texts]
|
||||||
|
docs = nlp2.pipe(texts, n_process=1, batch_size=2)
|
||||||
|
|
||||||
|
for doc, expected_doc in zip(docs, expecteds):
|
||||||
|
assert_docs_equal(doc, expected_doc)
|
||||||
|
|
||||||
|
@pytest.mark.skipif(
|
||||||
|
is_python2 or is_windows,
|
||||||
|
reason="python2 can't handle iterator properly? Fails windows conda-forge"
|
||||||
|
)
|
||||||
|
@pytest.mark.parametrize("n_process", [2, 3])
|
||||||
|
def test_language_pipe_multiprocess(nlp2, n_process, texts):
|
||||||
texts = texts * 10
|
texts = texts * 10
|
||||||
expecteds = [nlp2(text) for text in texts]
|
expecteds = [nlp2(text) for text in texts]
|
||||||
docs = nlp2.pipe(texts, n_process=n_process, batch_size=2)
|
docs = nlp2.pipe(texts, n_process=n_process, batch_size=2)
|
||||||
|
@ -123,7 +135,7 @@ def test_language_pipe(nlp2, n_process, texts):
|
||||||
@pytest.mark.skipif(
|
@pytest.mark.skipif(
|
||||||
is_python2, reason="python2 seems to be unable to handle iterator properly"
|
is_python2, reason="python2 seems to be unable to handle iterator properly"
|
||||||
)
|
)
|
||||||
@pytest.mark.parametrize("n_process", [1, 2])
|
@pytest.mark.parametrize("n_process", [1])
|
||||||
def test_language_pipe_stream(nlp2, n_process, texts):
|
def test_language_pipe_stream(nlp2, n_process, texts):
|
||||||
# check if nlp.pipe can handle infinite length iterator properly.
|
# check if nlp.pipe can handle infinite length iterator properly.
|
||||||
stream_texts = itertools.cycle(texts)
|
stream_texts = itertools.cycle(texts)
|
||||||
|
@ -134,3 +146,19 @@ def test_language_pipe_stream(nlp2, n_process, texts):
|
||||||
n_fetch = 20
|
n_fetch = 20
|
||||||
for doc, expected_doc in itertools.islice(zip(docs, expecteds), n_fetch):
|
for doc, expected_doc in itertools.islice(zip(docs, expecteds), n_fetch):
|
||||||
assert_docs_equal(doc, expected_doc)
|
assert_docs_equal(doc, expected_doc)
|
||||||
|
|
||||||
|
@pytest.mark.skipif(
|
||||||
|
is_python2 or is_windows,
|
||||||
|
reason="python2 can't handle iterator properly? Fails windows conda-forge"
|
||||||
|
)
|
||||||
|
@pytest.mark.parametrize("n_process", [2, 3])
|
||||||
|
def test_language_pipe_stream_multiprocess(nlp2, n_process, texts):
|
||||||
|
# check if nlp.pipe can handle infinite length iterator properly.
|
||||||
|
stream_texts = itertools.cycle(texts)
|
||||||
|
texts0, texts1 = itertools.tee(stream_texts)
|
||||||
|
expecteds = (nlp2(text) for text in texts0)
|
||||||
|
docs = nlp2.pipe(texts1, n_process=n_process, batch_size=2)
|
||||||
|
|
||||||
|
n_fetch = 20
|
||||||
|
for doc, expected_doc in itertools.islice(zip(docs, expecteds), n_fetch):
|
||||||
|
assert_docs_equal(doc, expected_doc)
|
||||||
|
|
Loading…
Reference in New Issue
Block a user