summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorVictor Stinner <victor.stinner@gmail.com>2017-04-04 08:35:15 (GMT)
committerGitHub <noreply@github.com>2017-04-04 08:35:15 (GMT)
commit5de85a17029356084b96db63e04d9eb150efd9c0 (patch)
treec281163219b3a185279a7b95ff7c15e40b21a231
parent02e12138000da834f23719521a011fa93763384d (diff)
downloadcpython-5de85a17029356084b96db63e04d9eb150efd9c0.zip
cpython-5de85a17029356084b96db63e04d9eb150efd9c0.tar.gz
cpython-5de85a17029356084b96db63e04d9eb150efd9c0.tar.bz2
bpo-29972: Skip tests known to fail on AIX (#979)
* bpo-29972: Fix test_eintr on AIX On AIX, sigtimedwait(0.2) sleeps 199.8 ms, whereas the test expects 200 ms or longer. * bpo-29972: Skip some inet_pton() tests on AIX Skip some inet_pton() tests of test_socket on AIX. inet_pton() on AIX is less strict than on Linux and doesn't reject some invalid IP addresses. The unit tests test more the libc than Python itself. * bpo-29972: Skip tests known to fail on AIX * test_locale.test_strcoll_with_diacritic() * test_locale.test_strxfrm_with_diacritic() * test_strptime.test_week_of_year_and_day_of_week_calculation() * test_tools.test_POT_Creation_Date()
-rw-r--r--Lib/test/eintrdata/eintr_tester.py7
-rw-r--r--Lib/test/test_locale.py4
-rw-r--r--Lib/test/test_socket.py10
-rw-r--r--Lib/test/test_strptime.py3
-rw-r--r--Lib/test/test_tools/test_i18n.py4
5 files changed, 23 insertions, 5 deletions
diff --git a/Lib/test/eintrdata/eintr_tester.py b/Lib/test/eintrdata/eintr_tester.py
index c619b3d..74a509b 100644
--- a/Lib/test/eintrdata/eintr_tester.py
+++ b/Lib/test/eintrdata/eintr_tester.py
@@ -380,7 +380,12 @@ class SignalEINTRTest(EINTRBaseTest):
t0 = time.monotonic()
signal.sigtimedwait([signal.SIGUSR1], self.sleep_time)
dt = time.monotonic() - t0
- self.assertGreaterEqual(dt, self.sleep_time)
+
+ if sys.platform.startswith('aix'):
+ # On AIX, sigtimedwait(0.2) sleeps 199.8 ms
+ self.assertGreaterEqual(dt, self.sleep_time * 0.9)
+ else:
+ self.assertGreaterEqual(dt, self.sleep_time)
@unittest.skipUnless(hasattr(signal, 'sigwaitinfo'),
'need signal.sigwaitinfo()')
diff --git a/Lib/test/test_locale.py b/Lib/test/test_locale.py
index 4dd300e..668f3cb 100644
--- a/Lib/test/test_locale.py
+++ b/Lib/test/test_locale.py
@@ -365,9 +365,13 @@ class TestEnUSCollation(BaseLocalizedTest, TestCollation):
raise unittest.SkipTest('wcscoll/wcsxfrm have known bugs')
BaseLocalizedTest.setUp(self)
+ @unittest.skipIf(sys.platform.startswith('aix'),
+ 'bpo-29972: broken test on AIX')
def test_strcoll_with_diacritic(self):
self.assertLess(locale.strcoll('à', 'b'), 0)
+ @unittest.skipIf(sys.platform.startswith('aix'),
+ 'bpo-29972: broken test on AIX')
def test_strxfrm_with_diacritic(self):
self.assertLess(locale.strxfrm('à'), locale.strxfrm('b'))
diff --git a/Lib/test/test_socket.py b/Lib/test/test_socket.py
index 7cc2e57..2155d63 100644
--- a/Lib/test/test_socket.py
+++ b/Lib/test/test_socket.py
@@ -1026,7 +1026,9 @@ class GeneralModuleTests(unittest.TestCase):
self.assertEqual(b'\xaa\xaa\xaa\xaa', f('170.170.170.170'))
self.assertEqual(b'\x01\x02\x03\x04', f('1.2.3.4'))
self.assertEqual(b'\xff\xff\xff\xff', f('255.255.255.255'))
- assertInvalid(f, '0.0.0.')
+ # bpo-29972: inet_pton() doesn't fail on AIX
+ if not sys.platform.startswith('aix'):
+ assertInvalid(f, '0.0.0.')
assertInvalid(f, '300.0.0.0')
assertInvalid(f, 'a.0.0.0')
assertInvalid(f, '1.2.3.4.5')
@@ -1081,10 +1083,12 @@ class GeneralModuleTests(unittest.TestCase):
assertInvalid('::0::')
assertInvalid('1::abc::')
assertInvalid('1::abc::def')
- assertInvalid('1:2:3:4:5:6:')
assertInvalid('1:2:3:4:5:6')
- assertInvalid('1:2:3:4:5:6:7:8:')
assertInvalid('1:2:3:4:5:6:7:8:0')
+ # bpo-29972: inet_pton() doesn't fail on AIX
+ if not sys.platform.startswith('aix'):
+ assertInvalid('1:2:3:4:5:6:')
+ assertInvalid('1:2:3:4:5:6:7:8:')
self.assertEqual(b'\x00' * 12 + b'\xfe\x2a\x17\x40',
f('::254.42.23.64')
diff --git a/Lib/test/test_strptime.py b/Lib/test/test_strptime.py
index 2cf0926..9343180 100644
--- a/Lib/test/test_strptime.py
+++ b/Lib/test/test_strptime.py
@@ -5,6 +5,7 @@ import time
import locale
import re
import os
+import sys
from test import support
from datetime import date as datetime_date
@@ -482,6 +483,8 @@ class CalculationTests(unittest.TestCase):
_ymd_excluded = ()
_formats_excluded = ()
+ @unittest.skipIf(sys.platform.startswith('aix'),
+ 'bpo-29972: broken test on AIX')
def test_week_of_year_and_day_of_week_calculation(self):
# Should be able to infer date if given year, week of year (%U or %W)
# and day of the week
diff --git a/Lib/test/test_tools/test_i18n.py b/Lib/test/test_tools/test_i18n.py
index ce6f549..5c28bae 100644
--- a/Lib/test/test_tools/test_i18n.py
+++ b/Lib/test/test_tools/test_i18n.py
@@ -1,6 +1,7 @@
"""Tests to cover the Tools/i18n package"""
import os
+import sys
import unittest
from test.support.script_helper import assert_python_ok
@@ -53,7 +54,8 @@ class Test_pygettext(unittest.TestCase):
#"Plural-Forms" is optional
-
+ @unittest.skipIf(sys.platform.startswith('aix'),
+ 'bpo-29972: broken test on AIX')
def test_POT_Creation_Date(self):
""" Match the date format from xgettext for POT-Creation-Date """
from datetime import datetime