diff options
Diffstat (limited to 'dev-python')
-rw-r--r-- | dev-python/pytest/Manifest | 1 | ||||
-rw-r--r-- | dev-python/pytest/files/pytest-2.8.7-skip-test-on-pypy.patch | 550 | ||||
-rw-r--r-- | dev-python/pytest/pytest-2.8.7.ebuild | 76 |
3 files changed, 627 insertions, 0 deletions
diff --git a/dev-python/pytest/Manifest b/dev-python/pytest/Manifest index 3ef55746974..acd5abdcd47 100644 --- a/dev-python/pytest/Manifest +++ b/dev-python/pytest/Manifest @@ -3,3 +3,4 @@ DIST pytest-2.8.2.tar.gz 563955 SHA256 da2fc57320dd11f621d166634c52b989aa2291af1 DIST pytest-2.8.3.tar.gz 880441 SHA256 37d950e93c1fd7e04d816a3ca4a5226ea2531c6d531c8284ad9b88848417e720 SHA512 04dd9041729d83b98a15cef22aac65dfb95cd3bf6b71a580ff91e8738f9a1ad5ee46fae45c950342e4a0162e38c875299a46fc69ec74702f36a1e36ef76dc0d6 WHIRLPOOL 78149cdcc25dc478ae004b0a54b333edcad0268ce5e66efe9878b0bcaff0e33d227513f84040f3aa53967afa5ffc51ecef0e6003814c09925fdf9e6a4921d88a DIST pytest-2.8.4.tar.gz 568888 SHA256 ca8afa5e216acfba6df7f26f2ef8a45baedf6a952e6b2f033ab55ec7e0a679eb SHA512 42e2949b66184cf2cecb7c803871639c1a3c887a48fc43580fe87f432507b9457c3a7c0b3bb620060e3eeb2db2178dfc35aba19022812497a917fdfa2ce5fd45 WHIRLPOOL 7ee539c61216463ccdaf5e09581cc1de82ffc6f6fb99dba04fa7d4eefb628c457c828ce9f8307477b5f95b997a4fd917f4818262ef4e1867cf0c10f9d2467bc2 DIST pytest-2.8.5.zip 664063 SHA256 44bb32fb3925b5a284ceee1af55e0a63d25436ec415232089403eed3a347667e SHA512 6489225732aa3b2130d5e533f9e013fc7cfeb820d43c341e0adefa2b397713366787d68461805b368a7c04dfeb421b5195ff96a44a9d10377b1da8b9760bdc8f WHIRLPOOL cd264e72db332163570641d7b7c5def59d0f3357697168a3418c50f0eb5461d5abdb17a7164bcd35c285a1221e4f51619029253c4eea18b327c45d2213ebcaad +DIST pytest-2.8.7.tar.gz 564943 SHA256 fc4c86be54fce08e4b85b646a736efa18c6cde7599c1d2919f4f74629e018baf SHA512 c7f626ceb599811caeab4646389a2c489dd22d766c772d6ca686098cef9a11dca47ef41a4a4b811110f358bca1f1a678b549b2adfea48317ae70cf166289b371 WHIRLPOOL c3849f1a9f62c05c1ce20593f32ee513aee87853914be4099503cd47b068732df99605a0a4db9a3a7add4ef2a85f4d5376acf1a2e3f48f5d438433f200cb6196 diff --git a/dev-python/pytest/files/pytest-2.8.7-skip-test-on-pypy.patch b/dev-python/pytest/files/pytest-2.8.7-skip-test-on-pypy.patch new file mode 100644 index 00000000000..f82522ffee0 --- /dev/null +++ b/dev-python/pytest/files/pytest-2.8.7-skip-test-on-pypy.patch @@ -0,0 +1,550 @@ + testing/acceptance_test.py | 5 +++++ + testing/python/collect.py | 3 +++ + testing/python/fixture.py | 14 ++++++++++++++ + testing/python/integration.py | 1 + + testing/python/metafunc.py | 3 +++ + testing/test_assertion.py | 5 +++++ + testing/test_assertrewrite.py | 3 +++ + testing/test_capture.py | 6 ++++++ + testing/test_collection.py | 1 + + testing/test_config.py | 3 +++ + testing/test_conftest.py | 3 +++ + testing/test_helpconfig.py | 1 + + testing/test_junitxml.py | 1 + + testing/test_mark.py | 1 + + testing/test_monkeypatch.py | 1 + + testing/test_skipping.py | 3 +++ + testing/test_terminal.py | 2 ++ + testing/test_unittest.py | 3 +++ + 18 files changed, 59 insertions(+) + +diff --git a/testing/acceptance_test.py b/testing/acceptance_test.py +index b9a3fa3..7875d94 100644 +--- a/testing/acceptance_test.py ++++ b/testing/acceptance_test.py +@@ -127,6 +127,7 @@ class TestGeneralUsage: + "*ERROR: not found:*%s" %(p2.basename,) + ]) + ++ @pytest.mark.skipif('"__pypy__" in sys.modules')
+ def test_issue486_better_reporting_on_conftest_load_failure(self, testdir): + testdir.makepyfile("") + testdir.makeconftest("import qwerty") +@@ -209,6 +210,8 @@ class TestGeneralUsage: + result = testdir.runpython(p) + assert not result.ret + ++ # https://github.com/pytest-dev/pytest/issues/1162
++ @pytest.mark.skipif('"__pypy__" in sys.modules')
+ def test_issue109_sibling_conftests_not_loaded(self, testdir): + sub1 = testdir.tmpdir.mkdir("sub1") + sub2 = testdir.tmpdir.mkdir("sub2") +@@ -350,6 +353,7 @@ class TestGeneralUsage: + res = testdir.runpytest(p.basename) + assert res.ret == 0 + ++ @pytest.mark.skipif('"__pypy__" in sys.modules')
+ def test_unknown_option(self, testdir): + result = testdir.runpytest("--qwlkej") + result.stderr.fnmatch_lines(""" +@@ -657,6 +661,7 @@ class TestDurations: + ]) + + ++@pytest.mark.skipif('"__pypy__" in sys.modules')
+ class TestDurationWithFixture: + source = """ + import time +diff --git a/testing/python/collect.py b/testing/python/collect.py +index bebc133..1cf0a80 100644 +--- a/testing/python/collect.py ++++ b/testing/python/collect.py +@@ -27,6 +27,7 @@ class TestModule: + "*HINT*", + ]) + ++ @pytest.mark.skipif('"__pypy__" in sys.modules')
+ def test_import_prepend_append(self, testdir, monkeypatch): + syspath = list(sys.path) + monkeypatch.setattr(sys, "path", syspath) +@@ -57,6 +58,7 @@ class TestModule: + pytest.raises(ImportError, lambda: modcol.obj) + + class TestClass: ++ @pytest.mark.skipif('"__pypy__" in sys.modules')
+ def test_class_with_init_warning(self, testdir): + testdir.makepyfile(""" + class TestClass1: +@@ -659,6 +661,7 @@ class TestConftestCustomization: + l = modcol.collect() + assert '_hello' not in l + ++@pytest.mark.skipif('"__pypy__" in sys.modules')
+ def test_setup_only_available_in_subdir(testdir): + sub1 = testdir.mkpydir("sub1") + sub2 = testdir.mkpydir("sub2") +diff --git a/testing/python/fixture.py b/testing/python/fixture.py +index 2031764..22e620a 100644 +--- a/testing/python/fixture.py ++++ b/testing/python/fixture.py +@@ -83,6 +83,7 @@ class TestFillFixtures: + "*1 passed*" + ]) + ++ @pytest.mark.skipif('"__pypy__" in sys.modules')
+ def test_conftest_funcargs_only_available_in_subdir(self, testdir): + sub1 = testdir.mkpydir("sub1") + sub2 = testdir.mkpydir("sub2") +@@ -606,6 +607,7 @@ class TestRequestBasic: + reprec = testdir.inline_run("-v") + reprec.assertoutcome(passed=3) + ++ @pytest.mark.skipif('"__pypy__" in sys.modules')
+ def test_fixtures_sub_subdir_normalize_sep(self, testdir): + # this tests that normalization of nodeids takes place + b = testdir.mkdir("tests").mkdir("unit") +@@ -953,6 +955,7 @@ class TestFixtureUsages: + "*2 passed*" + ]) + ++ @pytest.mark.skipif('"__pypy__" in sys.modules')
+ def test_factory_uses_unknown_funcarg_as_dependency_error(self, testdir): + testdir.makepyfile(""" + import pytest +@@ -1049,6 +1052,7 @@ class TestFixtureUsages: + reprec = testdir.inline_run() + reprec.assertoutcome(passed=2) + ++ @pytest.mark.skipif('"__pypy__" in sys.modules')
+ def test_usefixtures_seen_in_showmarkers(self, testdir): + result = testdir.runpytest("--markers") + result.stdout.fnmatch_lines(""" +@@ -1157,6 +1161,7 @@ class TestFixtureManagerParseFactories: + reprec = testdir.inline_run("-s") + reprec.assertoutcome(passed=1) + ++ @pytest.mark.skipif('"__pypy__" in sys.modules')
+ def test_parsefactories_relative_node_ids(self, testdir): + # example mostly taken from: + # https://mail.python.org/pipermail/pytest-dev/2014-September/002617.html +@@ -1305,6 +1310,7 @@ class TestAutouseDiscovery: + reprec = testdir.inline_run("-s") + reprec.assertoutcome(failed=0, passed=0) + ++ @pytest.mark.skipif('"__pypy__" in sys.modules')
+ def test_autouse_in_conftests(self, testdir): + a = testdir.mkdir("a") + b = testdir.mkdir("a1") +@@ -1890,6 +1896,7 @@ class TestFixtureMarker: + l = reprec.getcalls("pytest_runtest_call")[0].item.module.l + assert l == [1,1,2,2] + ++ @pytest.mark.skipif('"__pypy__" in sys.modules')
+ def test_module_parametrized_ordering(self, testdir): + testdir.makeconftest(""" + import pytest +@@ -1936,6 +1943,7 @@ class TestFixtureMarker: + test_mod1.py::test_func1[m2] PASSED + """) + ++ @pytest.mark.skipif('"__pypy__" in sys.modules')
+ def test_class_ordering(self, testdir): + testdir.makeconftest(""" + import pytest +@@ -1984,6 +1992,7 @@ class TestFixtureMarker: + test_class_ordering.py::TestClass::test_3[2-b] PASSED + """) + ++ @pytest.mark.skipif('"__pypy__" in sys.modules')
+ def test_parametrize_separated_order_higher_scope_first(self, testdir): + testdir.makepyfile(""" + import pytest +@@ -2028,6 +2037,7 @@ class TestFixtureMarker: + pprint.pprint(list(zip(l, expected))) + assert l == expected + ++ @pytest.mark.skipif('"__pypy__" in sys.modules')
+ def test_parametrized_fixture_teardown_order(self, testdir): + testdir.makepyfile(""" + import pytest +@@ -2065,6 +2075,7 @@ class TestFixtureMarker: + """) + assert "error" not in result.stdout.str() + ++ @pytest.mark.skipif('"__pypy__" in sys.modules')
+ def test_fixture_finalizer(self, testdir): + testdir.makeconftest(""" + import pytest +@@ -2385,6 +2396,7 @@ class TestErrors: + "*1 error*", + ]) + ++ @pytest.mark.skipif('"__pypy__" in sys.modules')
+ def test_issue498_fixture_finalizer_failing(self, testdir): + testdir.makepyfile(""" + import pytest +@@ -2431,6 +2443,7 @@ class TestErrors: + "*1 error*", + ]) + ++@pytest.mark.skipif('"__pypy__" in sys.modules')
+ class TestShowFixtures: + def test_funcarg_compat(self, testdir): + config = testdir.parseconfigure("--funcargs") +@@ -2561,6 +2574,7 @@ class TestShowFixtures: + """) + + ++@pytest.mark.skipif('"__pypy__" in sys.modules')
+ class TestContextManagerFixtureFuncs: + def test_simple(self, testdir): + testdir.makepyfile(""" +diff --git a/testing/python/integration.py b/testing/python/integration.py +index 0c436e3..1d0b4ee 100644 +--- a/testing/python/integration.py ++++ b/testing/python/integration.py +@@ -202,6 +202,7 @@ class TestMockDecoration: + + + class TestReRunTests: ++ @pytest.mark.skipif('"__pypy__" in sys.modules')
+ def test_rerun(self, testdir): + testdir.makeconftest(""" + from _pytest.runner import runtestprotocol +diff --git a/testing/python/metafunc.py b/testing/python/metafunc.py +index 111ca61..cd2e86d 100644 +--- a/testing/python/metafunc.py ++++ b/testing/python/metafunc.py +@@ -475,6 +475,7 @@ class TestMetafunc: + reprec = testdir.inline_run() + reprec.assertoutcome(passed=2) + ++ @pytest.mark.skipif('"__pypy__" in sys.modules')
+ def test_parametrize_class_scenarios(self, testdir): + testdir.makepyfile(""" + # same as doc/en/example/parametrize scenario example +@@ -766,6 +767,7 @@ class TestMetafuncFunctional: + "*test_function*advanced*FAILED", + ]) + ++ @pytest.mark.skipif('"__pypy__" in sys.modules')
+ def test_parametrize_without_ids(self, testdir): + testdir.makepyfile(""" + import pytest +@@ -835,6 +837,7 @@ class TestMetafuncFunctional: + reprec = testdir.runpytest() + reprec.assert_outcomes(passed=1) + ++ @pytest.mark.skipif('"__pypy__" in sys.modules')
+ def test_generate_tests_only_done_in_subdir(self, testdir): + sub1 = testdir.mkpydir("sub1") + sub2 = testdir.mkpydir("sub2") +diff --git a/testing/test_assertion.py b/testing/test_assertion.py +index 914fedd..fb0d0e2 100644 +--- a/testing/test_assertion.py ++++ b/testing/test_assertion.py +@@ -120,6 +120,7 @@ class TestAssert_reprcompare: + """) + ] + ) ++ @pytest.mark.skipif('"__pypy__" in sys.modules')
+ def test_iterable_full_diff(self, left, right, expected): + """Test the full diff assertion failure explanation. + +@@ -348,6 +349,7 @@ class TestFormatExplanation: + assert util.format_explanation(expl) == res + + ++@pytest.mark.skipif('"__pypy__" in sys.modules')
+ def test_python25_compile_issue257(testdir): + testdir.makepyfile(""" + def test_rewritten(): +@@ -559,6 +561,7 @@ def test_warn_missing(testdir): + "*WARNING*assert statements are not executed*", + ]) + ++@pytest.mark.skipif('"__pypy__" in sys.modules')
+ def test_recursion_source_decode(testdir): + testdir.makepyfile(""" + def test_something(): +@@ -573,6 +576,7 @@ def test_recursion_source_decode(testdir): + <Module*> + """) + ++@pytest.mark.skipif('"__pypy__" in sys.modules')
+ def test_AssertionError_message(testdir): + testdir.makepyfile(""" + def test_hello(): +@@ -587,6 +591,7 @@ def test_AssertionError_message(testdir): + """) + + @pytest.mark.skipif(PY3, reason='This bug does not exist on PY3') ++@pytest.mark.skipif('"__pypy__" in sys.modules')
+ def test_set_with_unsortable_elements(): + # issue #718 + class UnsortableKey(object): +diff --git a/testing/test_assertrewrite.py b/testing/test_assertrewrite.py +index 544250a..9dad082 100644 +--- a/testing/test_assertrewrite.py ++++ b/testing/test_assertrewrite.py +@@ -307,6 +307,7 @@ class TestAssertionRewrite: + assert g(**{x : 2}) + assert getmsg(f, ns) == """assert g(**{'a': 2})""" + ++ @pytest.mark.skipif('"__pypy__" in sys.modules')
+ def test_attribute(self): + class X(object): + g = 3 +@@ -343,6 +344,7 @@ class TestAssertionRewrite: + assert b < c + getmsg(f, must_pass=True) + ++ @pytest.mark.skipif('"__pypy__" in sys.modules')
+ def test_len(self): + def f(): + l = list(range(10)) +@@ -641,6 +643,7 @@ class TestAssertionRewriteHookDetails(object): + + assert _read_pyc(source, str(pyc)) is None # no error + ++ @pytest.mark.skipif('"__pypy__" in sys.modules')
+ def test_reload_is_same(self, testdir): + # A file that will be picked up during collecting. + testdir.tmpdir.join("file.py").ensure() +diff --git a/testing/test_capture.py b/testing/test_capture.py +index 5393335..0d2c238 100644 +--- a/testing/test_capture.py ++++ b/testing/test_capture.py +@@ -479,6 +479,8 @@ class TestCaptureFixture: + assert 'closed' not in result.stderr.str() + + ++# https://github.com/pytest-dev/pytest/issues/1162
++@pytest.mark.skipif('"__pypy__" in sys.modules')
+ def test_setup_failure_does_not_kill_capturing(testdir): + sub1 = testdir.mkpydir("sub1") + sub1.join("conftest.py").write(py.code.Source(""" +@@ -518,6 +520,7 @@ def test_capture_conftest_runtest_setup(testdir): + assert 'hello19' not in result.stdout.str() + + ++@pytest.mark.skipif('"__pypy__" in sys.modules')
+ def test_capture_badoutput_issue412(testdir): + testdir.makepyfile(""" + import os +@@ -897,6 +900,7 @@ class TestStdCaptureFD(TestStdCapture): + pytestmark = needsosdup + captureclass = staticmethod(StdCaptureFD) + ++ @pytest.mark.skipif('"__pypy__" in sys.modules')
+ def test_simple_only_fd(self, testdir): + testdir.makepyfile(""" + import os +@@ -981,6 +985,7 @@ def test_fdcapture_tmpfile_remains_the_same(tmpfile, use): + assert capfile2 == capfile + + @needsosdup ++@pytest.mark.skipif('"__pypy__" in sys.modules')
+ def test_close_and_capture_again(testdir): + testdir.makepyfile(""" + import os +@@ -1001,6 +1006,7 @@ def test_close_and_capture_again(testdir): + + + @pytest.mark.parametrize('method', ['SysCapture', 'FDCapture']) ++@pytest.mark.skipif('"__pypy__" in sys.modules')
+ def test_capturing_and_logging_fundamentals(testdir, method): + if method == "StdCaptureFD" and not hasattr(os, 'dup'): + pytest.skip("need os.dup") +diff --git a/testing/test_collection.py b/testing/test_collection.py +index 749c5b7..65370a6 100644 +--- a/testing/test_collection.py ++++ b/testing/test_collection.py +@@ -287,6 +287,7 @@ class TestCustomConftests: + "*test_x*" + ]) + ++ @pytest.mark.skipif('"__pypy__" in sys.modules') + def test_pytest_collect_file_from_sister_dir(self, testdir): + sub1 = testdir.mkpydir("sub1") + sub2 = testdir.mkpydir("sub2") +diff --git a/testing/test_config.py b/testing/test_config.py +index d497200..2987072 100644 +--- a/testing/test_config.py ++++ b/testing/test_config.py +@@ -47,6 +47,7 @@ class TestParseIni: + ]) + + @pytest.mark.parametrize("name", "setup.cfg tox.ini pytest.ini".split()) ++ @pytest.mark.skipif('"__pypy__" in sys.modules')
+ def test_ini_names(self, testdir, name): + testdir.tmpdir.join(name).write(py.std.textwrap.dedent(""" + [pytest] +@@ -55,6 +56,7 @@ class TestParseIni: + config = testdir.parseconfig() + assert config.getini("minversion") == "1.0" + ++ @pytest.mark.skipif('"__pypy__" in sys.modules')
+ def test_toxini_before_lower_pytestini(self, testdir): + sub = testdir.tmpdir.mkdir("sub") + sub.join("tox.ini").write(py.std.textwrap.dedent(""" +@@ -418,6 +420,7 @@ class TestWarning: + reprec = testdir.inline_run() + reprec.assertoutcome(passed=1) + ++ @pytest.mark.skipif('"__pypy__" in sys.modules')
+ def test_warn_on_test_item_from_request(self, testdir): + testdir.makepyfile(""" + import pytest +diff --git a/testing/test_conftest.py b/testing/test_conftest.py +index a0b77cf..3d07597 100644 +--- a/testing/test_conftest.py ++++ b/testing/test_conftest.py +@@ -204,6 +204,7 @@ def test_conftest_import_order(testdir, monkeypatch): + assert conftest._getconftestmodules(sub) == [ct1, ct2] + + ++@pytest.mark.skipif('"__pypy__" in sys.modules')
+ def test_fixture_dependency(testdir, monkeypatch): + ct1 = testdir.makeconftest("") + ct1 = testdir.makepyfile("__init__.py") +@@ -241,6 +242,7 @@ def test_fixture_dependency(testdir, monkeypatch): + result.stdout.fnmatch_lines(["*1 passed*"]) + + ++@pytest.mark.skipif('"__pypy__" in sys.modules')
+ def test_conftest_found_with_double_dash(testdir): + sub = testdir.mkdir("sub") + sub.join("conftest.py").write(py.std.textwrap.dedent(""" +@@ -259,6 +261,7 @@ def test_conftest_found_with_double_dash(testdir): + """) + + ++@pytest.mark.skipif('"__pypy__" in sys.modules')
+ class TestConftestVisibility: + def _setup_tree(self, testdir): # for issue616 + # example mostly taken from: +diff --git a/testing/test_helpconfig.py b/testing/test_helpconfig.py +index 9f8d87b..2ecd20d 100644 +--- a/testing/test_helpconfig.py ++++ b/testing/test_helpconfig.py +@@ -14,6 +14,7 @@ def test_version(testdir, pytestconfig): + "*at*", + ]) + ++@pytest.mark.skipif('"__pypy__" in sys.modules')
+ def test_help(testdir): + result = testdir.runpytest("--help") + assert result.ret == 0 +diff --git a/testing/test_junitxml.py b/testing/test_junitxml.py +index e6db810..1180ea7 100644 +--- a/testing/test_junitxml.py ++++ b/testing/test_junitxml.py +@@ -175,6 +175,7 @@ class TestPython: + classname="test_classname_instance.TestClass", + name="test_method") + ++ @pytest.mark.skipif('"__pypy__" in sys.modules') + def test_classname_nested_dir(self, testdir): + p = testdir.tmpdir.ensure("sub", "test_hello.py") + p.write("def test_func(): 0/0") +diff --git a/testing/test_mark.py b/testing/test_mark.py +index 1aa3361..242a65d 100644 +--- a/testing/test_mark.py ++++ b/testing/test_mark.py +@@ -133,6 +133,7 @@ def test_markers_option(testdir): + "*a1some*another marker", + ]) + ++@pytest.mark.skipif('"__pypy__" in sys.modules')
+ def test_markers_option_with_plugin_in_current_dir(testdir): + testdir.makeconftest('pytest_plugins = "flip_flop"') + testdir.makepyfile(flip_flop="""\ +diff --git a/testing/test_monkeypatch.py b/testing/test_monkeypatch.py +index 048c942..0c87b4e 100644 +--- a/testing/test_monkeypatch.py ++++ b/testing/test_monkeypatch.py +@@ -256,6 +256,7 @@ def test_chdir_double_undo(mp, tmpdir): + assert os.getcwd() == tmpdir.strpath + + ++@pytest.mark.skipif('"__pypy__" in sys.modules')
+ def test_issue185_time_breaks(testdir): + testdir.makepyfile(""" + import time +diff --git a/testing/test_skipping.py b/testing/test_skipping.py +index 1048c94..ea5cf44 100644 +--- a/testing/test_skipping.py ++++ b/testing/test_skipping.py +@@ -263,6 +263,7 @@ class TestXFail: + result = testdir.runpytest(p, "--runxfail") + result.stdout.fnmatch_lines("*1 pass*") + ++ @pytest.mark.skipif('"__pypy__" in sys.modules')
+ def test_xfail_imperative_in_setup_function(self, testdir): + p = testdir.makepyfile(""" + import pytest +@@ -671,6 +672,7 @@ def test_xfail_test_setup_exception(testdir): + assert 'xfailed' in result.stdout.str() + assert 'xpassed' not in result.stdout.str() + ++@pytest.mark.skipif('"__pypy__" in sys.modules')
+ def test_imperativeskip_on_xfail_test(testdir): + testdir.makepyfile(""" + import pytest +@@ -694,6 +696,7 @@ def test_imperativeskip_on_xfail_test(testdir): + *2 skipped* + """) + ++@pytest.mark.skipif('"__pypy__" in sys.modules')
+ class TestBooleanCondition: + def test_skipif(self, testdir): + testdir.makepyfile(""" +diff --git a/testing/test_terminal.py b/testing/test_terminal.py +index 305d60a..d503be8 100644 +--- a/testing/test_terminal.py ++++ b/testing/test_terminal.py +@@ -264,6 +264,7 @@ class TestCollectonly: + "* <Function 'test_method'*>", + ]) + ++ @pytest.mark.skipif('"__pypy__" in sys.modules')
+ def test_collectonly_error(self, testdir): + p = testdir.makepyfile("import Errlkjqweqwe") + result = testdir.runpytest("--collect-only", p) +@@ -726,6 +727,7 @@ def test_tbstyle_native_setup_error(testdir): + '*File *test_tbstyle_native_setup_error.py", line *, in setup_error_fixture*' + ]) + ++@pytest.mark.skipif('"__pypy__" in sys.modules')
+ def test_terminal_summary(testdir): + testdir.makeconftest(""" + def pytest_terminal_summary(terminalreporter): +diff --git a/testing/test_unittest.py b/testing/test_unittest.py +index 53dde6e..52eeae0 100644 +--- a/testing/test_unittest.py ++++ b/testing/test_unittest.py +@@ -14,6 +14,7 @@ def test_simple_unittest(testdir): + assert reprec.matchreport("testpassing").passed + assert reprec.matchreport("test_failing").failed + ++@pytest.mark.skipif('"__pypy__" in sys.modules')
+ def test_runTest_method(testdir): + testdir.makepyfile(""" + import unittest +@@ -705,6 +706,7 @@ def test_issue333_result_clearing(testdir): + reprec.assertoutcome(failed=1) + + @pytest.mark.skipif("sys.version_info < (2,7)") ++@pytest.mark.skipif('"__pypy__" in sys.modules')
+ def test_unittest_raise_skip_issue748(testdir): + testdir.makepyfile(test_foo=""" + import unittest +@@ -720,6 +722,7 @@ def test_unittest_raise_skip_issue748(testdir): + """) + + @pytest.mark.skipif("sys.version_info < (2,7)") ++@pytest.mark.skipif('"__pypy__" in sys.modules')
+ def test_unittest_skip_issue1169(testdir): + testdir.makepyfile(test_foo=""" + import unittest diff --git a/dev-python/pytest/pytest-2.8.7.ebuild b/dev-python/pytest/pytest-2.8.7.ebuild new file mode 100644 index 00000000000..a8487c5541f --- /dev/null +++ b/dev-python/pytest/pytest-2.8.7.ebuild @@ -0,0 +1,76 @@ +# Copyright 1999-2016 Gentoo Foundation +# Distributed under the terms of the GNU General Public License v2 +# $Id$ + +EAPI=5 + +PYTHON_COMPAT=( python2_7 python3_{3,4,5} pypy pypy3 ) + +inherit distutils-r1 + +DESCRIPTION="Simple powerful testing with Python" +HOMEPAGE="http://pytest.org/ https://pypi.python.org/pypi/pytest" +SRC_URI="mirror://pypi/${PN:0:1}/${PN}/${P}.tar.gz" + +LICENSE="MIT" +SLOT="0" +KEYWORDS="~alpha ~amd64 ~arm ~arm64 ~hppa ~ia64 ~m68k ~mips ~ppc ~ppc64 ~s390 ~sh ~sparc ~x86 ~amd64-fbsd ~x86-fbsd ~amd64-linux ~ia64-linux ~x86-linux ~ppc-macos ~x64-macos ~x86-macos" +IUSE="doc test" + +# When bumping, please check setup.py for the proper py version +PY_VER="1.4.29" +RDEPEND=">=dev-python/py-${PY_VER}[${PYTHON_USEDEP}]" + +# dev-python/pluggy +# https://github.com/hpk42/pluggy +# See https://github.com/pytest-dev/pytest/issues/944 +# for why not now + +#pexpect dep based on https://bitbucket.org/hpk42/pytest/issue/386/tests-fail-with-pexpect-30 +DEPEND="${RDEPEND} + dev-python/setuptools[${PYTHON_USEDEP}] + test? ( dev-python/pexpect[${PYTHON_USEDEP}] ) + doc? ( + >=dev-python/sphinx-1.2.3[${PYTHON_USEDEP}] + dev-python/pyyaml[${PYTHON_USEDEP}] + dev-python/regendoc[${PYTHON_USEDEP}] + )" + +PATCHES=( "${FILESDIR}"/${P}-skip-test-on-pypy.patch ) + +python_prepare_all() { + chmod o-w *egg*/* || die + # Disable versioning of py.test script to avoid collision with + # versioning performed by the eclass. + sed -e "s/return points/return {'py.test': target}/" -i setup.py || die "sed failed" + grep -qF "py>=${PY_VER}" setup.py || die "Incorrect dev-python/py dependency" + + # Prevent un-needed d'loading + sed -e "s/'sphinx.ext.intersphinx', //" -i doc/en/conf.py || die + + distutils-r1_python_prepare_all +} + +python_compile_all() { + if use doc; then + mkdir doc/en/.build || die + emake -C doc/en html + fi +} + +python_test() { + # test_nose.py not written to suit py3.2 in pypy3 + if [[ "${EPYTHON}" == pypy3 ]]; then + "${PYTHON}" "${BUILD_DIR}"/lib/pytest.py -x -v \ + --ignore=testing/BUILD_nose.py \ + || die "tests failed with ${EPYTHON}" + else + "${PYTHON}" "${BUILD_DIR}"/lib/pytest.py -x -v --runpytest=subprocess \ + || die "tests failed with ${EPYTHON}" + fi +} + +python_install_all() { + use doc && HTML_DOCS=( doc/en/_build/html/. ) + distutils-r1_python_install_all +} |