Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Multiple test failures on Alpine 3.15 / musl-1.2.2-r7 #90548

Open
tiran opened this issue Jan 15, 2022 · 10 comments
Open

Multiple test failures on Alpine 3.15 / musl-1.2.2-r7 #90548

tiran opened this issue Jan 15, 2022 · 10 comments
Labels
3.11 only security fixes build The build process and cross-build OS-unsupported tests Tests in the Lib/test dir type-bug An unexpected behavior, bug, or error

Comments

@tiran
Copy link
Member

tiran commented Jan 15, 2022

BPO 46390
Nosy @brettcannon, @terryjreedy, @tiran, @zware, @ncopa
Files
  • alpine315-tests.txt
  • Note: these values reflect the state of the issue at the time it was migrated and might not reflect the current state.

    Show more details

    GitHub fields:

    assignee = None
    closed_at = None
    created_at = <Date 2022-01-15.12:56:24.197>
    labels = ['type-bug', 'tests', 'build', '3.11']
    title = 'Multiple test failures on Alpine 3.15 / musl-1.2.2-r7'
    updated_at = <Date 2022-03-31.17:55:03.007>
    user = 'https://github.com/tiran'

    bugs.python.org fields:

    activity = <Date 2022-03-31.17:55:03.007>
    actor = 'brett.cannon'
    assignee = 'none'
    closed = False
    closed_date = None
    closer = None
    components = ['Build', 'Tests']
    creation = <Date 2022-01-15.12:56:24.197>
    creator = 'christian.heimes'
    dependencies = []
    files = ['50566']
    hgrepos = []
    issue_num = 46390
    keywords = []
    message_count = 7.0
    messages = ['410645', '410848', '410849', '411187', '411191', '411193', '411905']
    nosy_count = 5.0
    nosy_names = ['brett.cannon', 'terry.reedy', 'christian.heimes', 'zach.ware', 'ncopa']
    pr_nums = []
    priority = 'normal'
    resolution = None
    stage = None
    status = 'open'
    superseder = None
    type = 'behavior'
    url = 'https://bugs.python.org/issue46390'
    versions = ['Python 3.11']

    @tiran
    Copy link
    Member Author

    tiran commented Jan 15, 2022

    I'm getting multiple test failures with latest Alpine 3.15 and musl-1.2.2-r7. Some test failures may be caused by wrong assumptions in our tests, some might be bugs in musl lib.c

    9 tests failed:
    test__locale test_c_locale_coercion test_cmd_line test_gdb
    test_locale test_os test_posix test_re test_selectors

    I have attached the output of

    ./python -m test -v test__locale test_c_locale_coercion test_cmd_line test_gdb test_locale test_os test_posix test_re test_selectors 2>&1 | tee alpine315-tests.txt

    You can use my container to reproduce the test failures:

    $ podman run --privileged -ti --rm -v $(pwd):/cpython:Z quay.io/tiran/cpythonbuild:alpine-3.15 /bin/sh
    # /cmd.sh
    # cd /cpython/builddep/alpine-3.15-x86_64/
    # make test

    @tiran tiran added 3.11 only security fixes build The build process and cross-build tests Tests in the Lib/test dir type-bug An unexpected behavior, bug, or error labels Jan 15, 2022
    @kumaraditya303
    Copy link
    Contributor

    @tiran
    Copy link
    Member Author

    tiran commented Jan 18, 2022

    I would put it differently: The package maintainer of Python on Alpine decided to ignore all test failures in these test modules.

    @terryjreedy
    Copy link
    Member

    The first alpine315-tests.txt appears to be a truncated version of the second. Were you expecting the first to be automatically replaced? Should it be unlinked?

    https://www.alpinelinux.org "Alpine Linux is a security-oriented, lightweight Linux distribution based on musl libc and busybox." Fron the doc linked above:

    # Maintainer: Natanael Copa <[email protected]> ## I nosied Natanael at his CLA-signed Alpine id.
    # Contributor: Sheila Aman <[email protected]>
    ...
    # musl related
    fail="test__locale test_locale test_strptime test_re" # various musl locale deficiencies
    fail="$fail test_c_locale_coercion"
    fail="$fail test_datetime" # hangs if 'tzdata' installed
    fail="$fail test_os" # fpathconf, ttyname errno values
    fail="$fail test_posix" # sched_[gs]etscheduler not impl
    fail="$fail test_shutil" # lchmod, requires real unzip

    Should we change CPython tests to accommodate things that are missing (versus buggy). Should the tests requiring sched_[gs]etscheduler be skipped if missing? Or are they required to be 'posix' and is test_posix meant to test completeness as well as correctness of what is present?

    @tiran
    Copy link
    Member Author

    tiran commented Jan 21, 2022

    In my opinion we should treat these issues as Alpine / musl libc platform bugs and ask the Alpine maintainers to look into the issue. The tests are passing on Linux with glibc and BSD platforms (FreeBSD, macOS, ...) with BSD libc. It is reasonable to assume that failing test are caused by incompatibilities or deficiencies in musl libc, or by a different interpretation of POSIX and Open Group standards.

    I would not ignore or skip any test unless we have a thorough understanding of the problem and the deviation is documented. The issue can also affect user code.

    Python's test suite is exhaustive. Our tests have found a fair amount of problems in e.g, libm. A couple of years ago ine of my AF_ALG socket tests even found a Kernel bug by triggered a Kernel fault.

    @tiran
    Copy link
    Member Author

    tiran commented Jan 21, 2022

    The comment about sched_[gs]etscheduler seems to be outdated. For one CPython's test suite has a @requires_sched decorator that performs a check for sched_getscheduler and the Kernel syscall. musl libc in Alpine 3.13 and 3.15 have sched_setscheduler.

    @zware
    Copy link
    Member

    zware commented Jan 27, 2022

    BTW, we do have an Alpine buildbot worker in the unstable set, running only on the main branch: https://buildbot.python.org/all/#/workers/19

    @ezio-melotti ezio-melotti transferred this issue from another repository Apr 10, 2022
    @tiran
    Copy link
    Member Author

    tiran commented May 27, 2022

    GH-92826 is a compiler or musl libc issue on Alpine that manifests on PPC64LE platforms.

    @brettcannon
    Copy link
    Member

    FYI neither Alpine nor musl are covered by PEP 11 (PPC64LE is tier-2, though).

    @tianon
    Copy link

    tianon commented Oct 18, 2024

    FWIW, I visually spot-checked each instance of FAIL: in https://buildbot.python.org/all/api/v2/logs/11438284/raw_inline today (the latest build from https://buildbot.python.org/all/#/workers/19 at the time of my checking), and almost all the current failures are locale-related (which is somewhat expected with musl; see https://wiki.musl-libc.org/open-issues#Locale-limitations).

    If we ignore the Locale-related failures, here are the two failures I'm seeing that remain:

    ======================================================================
    FAIL: test_fma_zero_result (test.test_math.FMATests.test_fma_zero_result)
    ----------------------------------------------------------------------
    Traceback (most recent call last):
      File "/buildbot/buildarea/3.x.ware-alpine/build/Lib/test/test_math.py", line 2760, in test_fma_zero_result
        self.assertIsNegativeZero(math.fma(tiny, -tiny, 0.0))
        ~~~~~~~~~~~~~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^^^^^^^
      File "/buildbot/buildarea/3.x.ware-alpine/build/Lib/test/test_math.py", line 2876, in assertIsNegativeZero
        self.assertTrue(
        ~~~~~~~~~~~~~~~^
            value == 0 and math.copysign(1, value) < 0,
            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
            msg="Expected a negative zero, got {!r}".format(value)
            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
        )
        ^
    AssertionError: False is not true : Expected a negative zero, got 0.0
    
    ----------------------------------------------------------------------
    
    ======================================================================
    FAIL: test_fpathconf (test.test_os.TestInvalidFD.test_fpathconf)
    ----------------------------------------------------------------------
    Traceback (most recent call last):
      File "/buildbot/buildarea/3.x.ware-alpine/build/Lib/test/test_os.py", line 2452, in test_fpathconf
        self.check(os.pathconf, "PC_NAME_MAX")
        ~~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^^^^^^^
      File "/buildbot/buildarea/3.x.ware-alpine/build/Lib/test/test_os.py", line 2379, in check
        self.fail("%r didn't raise an OSError with a bad file descriptor"
        ~~~~~~~~~^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
                  % f)
                  ^^^^
    AssertionError: <built-in function pathconf> didn't raise an OSError with a bad file descriptor
    
    ----------------------------------------------------------------------
    

    These certainly seem worrying, but not "the build is totally invalid and shouldn't exist" levels of worrying (which is what I was looking at this to evaluate -- namely whether https://github.com/docker-library/python can reasonably continue to provide Alpine-based builds or whether we should deprecate and remove them).

    To be very clear, I don't have any good opinions on what CPython maintainers should do here (and in fact would love to follow any recommendations, including deprecating these builds anyhow, if that's the consensus), but I went through some of the data and figured it'd be worth noting the data points I found. 🙇 ❤️

    Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
    Labels
    3.11 only security fixes build The build process and cross-build OS-unsupported tests Tests in the Lib/test dir type-bug An unexpected behavior, bug, or error
    Projects
    Status: No status
    Development

    No branches or pull requests

    7 participants