>>> py3-trio: Building community/py3-trio 0.19.0-r1 (using abuild 3.10.0_rc1-r2) started Wed, 26 Oct 2022 22:49:42 +0000 >>> py3-trio: Checking sanity of /home/buildozer/aports/community/py3-trio/APKBUILD... >>> py3-trio: Analyzing dependencies... >>> py3-trio: Installing for build: build-base py3-idna py3-openssl py3-outcome py3-sniffio py3-sortedcontainers python3 py3-setuptools py3-astor py3-pytest py3-trustme (1/35) Installing libbz2 (1.0.8-r3) (2/35) Installing libffi (3.4.3-r0) (3/35) Installing gdbm (1.23-r0) (4/35) Installing xz-libs (5.2.7-r0) (5/35) Installing mpdecimal (2.5.1-r1) (6/35) Installing readline (8.2.0-r0) (7/35) Installing sqlite-libs (3.39.4-r0) (8/35) Installing python3 (3.10.8-r3) (9/35) Installing py3-idna (3.4-r2) (10/35) Installing py3-cparser (2.21-r0) (11/35) Installing py3-cffi (1.15.1-r0) (12/35) Installing py3-cryptography (38.0.2-r0) (13/35) Installing py3-six (1.16.0-r3) (14/35) Installing py3-openssl (22.1.0-r0) (15/35) Installing py3-async_generator (1.10-r3) (16/35) Installing py3-attrs (22.1.0-r0) (17/35) Installing py3-outcome (1.1.0-r3) (18/35) Installing py3-curio (1.5-r2) (19/35) Installing py3-sniffio (1.3.0-r0) (20/35) Installing py3-sortedcontainers (2.4.0-r1) (21/35) Installing py3-parsing (3.0.9-r0) (22/35) Installing py3-packaging (21.3-r2) (23/35) Installing py3-setuptools (65.5.0-r0) (24/35) Installing py3-astor (0.8.1-r2) (25/35) Installing py3-iniconfig (1.1.1-r3) (26/35) Installing py3-pluggy (1.0.0-r1) (27/35) Installing py3-py (1.11.0-r0) (28/35) Installing py3-tomli (2.0.1-r1) (29/35) Installing py3-pytest (7.1.3-r1) (30/35) Installing py3-asn1 (0.4.8-r2) (31/35) Installing py3-asn1-modules (0.2.8-r2) (32/35) Installing py3-characteristic (14.3.0-r8) (33/35) Installing py3-service_identity (21.1.0-r2) (34/35) Installing py3-trustme (0.9.0-r1) (35/35) Installing .makedepends-py3-trio (20221026.225000) Executing busybox-1.35.0-r27.trigger OK: 293 MiB in 128 packages >>> py3-trio: Cleaning up srcdir >>> py3-trio: Cleaning up pkgdir >>> py3-trio: Fetching https://distfiles.alpinelinux.org/distfiles/v3.17/trio-0.19.0.tar.gz >>> py3-trio: Fetching https://distfiles.alpinelinux.org/distfiles/v3.17/0639f87e58bae400070c5642f6fb339c7bb6e704.patch >>> py3-trio: Fetching https://distfiles.alpinelinux.org/distfiles/v3.17/trio-0.19.0.tar.gz >>> py3-trio: Fetching https://distfiles.alpinelinux.org/distfiles/v3.17/0639f87e58bae400070c5642f6fb339c7bb6e704.patch >>> py3-trio: Checking sha512sums... trio-0.19.0.tar.gz: OK 0639f87e58bae400070c5642f6fb339c7bb6e704.patch: OK >>> py3-trio: Unpacking /var/cache/distfiles/v3.17/trio-0.19.0.tar.gz... >>> py3-trio: https://github.com/python-trio/trio/commit/0639f87e58bae400070c5642f6fb339c7bb6e704.patch patching file trio/tests/test_ssl.py running build running build_py creating build creating build/lib creating build/lib/trio copying trio/_subprocess.py -> build/lib/trio copying trio/_path.py -> build/lib/trio copying trio/socket.py -> build/lib/trio copying trio/lowlevel.py -> build/lib/trio copying trio/_highlevel_generic.py -> build/lib/trio copying trio/_socket.py -> build/lib/trio copying trio/_unix_pipes.py -> build/lib/trio copying trio/_deprecate.py -> build/lib/trio copying trio/from_thread.py -> build/lib/trio copying trio/_ssl.py -> build/lib/trio copying trio/_wait_for_object.py -> build/lib/trio copying trio/_highlevel_serve_listeners.py -> build/lib/trio copying trio/_abc.py -> build/lib/trio copying trio/_sync.py -> build/lib/trio copying trio/_highlevel_open_unix_stream.py -> build/lib/trio copying trio/_timeouts.py -> build/lib/trio copying trio/_util.py -> build/lib/trio copying trio/_threads.py -> build/lib/trio copying trio/__init__.py -> build/lib/trio copying trio/_file_io.py -> build/lib/trio copying trio/_channel.py -> build/lib/trio copying trio/to_thread.py -> build/lib/trio copying trio/_signals.py -> build/lib/trio copying trio/_highlevel_socket.py -> build/lib/trio copying trio/_highlevel_ssl_helpers.py -> build/lib/trio copying trio/_highlevel_open_tcp_stream.py -> build/lib/trio copying trio/_windows_pipes.py -> build/lib/trio copying trio/_version.py -> build/lib/trio copying trio/abc.py -> build/lib/trio copying trio/_highlevel_open_tcp_listeners.py -> build/lib/trio creating build/lib/trio/testing copying trio/testing/_checkpoints.py -> build/lib/trio/testing copying trio/testing/_check_streams.py -> build/lib/trio/testing copying trio/testing/__init__.py -> build/lib/trio/testing copying trio/testing/_sequencer.py -> build/lib/trio/testing copying trio/testing/_trio_test.py -> build/lib/trio/testing copying trio/testing/_memory_streams.py -> build/lib/trio/testing copying trio/testing/_network.py -> build/lib/trio/testing creating build/lib/trio/tests copying trio/tests/test_highlevel_serve_listeners.py -> build/lib/trio/tests copying trio/tests/test_deprecate.py -> build/lib/trio/tests copying trio/tests/module_with_deprecations.py -> build/lib/trio/tests copying trio/tests/test_windows_pipes.py -> build/lib/trio/tests copying trio/tests/test_signals.py -> build/lib/trio/tests copying trio/tests/test_sync.py -> build/lib/trio/tests copying trio/tests/test_timeouts.py -> build/lib/trio/tests copying trio/tests/test_threads.py -> build/lib/trio/tests copying trio/tests/test_highlevel_socket.py -> build/lib/trio/tests copying trio/tests/test_abc.py -> build/lib/trio/tests copying trio/tests/test_scheduler_determinism.py -> build/lib/trio/tests copying trio/tests/test_subprocess.py -> build/lib/trio/tests copying trio/tests/test_highlevel_ssl_helpers.py -> build/lib/trio/tests copying trio/tests/test_unix_pipes.py -> build/lib/trio/tests copying trio/tests/test_highlevel_open_tcp_stream.py -> build/lib/trio/tests copying trio/tests/test_wait_for_object.py -> build/lib/trio/tests copying trio/tests/test_highlevel_open_tcp_listeners.py -> build/lib/trio/tests copying trio/tests/test_util.py -> build/lib/trio/tests copying trio/tests/test_ssl.py -> build/lib/trio/tests copying trio/tests/__init__.py -> build/lib/trio/tests copying trio/tests/test_path.py -> build/lib/trio/tests copying trio/tests/test_socket.py -> build/lib/trio/tests copying trio/tests/test_highlevel_open_unix_stream.py -> build/lib/trio/tests copying trio/tests/conftest.py -> build/lib/trio/tests copying trio/tests/test_exports.py -> build/lib/trio/tests copying trio/tests/test_channel.py -> build/lib/trio/tests copying trio/tests/test_file_io.py -> build/lib/trio/tests copying trio/tests/test_testing.py -> build/lib/trio/tests copying trio/tests/test_highlevel_generic.py -> build/lib/trio/tests creating build/lib/trio/_subprocess_platform copying trio/_subprocess_platform/kqueue.py -> build/lib/trio/_subprocess_platform copying trio/_subprocess_platform/windows.py -> build/lib/trio/_subprocess_platform copying trio/_subprocess_platform/__init__.py -> build/lib/trio/_subprocess_platform copying trio/_subprocess_platform/waitid.py -> build/lib/trio/_subprocess_platform creating build/lib/trio/_core copying trio/_core/_generated_io_kqueue.py -> build/lib/trio/_core copying trio/_core/_asyncgens.py -> build/lib/trio/_core copying trio/_core/_io_windows.py -> build/lib/trio/_core copying trio/_core/_instrumentation.py -> build/lib/trio/_core copying trio/_core/_unbounded_queue.py -> build/lib/trio/_core copying trio/_core/_local.py -> build/lib/trio/_core copying trio/_core/_generated_run.py -> build/lib/trio/_core copying trio/_core/_windows_cffi.py -> build/lib/trio/_core copying trio/_core/_io_common.py -> build/lib/trio/_core copying trio/_core/_parking_lot.py -> build/lib/trio/_core copying trio/_core/_entry_queue.py -> build/lib/trio/_core copying trio/_core/_mock_clock.py -> build/lib/trio/_core copying trio/_core/_ki.py -> build/lib/trio/_core copying trio/_core/_generated_io_epoll.py -> build/lib/trio/_core copying trio/_core/_io_kqueue.py -> build/lib/trio/_core copying trio/_core/_generated_io_windows.py -> build/lib/trio/_core copying trio/_core/_wakeup_socketpair.py -> build/lib/trio/_core copying trio/_core/_run.py -> build/lib/trio/_core copying trio/_core/__init__.py -> build/lib/trio/_core copying trio/_core/_multierror.py -> build/lib/trio/_core copying trio/_core/_generated_instrumentation.py -> build/lib/trio/_core copying trio/_core/_thread_cache.py -> build/lib/trio/_core copying trio/_core/_exceptions.py -> build/lib/trio/_core copying trio/_core/_io_epoll.py -> build/lib/trio/_core copying trio/_core/_traps.py -> build/lib/trio/_core creating build/lib/trio/_tools copying trio/_tools/gen_exports.py -> build/lib/trio/_tools copying trio/_tools/__init__.py -> build/lib/trio/_tools creating build/lib/trio/tests/tools copying trio/tests/tools/test_gen_exports.py -> build/lib/trio/tests/tools copying trio/tests/tools/__init__.py -> build/lib/trio/tests/tools creating build/lib/trio/_core/tests copying trio/_core/tests/test_windows.py -> build/lib/trio/_core/tests copying trio/_core/tests/tutil.py -> build/lib/trio/_core/tests copying trio/_core/tests/test_asyncgen.py -> build/lib/trio/_core/tests copying trio/_core/tests/test_io.py -> build/lib/trio/_core/tests copying trio/_core/tests/test_util.py -> build/lib/trio/_core/tests copying trio/_core/tests/test_tutil.py -> build/lib/trio/_core/tests copying trio/_core/tests/test_guest_mode.py -> build/lib/trio/_core/tests copying trio/_core/tests/__init__.py -> build/lib/trio/_core/tests copying trio/_core/tests/test_mock_clock.py -> build/lib/trio/_core/tests copying trio/_core/tests/test_multierror.py -> build/lib/trio/_core/tests copying trio/_core/tests/test_unbounded_queue.py -> build/lib/trio/_core/tests copying trio/_core/tests/test_parking_lot.py -> build/lib/trio/_core/tests copying trio/_core/tests/conftest.py -> build/lib/trio/_core/tests copying trio/_core/tests/test_run.py -> build/lib/trio/_core/tests copying trio/_core/tests/test_local.py -> build/lib/trio/_core/tests copying trio/_core/tests/test_instrumentation.py -> build/lib/trio/_core/tests copying trio/_core/tests/test_ki.py -> build/lib/trio/_core/tests copying trio/_core/tests/test_thread_cache.py -> build/lib/trio/_core/tests creating build/lib/trio/_core/tests/test_multierror_scripts copying trio/_core/tests/test_multierror_scripts/simple_excepthook_partial.py -> build/lib/trio/_core/tests/test_multierror_scripts copying trio/_core/tests/test_multierror_scripts/apport_excepthook.py -> build/lib/trio/_core/tests/test_multierror_scripts copying trio/_core/tests/test_multierror_scripts/_common.py -> build/lib/trio/_core/tests/test_multierror_scripts copying trio/_core/tests/test_multierror_scripts/simple_excepthook_IPython.py -> build/lib/trio/_core/tests/test_multierror_scripts copying trio/_core/tests/test_multierror_scripts/custom_excepthook.py -> build/lib/trio/_core/tests/test_multierror_scripts copying trio/_core/tests/test_multierror_scripts/__init__.py -> build/lib/trio/_core/tests/test_multierror_scripts copying trio/_core/tests/test_multierror_scripts/simple_excepthook.py -> build/lib/trio/_core/tests/test_multierror_scripts copying trio/_core/tests/test_multierror_scripts/ipython_custom_exc.py -> build/lib/trio/_core/tests/test_multierror_scripts running egg_info writing trio.egg-info/PKG-INFO writing dependency_links to trio.egg-info/dependency_links.txt writing requirements to trio.egg-info/requires.txt writing top-level names to trio.egg-info/top_level.txt reading manifest file 'trio.egg-info/SOURCES.txt' reading manifest template 'MANIFEST.in' warning: no files found matching '*.pem' under directory 'trio/tests/test_ssl_certs' no previously-included directories found matching 'docs/build' adding license file 'LICENSE' adding license file 'LICENSE.APACHE2' adding license file 'LICENSE.MIT' writing manifest file 'trio.egg-info/SOURCES.txt' ============================= test session starts ============================== platform linux -- Python 3.10.8, pytest-7.1.3, pluggy-1.0.0 -- /usr/bin/python3 cachedir: .pytest_cache rootdir: /home/buildozer/aports/community/py3-trio/src/trio-0.19.0, configfile: pyproject.toml collecting ... collected 610 items / 14 deselected / 596 selected trio/_core/tests/test_asyncgen.py::test_asyncgen_basics PASSED [ 0%] trio/_core/tests/test_asyncgen.py::test_asyncgen_throws_during_finalization PASSED [ 0%] trio/_core/tests/test_asyncgen.py::test_firstiter_after_closing PASSED [ 0%] trio/_core/tests/test_asyncgen.py::test_interdependent_asyncgen_cleanup_order PASSED [ 0%] trio/_core/tests/test_asyncgen.py::test_last_minute_gc_edge_case PASSED [ 0%] trio/_core/tests/test_asyncgen.py::test_fallback_when_no_hook_claims_it PASSED [ 1%] trio/_core/tests/test_asyncgen.py::test_delegation_to_existing_hooks PASSED [ 1%] trio/_core/tests/test_guest_mode.py::test_guest_trivial PASSED [ 1%] trio/_core/tests/test_guest_mode.py::test_guest_can_do_io PASSED [ 1%] trio/_core/tests/test_guest_mode.py::test_host_can_directly_wake_trio_task PASSED [ 1%] trio/_core/tests/test_guest_mode.py::test_host_altering_deadlines_wakes_trio_up PASSED [ 1%] trio/_core/tests/test_guest_mode.py::test_warn_set_wakeup_fd_overwrite FAILED [ 2%] trio/_core/tests/test_guest_mode.py::test_host_wakeup_doesnt_trigger_wait_all_tasks_blocked PASSED [ 2%] trio/_core/tests/test_guest_mode.py::test_guest_warns_if_abandoned PASSED [ 2%] trio/_core/tests/test_guest_mode.py::test_guest_mode_on_asyncio PASSED [ 2%] trio/_core/tests/test_guest_mode.py::test_guest_mode_internal_errors PASSED [ 2%] trio/_core/tests/test_guest_mode.py::test_guest_mode_ki PASSED [ 2%] trio/_core/tests/test_guest_mode.py::test_guest_mode_autojump_clock_threshold_changing PASSED [ 3%] trio/_core/tests/test_guest_mode.py::test_guest_mode_asyncgens PASSED [ 3%] trio/_core/tests/test_instrumentation.py::test_instruments PASSED [ 3%] trio/_core/tests/test_instrumentation.py::test_instruments_interleave PASSED [ 3%] trio/_core/tests/test_instrumentation.py::test_null_instrument PASSED [ 3%] trio/_core/tests/test_instrumentation.py::test_instrument_before_after_run PASSED [ 3%] trio/_core/tests/test_instrumentation.py::test_instrument_task_spawn_exit PASSED [ 4%] trio/_core/tests/test_instrumentation.py::test_instruments_crash PASSED [ 4%] trio/_core/tests/test_instrumentation.py::test_instruments_monkeypatch PASSED [ 4%] trio/_core/tests/test_instrumentation.py::test_instrument_that_raises_on_getattr PASSED [ 4%] trio/_core/tests/test_io.py::test_wait_basic[wait_writable-wait_readable] PASSED [ 4%] trio/_core/tests/test_io.py::test_wait_basic[wait_writable-] PASSED [ 4%] trio/_core/tests/test_io.py::test_wait_basic[-wait_readable] PASSED [ 5%] trio/_core/tests/test_io.py::test_wait_basic[-] PASSED [ 5%] trio/_core/tests/test_io.py::test_double_read[wait_readable] PASSED [ 5%] trio/_core/tests/test_io.py::test_double_read[] PASSED [ 5%] trio/_core/tests/test_io.py::test_double_write[wait_writable] PASSED [ 5%] trio/_core/tests/test_io.py::test_double_write[] PASSED [ 5%] trio/_core/tests/test_io.py::test_interrupted_by_close[notify_closing-wait_writable-wait_readable] PASSED [ 6%] trio/_core/tests/test_io.py::test_interrupted_by_close[notify_closing-wait_writable-] PASSED [ 6%] trio/_core/tests/test_io.py::test_interrupted_by_close[notify_closing--wait_readable] PASSED [ 6%] trio/_core/tests/test_io.py::test_interrupted_by_close[notify_closing--] PASSED [ 6%] trio/_core/tests/test_io.py::test_interrupted_by_close[-wait_writable-wait_readable] PASSED [ 6%] trio/_core/tests/test_io.py::test_interrupted_by_close[-wait_writable-] PASSED [ 6%] trio/_core/tests/test_io.py::test_interrupted_by_close[--wait_readable] PASSED [ 7%] trio/_core/tests/test_io.py::test_interrupted_by_close[--] PASSED [ 7%] trio/_core/tests/test_io.py::test_socket_simultaneous_read_write[wait_writable-wait_readable] PASSED [ 7%] trio/_core/tests/test_io.py::test_socket_simultaneous_read_write[wait_writable-] PASSED [ 7%] trio/_core/tests/test_io.py::test_socket_simultaneous_read_write[-wait_readable] PASSED [ 7%] trio/_core/tests/test_io.py::test_socket_simultaneous_read_write[-] PASSED [ 7%] trio/_core/tests/test_io.py::test_socket_actual_streaming[wait_writable-wait_readable] PASSED [ 8%] trio/_core/tests/test_io.py::test_socket_actual_streaming[wait_writable-] PASSED [ 8%] trio/_core/tests/test_io.py::test_socket_actual_streaming[-wait_readable] PASSED [ 8%] trio/_core/tests/test_io.py::test_socket_actual_streaming[-] PASSED [ 8%] trio/_core/tests/test_io.py::test_notify_closing_on_invalid_object PASSED [ 8%] trio/_core/tests/test_io.py::test_wait_on_invalid_object PASSED [ 8%] trio/_core/tests/test_io.py::test_io_manager_statistics PASSED [ 9%] trio/_core/tests/test_io.py::test_can_survive_unnotified_close PASSED [ 9%] trio/_core/tests/test_ki.py::test_ki_self PASSED [ 9%] trio/_core/tests/test_ki.py::test_ki_enabled PASSED [ 9%] trio/_core/tests/test_ki.py::test_ki_enabled_after_yield_briefly PASSED [ 9%] trio/_core/tests/test_ki.py::test_generator_based_context_manager_throw PASSED [ 9%] trio/_core/tests/test_ki.py::test_agen_protection PASSED [ 10%] trio/_core/tests/test_ki.py::test_ki_disabled_out_of_context PASSED [ 10%] trio/_core/tests/test_ki.py::test_ki_disabled_in_del PASSED [ 10%] trio/_core/tests/test_ki.py::test_ki_protection_works PASSED [ 10%] trio/_core/tests/test_ki.py::test_ki_is_good_neighbor PASSED [ 10%] trio/_core/tests/test_ki.py::test_ki_with_broken_threads PASSED [ 10%] trio/_core/tests/test_ki.py::test_ki_wakes_us_up PASSED [ 11%] trio/_core/tests/test_local.py::test_runvar_smoketest PASSED [ 11%] trio/_core/tests/test_local.py::test_runvar_resetting PASSED [ 11%] trio/_core/tests/test_local.py::test_runvar_sync PASSED [ 11%] trio/_core/tests/test_local.py::test_accessing_runvar_outside_run_call_fails PASSED [ 11%] trio/_core/tests/test_mock_clock.py::test_mock_clock PASSED [ 11%] trio/_core/tests/test_mock_clock.py::test_mock_clock_autojump PASSED [ 12%] trio/_core/tests/test_mock_clock.py::test_mock_clock_autojump_interference PASSED [ 12%] trio/_core/tests/test_mock_clock.py::test_mock_clock_autojump_preset PASSED [ 12%] trio/_core/tests/test_mock_clock.py::test_mock_clock_autojump_0_and_wait_all_tasks_blocked_0 PASSED [ 12%] trio/_core/tests/test_mock_clock.py::test_mock_clock_autojump_0_and_wait_all_tasks_blocked_nonzero PASSED [ 12%] trio/_core/tests/test_multierror.py::test_concat_tb PASSED [ 12%] trio/_core/tests/test_multierror.py::test_MultiError PASSED [ 13%] trio/_core/tests/test_multierror.py::test_MultiErrorOfSingleMultiError PASSED [ 13%] trio/_core/tests/test_multierror.py::test_MultiErrorNotHashable PASSED [ 13%] trio/_core/tests/test_multierror.py::test_MultiError_filter_NotHashable PASSED [ 13%] trio/_core/tests/test_multierror.py::test_traceback_recursion PASSED [ 13%] trio/_core/tests/test_multierror.py::test_MultiError_filter PASSED [ 13%] trio/_core/tests/test_multierror.py::test_MultiError_catch PASSED [ 14%] trio/_core/tests/test_multierror.py::test_assert_match_in_seq PASSED [ 14%] trio/_core/tests/test_multierror.py::test_format_exception PASSED [ 14%] trio/_core/tests/test_multierror.py::test_logging PASSED [ 14%] trio/_core/tests/test_multierror.py::test_simple_excepthook PASSED [ 14%] trio/_core/tests/test_multierror.py::test_custom_excepthook PASSED [ 14%] trio/_core/tests/test_multierror.py::test_ipython_exc_handler SKIPPED [ 15%] trio/_core/tests/test_multierror.py::test_ipython_imported_but_unused SKIPPED [ 15%] trio/_core/tests/test_multierror.py::test_partial_imported_but_unused PASSED [ 15%] trio/_core/tests/test_multierror.py::test_ipython_custom_exc_handler SKIPPED [ 15%] trio/_core/tests/test_multierror.py::test_apport_excepthook_monkeypatch_interaction SKIPPED [ 15%] trio/_core/tests/test_parking_lot.py::test_parking_lot_basic PASSED [ 15%] trio/_core/tests/test_parking_lot.py::test_parking_lot_cancel PASSED [ 16%] trio/_core/tests/test_parking_lot.py::test_parking_lot_repark PASSED [ 16%] trio/_core/tests/test_parking_lot.py::test_parking_lot_repark_with_count PASSED [ 16%] trio/_core/tests/test_run.py::test_basic PASSED [ 16%] trio/_core/tests/test_run.py::test_initial_task_error PASSED [ 16%] trio/_core/tests/test_run.py::test_run_nesting PASSED [ 16%] trio/_core/tests/test_run.py::test_nursery_warn_use_async_with PASSED [ 17%] trio/_core/tests/test_run.py::test_nursery_main_block_error_basic PASSED [ 17%] trio/_core/tests/test_run.py::test_child_crash_basic PASSED [ 17%] trio/_core/tests/test_run.py::test_basic_interleave PASSED [ 17%] trio/_core/tests/test_run.py::test_task_crash_propagation PASSED [ 17%] trio/_core/tests/test_run.py::test_main_and_task_both_crash PASSED [ 17%] trio/_core/tests/test_run.py::test_two_child_crashes PASSED [ 18%] trio/_core/tests/test_run.py::test_child_crash_wakes_parent PASSED [ 18%] trio/_core/tests/test_run.py::test_reschedule PASSED [ 18%] trio/_core/tests/test_run.py::test_current_time PASSED [ 18%] trio/_core/tests/test_run.py::test_current_time_with_mock_clock PASSED [ 18%] trio/_core/tests/test_run.py::test_current_clock PASSED [ 18%] trio/_core/tests/test_run.py::test_current_task PASSED [ 19%] trio/_core/tests/test_run.py::test_root_task PASSED [ 19%] trio/_core/tests/test_run.py::test_out_of_context PASSED [ 19%] trio/_core/tests/test_run.py::test_current_statistics PASSED [ 19%] trio/_core/tests/test_run.py::test_cancel_scope_repr PASSED [ 19%] trio/_core/tests/test_run.py::test_cancel_points PASSED [ 19%] trio/_core/tests/test_run.py::test_cancel_edge_cases PASSED [ 20%] trio/_core/tests/test_run.py::test_cancel_scope_multierror_filtering PASSED [ 20%] trio/_core/tests/test_run.py::test_precancelled_task PASSED [ 20%] trio/_core/tests/test_run.py::test_cancel_shielding PASSED [ 20%] trio/_core/tests/test_run.py::test_cancel_inheritance PASSED [ 20%] trio/_core/tests/test_run.py::test_cancel_shield_abort PASSED [ 20%] trio/_core/tests/test_run.py::test_basic_timeout PASSED [ 21%] trio/_core/tests/test_run.py::test_cancel_scope_nesting PASSED [ 21%] trio/_core/tests/test_run.py::test_unshield_while_cancel_propagating PASSED [ 21%] trio/_core/tests/test_run.py::test_cancel_unbound PASSED [ 21%] trio/_core/tests/test_run.py::test_cancel_scope_misnesting PASSED [ 21%] trio/_core/tests/test_run.py::test_timekeeping PASSED [ 21%] trio/_core/tests/test_run.py::test_failed_abort PASSED [ 22%] trio/_core/tests/test_run.py::test_broken_abort PASSED [ 22%] trio/_core/tests/test_run.py::test_error_in_run_loop PASSED [ 22%] trio/_core/tests/test_run.py::test_spawn_system_task PASSED [ 22%] trio/_core/tests/test_run.py::test_system_task_crash PASSED [ 22%] trio/_core/tests/test_run.py::test_system_task_crash_MultiError PASSED [ 22%] trio/_core/tests/test_run.py::test_system_task_crash_plus_Cancelled PASSED [ 23%] trio/_core/tests/test_run.py::test_system_task_crash_KeyboardInterrupt PASSED [ 23%] trio/_core/tests/test_run.py::test_yield_briefly_checks_for_timeout PASSED [ 23%] trio/_core/tests/test_run.py::test_exc_info PASSED [ 23%] trio/_core/tests/test_run.py::test_exc_info_after_yield_error PASSED [ 23%] trio/_core/tests/test_run.py::test_exception_chaining_after_yield_error PASSED [ 23%] trio/_core/tests/test_run.py::test_nursery_exception_chaining_doesnt_make_context_loops PASSED [ 24%] trio/_core/tests/test_run.py::test_TrioToken_identity PASSED [ 24%] trio/_core/tests/test_run.py::test_TrioToken_run_sync_soon_basic PASSED [ 24%] trio/_core/tests/test_run.py::test_TrioToken_run_sync_soon_too_late PASSED [ 24%] trio/_core/tests/test_run.py::test_TrioToken_run_sync_soon_idempotent PASSED [ 24%] trio/_core/tests/test_run.py::test_TrioToken_run_sync_soon_idempotent_requeue PASSED [ 25%] trio/_core/tests/test_run.py::test_TrioToken_run_sync_soon_after_main_crash PASSED [ 25%] trio/_core/tests/test_run.py::test_TrioToken_run_sync_soon_crashes PASSED [ 25%] trio/_core/tests/test_run.py::test_TrioToken_run_sync_soon_FIFO PASSED [ 25%] trio/_core/tests/test_run.py::test_TrioToken_run_sync_soon_starvation_resistance PASSED [ 25%] trio/_core/tests/test_run.py::test_TrioToken_run_sync_soon_threaded_stress_test PASSED [ 25%] trio/_core/tests/test_run.py::test_TrioToken_run_sync_soon_massive_queue PASSED [ 26%] trio/_core/tests/test_run.py::test_TrioToken_run_sync_soon_late_crash PASSED [ 26%] trio/_core/tests/test_run.py::test_slow_abort_basic PASSED [ 26%] trio/_core/tests/test_run.py::test_slow_abort_edge_cases PASSED [ 26%] trio/_core/tests/test_run.py::test_task_tree_introspection PASSED [ 26%] trio/_core/tests/test_run.py::test_nursery_closure PASSED [ 26%] trio/_core/tests/test_run.py::test_spawn_name PASSED [ 27%] trio/_core/tests/test_run.py::test_current_effective_deadline PASSED [ 27%] trio/_core/tests/test_run.py::test_nice_error_on_bad_calls_to_run_or_spawn PASSED [ 27%] trio/_core/tests/test_run.py::test_calling_asyncio_function_gives_nice_error PASSED [ 27%] trio/_core/tests/test_run.py::test_asyncio_function_inside_nursery_does_not_explode PASSED [ 27%] trio/_core/tests/test_run.py::test_trivial_yields PASSED [ 27%] trio/_core/tests/test_run.py::test_nursery_start PASSED [ 28%] trio/_core/tests/test_run.py::test_task_nursery_stack PASSED [ 28%] trio/_core/tests/test_run.py::test_nursery_start_with_cancelled_nursery PASSED [ 28%] trio/_core/tests/test_run.py::test_nursery_start_keeps_nursery_open PASSED [ 28%] trio/_core/tests/test_run.py::test_nursery_explicit_exception PASSED [ 28%] trio/_core/tests/test_run.py::test_nursery_stop_iteration PASSED [ 28%] trio/_core/tests/test_run.py::test_nursery_stop_async_iteration PASSED [ 29%] trio/_core/tests/test_run.py::test_traceback_frame_removal PASSED [ 29%] trio/_core/tests/test_run.py::test_contextvar_support PASSED [ 29%] trio/_core/tests/test_run.py::test_contextvar_multitask PASSED [ 29%] trio/_core/tests/test_run.py::test_system_task_contexts PASSED [ 29%] trio/_core/tests/test_run.py::test_Nursery_init PASSED [ 29%] trio/_core/tests/test_run.py::test_Nursery_private_init PASSED [ 30%] trio/_core/tests/test_run.py::test_Nursery_subclass PASSED [ 30%] trio/_core/tests/test_run.py::test_Cancelled_init PASSED [ 30%] trio/_core/tests/test_run.py::test_Cancelled_str PASSED [ 30%] trio/_core/tests/test_run.py::test_Cancelled_subclass PASSED [ 30%] trio/_core/tests/test_run.py::test_CancelScope_subclass PASSED [ 30%] trio/_core/tests/test_run.py::test_sniffio_integration PASSED [ 31%] trio/_core/tests/test_run.py::test_Task_custom_sleep_data PASSED [ 31%] trio/_core/tests/test_run.py::test_permanently_detach_coroutine_object PASSED [ 31%] trio/_core/tests/test_run.py::test_detach_and_reattach_coroutine_object PASSED [ 31%] trio/_core/tests/test_run.py::test_detached_coroutine_cancellation PASSED [ 31%] trio/_core/tests/test_run.py::test_async_function_implemented_in_C PASSED [ 31%] trio/_core/tests/test_run.py::test_very_deep_cancel_scope_nesting PASSED [ 32%] trio/_core/tests/test_run.py::test_cancel_scope_deadline_duplicates PASSED [ 32%] trio/_core/tests/test_run.py::test_simple_cancel_scope_usage_doesnt_create_cyclic_garbage PASSED [ 32%] trio/_core/tests/test_run.py::test_nursery_cancel_doesnt_create_cyclic_garbage PASSED [ 32%] trio/_core/tests/test_run.py::test_locals_destroyed_promptly_on_cancel PASSED [ 32%] trio/_core/tests/test_thread_cache.py::test_thread_cache_basics PASSED [ 32%] trio/_core/tests/test_thread_cache.py::test_thread_cache_deref PASSED [ 33%] trio/_core/tests/test_thread_cache.py::test_spawning_new_thread_from_deliver_reuses_starting_thread PASSED [ 33%] trio/_core/tests/test_thread_cache.py::test_idle_threads_exit PASSED [ 33%] trio/_core/tests/test_thread_cache.py::test_race_between_idle_exit_and_job_assignment PASSED [ 33%] trio/_core/tests/test_tutil.py::test_check_sequence_matches PASSED [ 33%] trio/_core/tests/test_unbounded_queue.py::test_UnboundedQueue_basic PASSED [ 33%] trio/_core/tests/test_unbounded_queue.py::test_UnboundedQueue_blocking PASSED [ 34%] trio/_core/tests/test_unbounded_queue.py::test_UnboundedQueue_fairness PASSED [ 34%] trio/_core/tests/test_unbounded_queue.py::test_UnboundedQueue_trivial_yields PASSED [ 34%] trio/_core/tests/test_unbounded_queue.py::test_UnboundedQueue_no_spurious_wakeups PASSED [ 34%] trio/_core/tests/test_windows.py::test_completion_key_listen SKIPPED [ 34%] trio/_core/tests/test_windows.py::test_readinto_overlapped SKIPPED (...) [ 34%] trio/_core/tests/test_windows.py::test_forgot_to_register_with_iocp SKIPPED [ 35%] trio/_core/tests/test_windows.py::test_too_late_to_cancel SKIPPED (w...) [ 35%] trio/_core/tests/test_windows.py::test_lsp_that_hooks_select_gives_good_error SKIPPED [ 35%] trio/_core/tests/test_windows.py::test_lsp_that_completely_hides_base_socket_gives_good_error SKIPPED [ 35%] trio/tests/test_abc.py::test_AsyncResource_defaults PASSED [ 35%] trio/tests/test_abc.py::test_abc_generics PASSED [ 35%] trio/tests/test_channel.py::test_channel PASSED [ 36%] trio/tests/test_channel.py::test_553 PASSED [ 36%] trio/tests/test_channel.py::test_channel_multiple_producers PASSED [ 36%] trio/tests/test_channel.py::test_channel_multiple_consumers PASSED [ 36%] trio/tests/test_channel.py::test_close_basics PASSED [ 36%] trio/tests/test_channel.py::test_close_sync PASSED [ 36%] trio/tests/test_channel.py::test_receive_channel_clone_and_close PASSED [ 37%] trio/tests/test_channel.py::test_close_multiple_send_handles PASSED [ 37%] trio/tests/test_channel.py::test_close_multiple_receive_handles PASSED [ 37%] trio/tests/test_channel.py::test_inf_capacity PASSED [ 37%] trio/tests/test_channel.py::test_statistics PASSED [ 37%] trio/tests/test_channel.py::test_channel_fairness PASSED [ 37%] trio/tests/test_channel.py::test_unbuffered PASSED [ 38%] trio/tests/test_deprecate.py::test_warn_deprecated PASSED [ 38%] trio/tests/test_deprecate.py::test_warn_deprecated_no_instead_or_issue PASSED [ 38%] trio/tests/test_deprecate.py::test_warn_deprecated_stacklevel PASSED [ 38%] trio/tests/test_deprecate.py::test_warn_deprecated_formatting PASSED [ 38%] trio/tests/test_deprecate.py::test_deprecated_decorator PASSED [ 38%] trio/tests/test_deprecate.py::test_deprecated_decorator_method PASSED [ 39%] trio/tests/test_deprecate.py::test_deprecated_decorator_with_explicit_thing PASSED [ 39%] trio/tests/test_deprecate.py::test_deprecated_alias PASSED [ 39%] trio/tests/test_deprecate.py::test_deprecated_alias_method PASSED [ 39%] trio/tests/test_deprecate.py::test_deprecated_docstring_munging PASSED [ 39%] trio/tests/test_deprecate.py::test_module_with_deprecations PASSED [ 39%] trio/tests/test_exports.py::test_core_is_properly_reexported PASSED [ 40%] trio/tests/test_exports.py::test_classes_are_final PASSED [ 40%] trio/tests/test_file_io.py::test_wrap_invalid PASSED [ 40%] trio/tests/test_file_io.py::test_wrap_non_iobase PASSED [ 40%] trio/tests/test_file_io.py::test_wrapped_property PASSED [ 40%] trio/tests/test_file_io.py::test_dir_matches_wrapped PASSED [ 40%] trio/tests/test_file_io.py::test_unsupported_not_forwarded PASSED [ 41%] trio/tests/test_file_io.py::test_sync_attrs_forwarded PASSED [ 41%] trio/tests/test_file_io.py::test_sync_attrs_match_wrapper PASSED [ 41%] trio/tests/test_file_io.py::test_async_methods_generated_once PASSED [ 41%] trio/tests/test_file_io.py::test_async_methods_signature PASSED [ 41%] trio/tests/test_file_io.py::test_async_methods_wrap PASSED [ 41%] trio/tests/test_file_io.py::test_async_methods_match_wrapper PASSED [ 42%] trio/tests/test_file_io.py::test_open PASSED [ 42%] trio/tests/test_file_io.py::test_open_context_manager PASSED [ 42%] trio/tests/test_file_io.py::test_async_iter PASSED [ 42%] trio/tests/test_file_io.py::test_aclose_cancelled PASSED [ 42%] trio/tests/test_file_io.py::test_detach_rewraps_asynciobase PASSED [ 42%] trio/tests/test_highlevel_generic.py::test_StapledStream PASSED [ 43%] trio/tests/test_highlevel_generic.py::test_StapledStream_with_erroring_close PASSED [ 43%] trio/tests/test_highlevel_open_tcp_listeners.py::test_open_tcp_listeners_basic PASSED [ 43%] trio/tests/test_highlevel_open_tcp_listeners.py::test_open_tcp_listeners_specific_port_specific_host PASSED [ 43%] trio/tests/test_highlevel_open_tcp_listeners.py::test_open_tcp_listeners_ipv6_v6only PASSED [ 43%] trio/tests/test_highlevel_open_tcp_listeners.py::test_open_tcp_listeners_rebind PASSED [ 43%] trio/tests/test_highlevel_open_tcp_listeners.py::test_open_tcp_listeners_multiple_host_cleanup_on_error PASSED [ 44%] trio/tests/test_highlevel_open_tcp_listeners.py::test_open_tcp_listeners_port_checking PASSED [ 44%] trio/tests/test_highlevel_open_tcp_listeners.py::test_serve_tcp PASSED [ 44%] trio/tests/test_highlevel_open_tcp_listeners.py::test_open_tcp_listeners_some_address_families_unavailable[fail_families0-try_families0] PASSED [ 44%] trio/tests/test_highlevel_open_tcp_listeners.py::test_open_tcp_listeners_some_address_families_unavailable[fail_families0-try_families1] PASSED [ 44%] trio/tests/test_highlevel_open_tcp_listeners.py::test_open_tcp_listeners_some_address_families_unavailable[fail_families0-try_families2] PASSED [ 44%] trio/tests/test_highlevel_open_tcp_listeners.py::test_open_tcp_listeners_some_address_families_unavailable[fail_families1-try_families0] PASSED [ 45%] trio/tests/test_highlevel_open_tcp_listeners.py::test_open_tcp_listeners_some_address_families_unavailable[fail_families1-try_families1] PASSED [ 45%] trio/tests/test_highlevel_open_tcp_listeners.py::test_open_tcp_listeners_some_address_families_unavailable[fail_families1-try_families2] PASSED [ 45%] trio/tests/test_highlevel_open_tcp_listeners.py::test_open_tcp_listeners_some_address_families_unavailable[fail_families2-try_families0] PASSED [ 45%] trio/tests/test_highlevel_open_tcp_listeners.py::test_open_tcp_listeners_some_address_families_unavailable[fail_families2-try_families1] PASSED [ 45%] trio/tests/test_highlevel_open_tcp_listeners.py::test_open_tcp_listeners_some_address_families_unavailable[fail_families2-try_families2] PASSED [ 45%] trio/tests/test_highlevel_open_tcp_listeners.py::test_open_tcp_listeners_socket_fails_not_afnosupport PASSED [ 46%] trio/tests/test_highlevel_open_tcp_listeners.py::test_open_tcp_listeners_backlog PASSED [ 46%] trio/tests/test_highlevel_open_tcp_stream.py::test_close_all PASSED [ 46%] trio/tests/test_highlevel_open_tcp_stream.py::test_reorder_for_rfc_6555_section_5_4 PASSED [ 46%] trio/tests/test_highlevel_open_tcp_stream.py::test_format_host_port PASSED [ 46%] trio/tests/test_highlevel_open_tcp_stream.py::test_open_tcp_stream_real_socket_smoketest PASSED [ 46%] trio/tests/test_highlevel_open_tcp_stream.py::test_open_tcp_stream_input_validation PASSED [ 47%] trio/tests/test_highlevel_open_tcp_stream.py::test_local_address_real PASSED [ 47%] trio/tests/test_highlevel_open_tcp_stream.py::test_one_host_quick_success PASSED [ 47%] trio/tests/test_highlevel_open_tcp_stream.py::test_one_host_slow_success PASSED [ 47%] trio/tests/test_highlevel_open_tcp_stream.py::test_one_host_quick_fail PASSED [ 47%] trio/tests/test_highlevel_open_tcp_stream.py::test_one_host_slow_fail PASSED [ 47%] trio/tests/test_highlevel_open_tcp_stream.py::test_one_host_failed_after_connect PASSED [ 48%] trio/tests/test_highlevel_open_tcp_stream.py::test_basic_fallthrough PASSED [ 48%] trio/tests/test_highlevel_open_tcp_stream.py::test_early_success PASSED [ 48%] trio/tests/test_highlevel_open_tcp_stream.py::test_custom_delay PASSED [ 48%] trio/tests/test_highlevel_open_tcp_stream.py::test_custom_errors_expedite PASSED [ 48%] trio/tests/test_highlevel_open_tcp_stream.py::test_all_fail PASSED [ 48%] trio/tests/test_highlevel_open_tcp_stream.py::test_multi_success PASSED [ 49%] trio/tests/test_highlevel_open_tcp_stream.py::test_does_reorder PASSED [ 49%] trio/tests/test_highlevel_open_tcp_stream.py::test_handles_no_ipv4 PASSED [ 49%] trio/tests/test_highlevel_open_tcp_stream.py::test_handles_no_ipv6 PASSED [ 49%] trio/tests/test_highlevel_open_tcp_stream.py::test_no_hosts PASSED [ 49%] trio/tests/test_highlevel_open_tcp_stream.py::test_cancel PASSED [ 50%] trio/tests/test_highlevel_open_unix_stream.py::test_close_on_error PASSED [ 50%] trio/tests/test_highlevel_open_unix_stream.py::test_open_with_bad_filename_type[4] PASSED [ 50%] trio/tests/test_highlevel_open_unix_stream.py::test_open_with_bad_filename_type[4.5] PASSED [ 50%] trio/tests/test_highlevel_open_unix_stream.py::test_open_bad_socket PASSED [ 50%] trio/tests/test_highlevel_open_unix_stream.py::test_open_unix_socket PASSED [ 50%] trio/tests/test_highlevel_serve_listeners.py::test_serve_listeners_basic PASSED [ 51%] trio/tests/test_highlevel_serve_listeners.py::test_serve_listeners_accept_unrecognized_error PASSED [ 51%] trio/tests/test_highlevel_serve_listeners.py::test_serve_listeners_accept_capacity_error PASSED [ 51%] trio/tests/test_highlevel_serve_listeners.py::test_serve_listeners_connection_nursery PASSED [ 51%] trio/tests/test_highlevel_socket.py::test_SocketStream_basics PASSED [ 51%] trio/tests/test_highlevel_socket.py::test_SocketStream_send_all PASSED [ 51%] trio/tests/test_highlevel_socket.py::test_SocketStream_generic PASSED [ 52%] trio/tests/test_highlevel_socket.py::test_SocketListener PASSED [ 52%] trio/tests/test_highlevel_socket.py::test_SocketListener_socket_closed_underfoot PASSED [ 52%] trio/tests/test_highlevel_socket.py::test_SocketListener_accept_errors PASSED [ 52%] trio/tests/test_highlevel_socket.py::test_socket_stream_works_when_peer_has_already_closed PASSED [ 52%] trio/tests/test_highlevel_ssl_helpers.py::test_open_ssl_over_tcp_stream_and_everything_else[tls13] PASSED [ 52%] trio/tests/test_highlevel_ssl_helpers.py::test_open_ssl_over_tcp_stream_and_everything_else[tls12] PASSED [ 53%] trio/tests/test_highlevel_ssl_helpers.py::test_open_ssl_over_tcp_listeners PASSED [ 53%] trio/tests/test_path.py::test_open_is_async_context_manager PASSED [ 53%] trio/tests/test_path.py::test_magic PASSED [ 53%] trio/tests/test_path.py::test_cmp_magic[Path-Path0] PASSED [ 53%] trio/tests/test_path.py::test_cmp_magic[Path-Path1] PASSED [ 53%] trio/tests/test_path.py::test_cmp_magic[Path-Path2] PASSED [ 54%] trio/tests/test_path.py::test_div_magic[Path-Path0] PASSED [ 54%] trio/tests/test_path.py::test_div_magic[Path-Path1] PASSED [ 54%] trio/tests/test_path.py::test_div_magic[Path-str] PASSED [ 54%] trio/tests/test_path.py::test_div_magic[str-Path] PASSED [ 54%] trio/tests/test_path.py::test_hash_magic[foo-Path-Path0] PASSED [ 54%] trio/tests/test_path.py::test_hash_magic[foo-Path-Path1] PASSED [ 55%] trio/tests/test_path.py::test_hash_magic[foo/bar/baz-Path-Path0] PASSED [ 55%] trio/tests/test_path.py::test_hash_magic[foo/bar/baz-Path-Path1] PASSED [ 55%] trio/tests/test_path.py::test_hash_magic[./foo-Path-Path0] PASSED [ 55%] trio/tests/test_path.py::test_hash_magic[./foo-Path-Path1] PASSED [ 55%] trio/tests/test_path.py::test_forwarded_properties PASSED [ 55%] trio/tests/test_path.py::test_async_method_signature PASSED [ 56%] trio/tests/test_path.py::test_compare_async_stat_methods[is_dir] PASSED [ 56%] trio/tests/test_path.py::test_compare_async_stat_methods[is_file] PASSED [ 56%] trio/tests/test_path.py::test_invalid_name_not_wrapped PASSED [ 56%] trio/tests/test_path.py::test_async_methods_rewrap[absolute] PASSED [ 56%] trio/tests/test_path.py::test_async_methods_rewrap[resolve] PASSED [ 56%] trio/tests/test_path.py::test_forward_methods_rewrap PASSED [ 57%] trio/tests/test_path.py::test_forward_properties_rewrap PASSED [ 57%] trio/tests/test_path.py::test_forward_methods_without_rewrap PASSED [ 57%] trio/tests/test_path.py::test_repr PASSED [ 57%] trio/tests/test_path.py::test_type_forwards_unsupported PASSED [ 57%] trio/tests/test_path.py::test_type_wraps_unsupported PASSED [ 57%] trio/tests/test_path.py::test_type_forwards_private PASSED [ 58%] trio/tests/test_path.py::test_type_wraps_private PASSED [ 58%] trio/tests/test_path.py::test_path_wraps_path[__init__] PASSED [ 58%] trio/tests/test_path.py::test_path_wraps_path[joinpath] PASSED [ 58%] trio/tests/test_path.py::test_path_nonpath PASSED [ 58%] trio/tests/test_path.py::test_open_file_can_open_path PASSED [ 58%] trio/tests/test_path.py::test_globmethods PASSED [ 59%] trio/tests/test_path.py::test_iterdir PASSED [ 59%] trio/tests/test_path.py::test_classmethods PASSED [ 59%] trio/tests/test_scheduler_determinism.py::test_the_trio_scheduler_is_not_deterministic PASSED [ 59%] trio/tests/test_scheduler_determinism.py::test_the_trio_scheduler_is_deterministic_if_seeded PASSED [ 59%] trio/tests/test_signals.py::test_open_signal_receiver PASSED [ 59%] trio/tests/test_signals.py::test_open_signal_receiver_restore_handler_after_one_bad_signal PASSED [ 60%] trio/tests/test_signals.py::test_open_signal_receiver_empty_fail PASSED [ 60%] trio/tests/test_signals.py::test_open_signal_receiver_restore_handler_after_duplicate_signal PASSED [ 60%] trio/tests/test_signals.py::test_catch_signals_wrong_thread PASSED [ 60%] trio/tests/test_signals.py::test_open_signal_receiver_conflict PASSED [ 60%] trio/tests/test_signals.py::test_open_signal_receiver_no_starvation PASSED [ 60%] trio/tests/test_signals.py::test_catch_signals_race_condition_on_exit PASSED [ 61%] trio/tests/test_socket.py::test__try_sync PASSED [ 61%] trio/tests/test_socket.py::test_socket_has_some_reexports PASSED [ 61%] trio/tests/test_socket.py::test_getaddrinfo PASSED [ 61%] trio/tests/test_socket.py::test_getnameinfo PASSED [ 61%] trio/tests/test_socket.py::test_from_stdlib_socket PASSED [ 61%] trio/tests/test_socket.py::test_from_fd PASSED [ 62%] trio/tests/test_socket.py::test_socketpair_simple PASSED [ 62%] trio/tests/test_socket.py::test_fromshare SKIPPED (windows only) [ 62%] trio/tests/test_socket.py::test_socket PASSED [ 62%] trio/tests/test_socket.py::test_socket_v6 PASSED [ 62%] trio/tests/test_socket.py::test_sniff_sockopts PASSED [ 62%] trio/tests/test_socket.py::test_SocketType_basics PASSED [ 63%] trio/tests/test_socket.py::test_SocketType_dup PASSED [ 63%] trio/tests/test_socket.py::test_SocketType_shutdown PASSED [ 63%] trio/tests/test_socket.py::test_SocketType_simple_server[127.0.0.1-AddressFamily.AF_INET] PASSED [ 63%] trio/tests/test_socket.py::test_SocketType_simple_server[::1-AddressFamily.AF_INET6] PASSED [ 63%] trio/tests/test_socket.py::test_SocketType_is_readable PASSED [ 63%] trio/tests/test_socket.py::test_SocketType_resolve[AddressFamily.AF_INET-addrs0] PASSED [ 64%] trio/tests/test_socket.py::test_SocketType_resolve[AddressFamily.AF_INET6-addrs1] PASSED [ 64%] trio/tests/test_socket.py::test_SocketType_unresolved_names PASSED [ 64%] trio/tests/test_socket.py::test_SocketType_non_blocking_paths PASSED [ 64%] trio/tests/test_socket.py::test_SocketType_connect_paths PASSED [ 64%] trio/tests/test_socket.py::test_resolve_remote_address_exception_closes_socket PASSED [ 64%] trio/tests/test_socket.py::test_send_recv_variants PASSED [ 65%] trio/tests/test_socket.py::test_idna PASSED [ 65%] trio/tests/test_socket.py::test_getprotobyname PASSED [ 65%] trio/tests/test_socket.py::test_custom_hostname_resolver PASSED [ 65%] trio/tests/test_socket.py::test_custom_socket_factory PASSED [ 65%] trio/tests/test_socket.py::test_SocketType_is_abstract PASSED [ 65%] trio/tests/test_socket.py::test_unix_domain_socket PASSED [ 66%] trio/tests/test_socket.py::test_interrupted_by_close PASSED [ 66%] trio/tests/test_socket.py::test_many_sockets PASSED [ 66%] trio/tests/test_ssl.py::test_PyOpenSSLEchoStream_gives_resource_busy_errors PASSED [ 66%] trio/tests/test_ssl.py::test_ssl_client_basics[tls13] PASSED [ 66%] trio/tests/test_ssl.py::test_ssl_server_basics[tls13] PASSED [ 66%] trio/tests/test_ssl.py::test_attributes[tls13] PASSED [ 67%] trio/tests/test_ssl.py::test_full_duplex_basics[tls13] PASSED [ 67%] trio/tests/test_ssl.py::test_renegotiation_simple[tls13] PASSED [ 67%] trio/tests/test_ssl.py::test_renegotiation_randomized[tls13] PASSED [ 67%] trio/tests/test_ssl.py::test_resource_busy_errors[tls13] PASSED [ 67%] trio/tests/test_ssl.py::test_checkpoints[tls13] PASSED [ 67%] trio/tests/test_ssl.py::test_send_all_empty_string[tls13] PASSED [ 68%] trio/tests/test_ssl.py::test_SSLStream_generic[tls13-False] PASSED [ 68%] trio/tests/test_ssl.py::test_SSLStream_generic[tls13-True] PASSED [ 68%] trio/tests/test_ssl.py::test_unwrap[tls13] PASSED [ 68%] trio/tests/test_ssl.py::test_closing_nice_case[tls13] PASSED [ 68%] trio/tests/test_ssl.py::test_send_all_fails_in_the_middle[tls13] PASSED [ 68%] trio/tests/test_ssl.py::test_ssl_over_ssl[tls13] PASSED [ 69%] trio/tests/test_ssl.py::test_ssl_bad_shutdown[tls13] FAILED [ 69%] trio/tests/test_ssl.py::test_ssl_bad_shutdown_but_its_ok[tls13] PASSED [ 69%] trio/tests/test_ssl.py::test_ssl_only_closes_stream_once[tls13] PASSED [ 69%] trio/tests/test_ssl.py::test_ssl_https_compatibility_disagreement[tls13] FAILED [ 69%] trio/tests/test_ssl.py::test_https_mode_eof_before_handshake[tls13] FAILED [ 69%] trio/tests/test_ssl.py::test_send_error_during_handshake[tls13] PASSED [ 70%] trio/tests/test_ssl.py::test_receive_error_during_handshake[tls13] PASSED [ 70%] trio/tests/test_ssl.py::test_selected_alpn_protocol_before_handshake[tls13] PASSED [ 70%] trio/tests/test_ssl.py::test_selected_alpn_protocol_when_not_set[tls13] PASSED [ 70%] trio/tests/test_ssl.py::test_selected_npn_protocol_before_handshake[tls13] PASSED [ 70%] trio/tests/test_ssl.py::test_selected_npn_protocol_when_not_set[tls13] PASSED [ 70%] trio/tests/test_ssl.py::test_get_channel_binding_before_handshake[tls13] PASSED [ 71%] trio/tests/test_ssl.py::test_get_channel_binding_after_handshake[tls13] PASSED [ 71%] trio/tests/test_ssl.py::test_getpeercert[tls13] PASSED [ 71%] trio/tests/test_ssl.py::test_SSLListener[tls13] PASSED [ 71%] trio/tests/test_ssl.py::test_ssl_client_basics[tls12] PASSED [ 71%] trio/tests/test_ssl.py::test_ssl_server_basics[tls12] PASSED [ 71%] trio/tests/test_ssl.py::test_attributes[tls12] PASSED [ 72%] trio/tests/test_ssl.py::test_full_duplex_basics[tls12] PASSED [ 72%] trio/tests/test_ssl.py::test_renegotiation_simple[tls12] PASSED [ 72%] trio/tests/test_ssl.py::test_renegotiation_randomized[tls12] PASSED [ 72%] trio/tests/test_ssl.py::test_resource_busy_errors[tls12] PASSED [ 72%] trio/tests/test_ssl.py::test_checkpoints[tls12] PASSED [ 72%] trio/tests/test_ssl.py::test_send_all_empty_string[tls12] PASSED [ 73%] trio/tests/test_ssl.py::test_SSLStream_generic[tls12-False] PASSED [ 73%] trio/tests/test_ssl.py::test_SSLStream_generic[tls12-True] PASSED [ 73%] trio/tests/test_ssl.py::test_unwrap[tls12] PASSED [ 73%] trio/tests/test_ssl.py::test_closing_nice_case[tls12] PASSED [ 73%] trio/tests/test_ssl.py::test_send_all_fails_in_the_middle[tls12] PASSED [ 73%] trio/tests/test_ssl.py::test_ssl_over_ssl[tls12] PASSED [ 74%] trio/tests/test_ssl.py::test_ssl_bad_shutdown[tls12] FAILED [ 74%] trio/tests/test_ssl.py::test_ssl_bad_shutdown_but_its_ok[tls12] PASSED [ 74%] trio/tests/test_ssl.py::test_ssl_only_closes_stream_once[tls12] PASSED [ 74%] trio/tests/test_ssl.py::test_ssl_https_compatibility_disagreement[tls12] FAILED [ 74%] trio/tests/test_ssl.py::test_https_mode_eof_before_handshake[tls12] FAILED [ 75%] trio/tests/test_ssl.py::test_send_error_during_handshake[tls12] PASSED [ 75%] trio/tests/test_ssl.py::test_receive_error_during_handshake[tls12] PASSED [ 75%] trio/tests/test_ssl.py::test_selected_alpn_protocol_before_handshake[tls12] PASSED [ 75%] trio/tests/test_ssl.py::test_selected_alpn_protocol_when_not_set[tls12] PASSED [ 75%] trio/tests/test_ssl.py::test_selected_npn_protocol_before_handshake[tls12] PASSED [ 75%] trio/tests/test_ssl.py::test_selected_npn_protocol_when_not_set[tls12] PASSED [ 76%] trio/tests/test_ssl.py::test_get_channel_binding_before_handshake[tls12] PASSED [ 76%] trio/tests/test_ssl.py::test_get_channel_binding_after_handshake[tls12] PASSED [ 76%] trio/tests/test_ssl.py::test_getpeercert[tls12] PASSED [ 76%] trio/tests/test_ssl.py::test_SSLListener[tls12] PASSED [ 76%] trio/tests/test_ssl.py::test_wait_writable_calls_underlying_wait_writable PASSED [ 76%] trio/tests/test_ssl.py::test_ssl_handshake_failure_during_aclose PASSED [ 77%] trio/tests/test_subprocess.py::test_basic PASSED [ 77%] trio/tests/test_subprocess.py::test_auto_update_returncode PASSED [ 77%] trio/tests/test_subprocess.py::test_multi_wait PASSED [ 77%] trio/tests/test_subprocess.py::test_kill_when_context_cancelled PASSED [ 77%] trio/tests/test_subprocess.py::test_pipes PASSED [ 77%] trio/tests/test_subprocess.py::test_interactive PASSED [ 78%] trio/tests/test_subprocess.py::test_run PASSED [ 78%] trio/tests/test_subprocess.py::test_run_check PASSED [ 78%] trio/tests/test_subprocess.py::test_run_with_broken_pipe PASSED [ 78%] trio/tests/test_subprocess.py::test_stderr_stdout PASSED [ 78%] trio/tests/test_subprocess.py::test_errors PASSED [ 78%] trio/tests/test_subprocess.py::test_signals PASSED [ 79%] trio/tests/test_subprocess.py::test_wait_reapable_fails PASSED [ 79%] trio/tests/test_subprocess.py::test_waitid_eintr PASSED [ 79%] trio/tests/test_subprocess.py::test_custom_deliver_cancel PASSED [ 79%] trio/tests/test_subprocess.py::test_warn_on_failed_cancel_terminate PASSED [ 79%] trio/tests/test_subprocess.py::test_warn_on_cancel_SIGKILL_escalation PASSED [ 79%] trio/tests/test_sync.py::test_Event PASSED [ 80%] trio/tests/test_sync.py::test_CapacityLimiter PASSED [ 80%] trio/tests/test_sync.py::test_CapacityLimiter_inf PASSED [ 80%] trio/tests/test_sync.py::test_CapacityLimiter_change_total_tokens PASSED [ 80%] trio/tests/test_sync.py::test_CapacityLimiter_memleak_548 PASSED [ 80%] trio/tests/test_sync.py::test_Semaphore PASSED [ 80%] trio/tests/test_sync.py::test_Semaphore_bounded PASSED [ 81%] trio/tests/test_sync.py::test_Lock_and_StrictFIFOLock[Lock] PASSED [ 81%] trio/tests/test_sync.py::test_Lock_and_StrictFIFOLock[StrictFIFOLock] PASSED [ 81%] trio/tests/test_sync.py::test_Condition PASSED [ 81%] trio/tests/test_sync.py::test_generic_lock_exclusion[CapacityLimiter(1)] PASSED [ 81%] trio/tests/test_sync.py::test_generic_lock_exclusion[Semaphore(1)] PASSED [ 81%] trio/tests/test_sync.py::test_generic_lock_exclusion[Lock] PASSED [ 82%] trio/tests/test_sync.py::test_generic_lock_exclusion[StrictFIFOLock] PASSED [ 82%] trio/tests/test_sync.py::test_generic_lock_exclusion[ChannelLock1(10)] PASSED [ 82%] trio/tests/test_sync.py::test_generic_lock_exclusion[ChannelLock1(1)] PASSED [ 82%] trio/tests/test_sync.py::test_generic_lock_exclusion[ChannelLock2] PASSED [ 82%] trio/tests/test_sync.py::test_generic_lock_exclusion[ChannelLock3] PASSED [ 82%] trio/tests/test_sync.py::test_generic_lock_fifo_fairness[CapacityLimiter(1)] PASSED [ 83%] trio/tests/test_sync.py::test_generic_lock_fifo_fairness[Semaphore(1)] PASSED [ 83%] trio/tests/test_sync.py::test_generic_lock_fifo_fairness[Lock] PASSED [ 83%] trio/tests/test_sync.py::test_generic_lock_fifo_fairness[StrictFIFOLock] PASSED [ 83%] trio/tests/test_sync.py::test_generic_lock_fifo_fairness[ChannelLock1(10)] PASSED [ 83%] trio/tests/test_sync.py::test_generic_lock_fifo_fairness[ChannelLock1(1)] PASSED [ 83%] trio/tests/test_sync.py::test_generic_lock_fifo_fairness[ChannelLock2] PASSED [ 84%] trio/tests/test_sync.py::test_generic_lock_fifo_fairness[ChannelLock3] PASSED [ 84%] trio/tests/test_sync.py::test_generic_lock_acquire_nowait_blocks_acquire[CapacityLimiter(1)] PASSED [ 84%] trio/tests/test_sync.py::test_generic_lock_acquire_nowait_blocks_acquire[Semaphore(1)] PASSED [ 84%] trio/tests/test_sync.py::test_generic_lock_acquire_nowait_blocks_acquire[Lock] PASSED [ 84%] trio/tests/test_sync.py::test_generic_lock_acquire_nowait_blocks_acquire[StrictFIFOLock] PASSED [ 84%] trio/tests/test_sync.py::test_generic_lock_acquire_nowait_blocks_acquire[ChannelLock1(10)] PASSED [ 85%] trio/tests/test_sync.py::test_generic_lock_acquire_nowait_blocks_acquire[ChannelLock1(1)] PASSED [ 85%] trio/tests/test_sync.py::test_generic_lock_acquire_nowait_blocks_acquire[ChannelLock2] PASSED [ 85%] trio/tests/test_sync.py::test_generic_lock_acquire_nowait_blocks_acquire[ChannelLock3] PASSED [ 85%] trio/tests/test_testing.py::test_wait_all_tasks_blocked PASSED [ 85%] trio/tests/test_testing.py::test_wait_all_tasks_blocked_with_timeouts PASSED [ 85%] trio/tests/test_testing.py::test_wait_all_tasks_blocked_with_cushion PASSED [ 86%] trio/tests/test_testing.py::test_assert_checkpoints PASSED [ 86%] trio/tests/test_testing.py::test_assert_no_checkpoints PASSED [ 86%] trio/tests/test_testing.py::test_Sequencer PASSED [ 86%] trio/tests/test_testing.py::test_Sequencer_cancel PASSED [ 86%] trio/tests/test_testing.py::test__assert_raises PASSED [ 86%] trio/tests/test_testing.py::test__UnboundeByteQueue PASSED [ 87%] trio/tests/test_testing.py::test_MemorySendStream PASSED [ 87%] trio/tests/test_testing.py::test_MemoryReceiveStream PASSED [ 87%] trio/tests/test_testing.py::test_MemoryRecvStream_closing PASSED [ 87%] trio/tests/test_testing.py::test_memory_stream_pump PASSED [ 87%] trio/tests/test_testing.py::test_memory_stream_one_way_pair PASSED [ 87%] trio/tests/test_testing.py::test_memory_stream_pair PASSED [ 88%] trio/tests/test_testing.py::test_memory_streams_with_generic_tests PASSED [ 88%] trio/tests/test_testing.py::test_lockstep_streams_with_generic_tests PASSED [ 88%] trio/tests/test_testing.py::test_open_stream_to_socket_listener PASSED [ 88%] trio/tests/test_threads.py::test_do_in_trio_thread PASSED [ 88%] trio/tests/test_threads.py::test_do_in_trio_thread_from_trio_thread PASSED [ 88%] trio/tests/test_threads.py::test_run_in_trio_thread_ki PASSED [ 89%] trio/tests/test_threads.py::test_await_in_trio_thread_while_main_exits PASSED [ 89%] trio/tests/test_threads.py::test_run_in_worker_thread PASSED [ 89%] trio/tests/test_threads.py::test_run_in_worker_thread_cancellation PASSED [ 89%] trio/tests/test_threads.py::test_run_in_worker_thread_abandoned PASSED [ 89%] trio/tests/test_threads.py::test_run_in_worker_thread_limiter[False-False-3] PASSED [ 89%] trio/tests/test_threads.py::test_run_in_worker_thread_limiter[False-False-5] PASSED [ 90%] trio/tests/test_threads.py::test_run_in_worker_thread_limiter[False-False-10] PASSED [ 90%] trio/tests/test_threads.py::test_run_in_worker_thread_limiter[False-True-3] PASSED [ 90%] trio/tests/test_threads.py::test_run_in_worker_thread_limiter[False-True-5] PASSED [ 90%] trio/tests/test_threads.py::test_run_in_worker_thread_limiter[False-True-10] PASSED [ 90%] trio/tests/test_threads.py::test_run_in_worker_thread_limiter[True-False-3] PASSED [ 90%] trio/tests/test_threads.py::test_run_in_worker_thread_limiter[True-False-5] PASSED [ 91%] trio/tests/test_threads.py::test_run_in_worker_thread_limiter[True-False-10] PASSED [ 91%] trio/tests/test_threads.py::test_run_in_worker_thread_limiter[True-True-3] PASSED [ 91%] trio/tests/test_threads.py::test_run_in_worker_thread_limiter[True-True-5] PASSED [ 91%] trio/tests/test_threads.py::test_run_in_worker_thread_limiter[True-True-10] PASSED [ 91%] trio/tests/test_threads.py::test_run_in_worker_thread_custom_limiter PASSED [ 91%] trio/tests/test_threads.py::test_run_in_worker_thread_limiter_error PASSED [ 92%] trio/tests/test_threads.py::test_run_in_worker_thread_fail_to_spawn PASSED [ 92%] trio/tests/test_threads.py::test_trio_to_thread_run_sync_token PASSED [ 92%] trio/tests/test_threads.py::test_trio_to_thread_run_sync_expected_error PASSED [ 92%] trio/tests/test_threads.py::test_trio_from_thread_run_sync PASSED [ 92%] trio/tests/test_threads.py::test_trio_from_thread_run PASSED [ 92%] trio/tests/test_threads.py::test_trio_from_thread_token PASSED [ 93%] trio/tests/test_threads.py::test_trio_from_thread_token_kwarg PASSED [ 93%] trio/tests/test_threads.py::test_from_thread_no_token PASSED [ 93%] trio/tests/test_threads.py::test_run_fn_as_system_task_catched_badly_typed_token PASSED [ 93%] trio/tests/test_threads.py::test_from_thread_inside_trio_thread PASSED [ 93%] trio/tests/test_threads.py::test_from_thread_run_during_shutdown PASSED [ 93%] trio/tests/test_threads.py::test_trio_token_weak_referenceable PASSED [ 94%] trio/tests/test_timeouts.py::test_sleep PASSED [ 94%] trio/tests/test_timeouts.py::test_move_on_after PASSED [ 94%] trio/tests/test_timeouts.py::test_fail PASSED [ 94%] trio/tests/test_unix_pipes.py::test_send_pipe PASSED [ 94%] trio/tests/test_unix_pipes.py::test_receive_pipe PASSED [ 94%] trio/tests/test_unix_pipes.py::test_pipes_combined PASSED [ 95%] trio/tests/test_unix_pipes.py::test_pipe_errors PASSED [ 95%] trio/tests/test_unix_pipes.py::test_del PASSED [ 95%] trio/tests/test_unix_pipes.py::test_async_with PASSED [ 95%] trio/tests/test_unix_pipes.py::test_misdirected_aclose_regression PASSED [ 95%] trio/tests/test_unix_pipes.py::test_close_at_bad_time_for_receive_some PASSED [ 95%] trio/tests/test_unix_pipes.py::test_close_at_bad_time_for_send_all PASSED [ 96%] trio/tests/test_unix_pipes.py::test_bizarro_OSError_from_receive PASSED [ 96%] trio/tests/test_unix_pipes.py::test_pipe_fully PASSED [ 96%] trio/tests/test_util.py::test_signal_raise PASSED [ 96%] trio/tests/test_util.py::test_ConflictDetector PASSED [ 96%] trio/tests/test_util.py::test_module_metadata_is_fixed_up PASSED [ 96%] trio/tests/test_util.py::test_is_main_thread PASSED [ 97%] trio/tests/test_util.py::test_coroutine_or_error PASSED [ 97%] trio/tests/test_util.py::test_generic_function PASSED [ 97%] trio/tests/test_util.py::test_final_metaclass PASSED [ 97%] trio/tests/test_util.py::test_no_public_constructor_metaclass PASSED [ 97%] trio/tests/test_wait_for_object.py::test_WaitForMultipleObjects_sync SKIPPED [ 97%] trio/tests/test_wait_for_object.py::test_WaitForMultipleObjects_sync_slow SKIPPED [ 98%] trio/tests/test_wait_for_object.py::test_WaitForSingleObject SKIPPED [ 98%] trio/tests/test_wait_for_object.py::test_WaitForSingleObject_slow SKIPPED [ 98%] trio/tests/test_windows_pipes.py::test_pipe_typecheck SKIPPED (windo...) [ 98%] trio/tests/test_windows_pipes.py::test_pipe_error_on_close SKIPPED (...) [ 98%] trio/tests/test_windows_pipes.py::test_pipes_combined SKIPPED (windo...) [ 98%] trio/tests/test_windows_pipes.py::test_async_with SKIPPED (windows only) [ 99%] trio/tests/test_windows_pipes.py::test_close_during_write SKIPPED (w...) [ 99%] trio/tests/test_windows_pipes.py::test_pipe_fully SKIPPED (windows only) [ 99%] trio/tests/tools/test_gen_exports.py::test_get_public_methods PASSED [ 99%] trio/tests/tools/test_gen_exports.py::test_create_pass_through_args PASSED [ 99%] trio/tests/tools/test_gen_exports.py::test_process PASSED [100%] =================================== FAILURES =================================== ______________________ test_warn_set_wakeup_fd_overwrite _______________________ def test_warn_set_wakeup_fd_overwrite(): assert signal.set_wakeup_fd(-1) == -1 async def trio_main(in_host): return "ok" a, b = socket.socketpair() with a, b: a.setblocking(False) # Warn if there's already a wakeup fd signal.set_wakeup_fd(a.fileno()) try: with pytest.warns(RuntimeWarning, match="signal handling code.*collided"): assert trivial_guest_run(trio_main) == "ok" finally: assert signal.set_wakeup_fd(-1) == a.fileno() signal.set_wakeup_fd(a.fileno()) try: with pytest.warns(RuntimeWarning, match="signal handling code.*collided"): assert ( trivial_guest_run(trio_main, host_uses_signal_set_wakeup_fd=False) == "ok" ) finally: assert signal.set_wakeup_fd(-1) == a.fileno() # Don't warn if there isn't already a wakeup fd > with pytest.warns(None) as record: trio/_core/tests/test_guest_mode.py:170: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = WarningsChecker(record=True), expected_warning = None, match_expr = None def __init__( self, expected_warning: Optional[ Union[Type[Warning], Tuple[Type[Warning], ...]] ] = Warning, match_expr: Optional[Union[str, Pattern[str]]] = None, *, _ispytest: bool = False, ) -> None: check_ispytest(_ispytest) super().__init__(_ispytest=True) msg = "exceptions must be derived from Warning, not %s" if expected_warning is None: > warnings.warn(WARNS_NONE_ARG, stacklevel=4) E pytest.PytestRemovedIn8Warning: Passing None has been deprecated. E See https://docs.pytest.org/en/latest/how-to/capture-warnings.html#additional-use-cases-of-warnings-in-tests for alternatives in common use cases. /usr/lib/python3.10/site-packages/_pytest/recwarn.py:253: PytestRemovedIn8Warning _________________________ test_ssl_bad_shutdown[tls13] _________________________ client_ctx = async def test_ssl_bad_shutdown(client_ctx): client, server = ssl_memory_stream_pair(client_ctx) async with _core.open_nursery() as nursery: nursery.start_soon(client.do_handshake) nursery.start_soon(server.do_handshake) await trio.aclose_forcefully(client) # now the server sees a broken stream > with pytest.raises(BrokenResourceError): E Failed: DID NOT RAISE trio/tests/test_ssl.py:1020: Failed _______________ test_ssl_https_compatibility_disagreement[tls13] _______________ client_ctx = async def test_ssl_https_compatibility_disagreement(client_ctx): client, server = ssl_memory_stream_pair( client_ctx, server_kwargs={"https_compatible": False}, client_kwargs={"https_compatible": True}, ) async with _core.open_nursery() as nursery: nursery.start_soon(client.do_handshake) nursery.start_soon(server.do_handshake) # client is in HTTPS-mode, server is not # so client doing graceful_shutdown causes an error on server async def receive_and_expect_error(): with pytest.raises(BrokenResourceError) as excinfo: await server.receive_some(10) assert isinstance(excinfo.value.__cause__, ssl.SSLEOFError) > async with _core.open_nursery() as nursery: trio/tests/test_ssl.py:1110: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ trio/_core/_run.py:815: in __aexit__ raise combined_error_from_nursery _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ async def receive_and_expect_error(): > with pytest.raises(BrokenResourceError) as excinfo: E Failed: DID NOT RAISE trio/tests/test_ssl.py:1106: Failed _________________ test_https_mode_eof_before_handshake[tls13] __________________ self = fn = > ignore_want_read = False, is_handshake = True, args = (), yielded = True async def _retry(self, fn, *args, ignore_want_read=False, is_handshake=False): await trio.lowlevel.checkpoint_if_cancelled() yielded = False finished = False while not finished: # WARNING: this code needs to be very careful with when it # calls 'await'! There might be multiple tasks calling this # function at the same time trying to do different operations, # so we need to be careful to: # # 1) interact with the SSLObject, then # 2) await on exactly one thing that lets us make forward # progress, then # 3) loop or exit # # In particular we don't want to yield while interacting with # the SSLObject (because it's shared state, so someone else # might come in and mess with it while we're suspended), and # we don't want to yield *before* starting the operation that # will help us make progress, because then someone else might # come in and leapfrog us. # Call the SSLObject method, and get its result. # # NB: despite what the docs say, SSLWantWriteError can't # happen – "Writes to memory BIOs will always succeed if # memory is available: that is their size can grow # indefinitely." # https://wiki.openssl.org/index.php/Manual:BIO_s_mem(3) want_read = False ret = None try: > ret = fn(*args) trio/_ssl.py:458: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = def do_handshake(self): """Start the SSL/TLS handshake.""" > self._sslobj.do_handshake() E ssl.SSLZeroReturnError: TLS/SSL connection has been closed (EOF) (_ssl.c:997) /usr/lib/python3.10/ssl.py:975: SSLZeroReturnError The above exception was the direct cause of the following exception: client_ctx = async def test_https_mode_eof_before_handshake(client_ctx): client, server = ssl_memory_stream_pair( client_ctx, server_kwargs={"https_compatible": True}, client_kwargs={"https_compatible": True}, ) async def server_expect_clean_eof(): assert await server.receive_some(10) == b"" > async with _core.open_nursery() as nursery: trio/tests/test_ssl.py:1125: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ trio/_core/_run.py:815: in __aexit__ raise combined_error_from_nursery trio/tests/test_ssl.py:1123: in server_expect_clean_eof assert await server.receive_some(10) == b"" trio/_ssl.py:656: in receive_some await self._handshook.ensure(checkpoint=False) trio/_ssl.py:211: in ensure await self._afn(*self._args) trio/_ssl.py:600: in _do_handshake await self._retry(self._ssl_object.do_handshake, is_handshake=True) _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = fn = > ignore_want_read = False, is_handshake = True, args = (), yielded = True async def _retry(self, fn, *args, ignore_want_read=False, is_handshake=False): await trio.lowlevel.checkpoint_if_cancelled() yielded = False finished = False while not finished: # WARNING: this code needs to be very careful with when it # calls 'await'! There might be multiple tasks calling this # function at the same time trying to do different operations, # so we need to be careful to: # # 1) interact with the SSLObject, then # 2) await on exactly one thing that lets us make forward # progress, then # 3) loop or exit # # In particular we don't want to yield while interacting with # the SSLObject (because it's shared state, so someone else # might come in and mess with it while we're suspended), and # we don't want to yield *before* starting the operation that # will help us make progress, because then someone else might # come in and leapfrog us. # Call the SSLObject method, and get its result. # # NB: despite what the docs say, SSLWantWriteError can't # happen – "Writes to memory BIOs will always succeed if # memory is available: that is their size can grow # indefinitely." # https://wiki.openssl.org/index.php/Manual:BIO_s_mem(3) want_read = False ret = None try: ret = fn(*args) except _stdlib_ssl.SSLWantReadError: want_read = True except (_stdlib_ssl.SSLError, _stdlib_ssl.CertificateError) as exc: self._state = _State.BROKEN > raise trio.BrokenResourceError from exc E trio.BrokenResourceError trio/_ssl.py:463: BrokenResourceError _________________________ test_ssl_bad_shutdown[tls12] _________________________ client_ctx = async def test_ssl_bad_shutdown(client_ctx): client, server = ssl_memory_stream_pair(client_ctx) async with _core.open_nursery() as nursery: nursery.start_soon(client.do_handshake) nursery.start_soon(server.do_handshake) await trio.aclose_forcefully(client) # now the server sees a broken stream > with pytest.raises(BrokenResourceError): E Failed: DID NOT RAISE trio/tests/test_ssl.py:1020: Failed _______________ test_ssl_https_compatibility_disagreement[tls12] _______________ client_ctx = async def test_ssl_https_compatibility_disagreement(client_ctx): client, server = ssl_memory_stream_pair( client_ctx, server_kwargs={"https_compatible": False}, client_kwargs={"https_compatible": True}, ) async with _core.open_nursery() as nursery: nursery.start_soon(client.do_handshake) nursery.start_soon(server.do_handshake) # client is in HTTPS-mode, server is not # so client doing graceful_shutdown causes an error on server async def receive_and_expect_error(): with pytest.raises(BrokenResourceError) as excinfo: await server.receive_some(10) assert isinstance(excinfo.value.__cause__, ssl.SSLEOFError) > async with _core.open_nursery() as nursery: trio/tests/test_ssl.py:1110: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ trio/_core/_run.py:815: in __aexit__ raise combined_error_from_nursery _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ async def receive_and_expect_error(): > with pytest.raises(BrokenResourceError) as excinfo: E Failed: DID NOT RAISE trio/tests/test_ssl.py:1106: Failed _________________ test_https_mode_eof_before_handshake[tls12] __________________ self = fn = > ignore_want_read = False, is_handshake = True, args = (), yielded = True async def _retry(self, fn, *args, ignore_want_read=False, is_handshake=False): await trio.lowlevel.checkpoint_if_cancelled() yielded = False finished = False while not finished: # WARNING: this code needs to be very careful with when it # calls 'await'! There might be multiple tasks calling this # function at the same time trying to do different operations, # so we need to be careful to: # # 1) interact with the SSLObject, then # 2) await on exactly one thing that lets us make forward # progress, then # 3) loop or exit # # In particular we don't want to yield while interacting with # the SSLObject (because it's shared state, so someone else # might come in and mess with it while we're suspended), and # we don't want to yield *before* starting the operation that # will help us make progress, because then someone else might # come in and leapfrog us. # Call the SSLObject method, and get its result. # # NB: despite what the docs say, SSLWantWriteError can't # happen – "Writes to memory BIOs will always succeed if # memory is available: that is their size can grow # indefinitely." # https://wiki.openssl.org/index.php/Manual:BIO_s_mem(3) want_read = False ret = None try: > ret = fn(*args) trio/_ssl.py:458: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = def do_handshake(self): """Start the SSL/TLS handshake.""" > self._sslobj.do_handshake() E ssl.SSLZeroReturnError: TLS/SSL connection has been closed (EOF) (_ssl.c:997) /usr/lib/python3.10/ssl.py:975: SSLZeroReturnError The above exception was the direct cause of the following exception: client_ctx = async def test_https_mode_eof_before_handshake(client_ctx): client, server = ssl_memory_stream_pair( client_ctx, server_kwargs={"https_compatible": True}, client_kwargs={"https_compatible": True}, ) async def server_expect_clean_eof(): assert await server.receive_some(10) == b"" > async with _core.open_nursery() as nursery: trio/tests/test_ssl.py:1125: _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ trio/_core/_run.py:815: in __aexit__ raise combined_error_from_nursery trio/tests/test_ssl.py:1123: in server_expect_clean_eof assert await server.receive_some(10) == b"" trio/_ssl.py:656: in receive_some await self._handshook.ensure(checkpoint=False) trio/_ssl.py:211: in ensure await self._afn(*self._args) trio/_ssl.py:600: in _do_handshake await self._retry(self._ssl_object.do_handshake, is_handshake=True) _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ self = fn = > ignore_want_read = False, is_handshake = True, args = (), yielded = True async def _retry(self, fn, *args, ignore_want_read=False, is_handshake=False): await trio.lowlevel.checkpoint_if_cancelled() yielded = False finished = False while not finished: # WARNING: this code needs to be very careful with when it # calls 'await'! There might be multiple tasks calling this # function at the same time trying to do different operations, # so we need to be careful to: # # 1) interact with the SSLObject, then # 2) await on exactly one thing that lets us make forward # progress, then # 3) loop or exit # # In particular we don't want to yield while interacting with # the SSLObject (because it's shared state, so someone else # might come in and mess with it while we're suspended), and # we don't want to yield *before* starting the operation that # will help us make progress, because then someone else might # come in and leapfrog us. # Call the SSLObject method, and get its result. # # NB: despite what the docs say, SSLWantWriteError can't # happen – "Writes to memory BIOs will always succeed if # memory is available: that is their size can grow # indefinitely." # https://wiki.openssl.org/index.php/Manual:BIO_s_mem(3) want_read = False ret = None try: ret = fn(*args) except _stdlib_ssl.SSLWantReadError: want_read = True except (_stdlib_ssl.SSLError, _stdlib_ssl.CertificateError) as exc: self._state = _State.BROKEN > raise trio.BrokenResourceError from exc E trio.BrokenResourceError trio/_ssl.py:463: BrokenResourceError =========================== short test summary info ============================ FAILED trio/_core/tests/test_guest_mode.py::test_warn_set_wakeup_fd_overwrite FAILED trio/tests/test_ssl.py::test_ssl_bad_shutdown[tls13] - Failed: DID NOT... FAILED trio/tests/test_ssl.py::test_ssl_https_compatibility_disagreement[tls13] FAILED trio/tests/test_ssl.py::test_https_mode_eof_before_handshake[tls13] - ... FAILED trio/tests/test_ssl.py::test_ssl_bad_shutdown[tls12] - Failed: DID NOT... FAILED trio/tests/test_ssl.py::test_ssl_https_compatibility_disagreement[tls12] FAILED trio/tests/test_ssl.py::test_https_mode_eof_before_handshake[tls12] - ... ========== 7 failed, 568 passed, 21 skipped, 14 deselected in 38.82s =========== >>> ERROR: py3-trio: check failed >>> py3-trio: Uninstalling dependencies... (1/35) Purging .makedepends-py3-trio (20221026.225000) (2/35) Purging py3-outcome (1.1.0-r3) (3/35) Purging py3-async_generator (1.10-r3) (4/35) Purging py3-sniffio (1.3.0-r0) (5/35) Purging py3-curio (1.5-r2) (6/35) Purging py3-sortedcontainers (2.4.0-r1) (7/35) Purging py3-setuptools (65.5.0-r0) (8/35) Purging py3-astor (0.8.1-r2) (9/35) Purging py3-pytest (7.1.3-r1) (10/35) Purging py3-iniconfig (1.1.1-r3) (11/35) Purging py3-packaging (21.3-r2) (12/35) Purging py3-parsing (3.0.9-r0) (13/35) Purging py3-pluggy (1.0.0-r1) (14/35) Purging py3-py (1.11.0-r0) (15/35) Purging py3-tomli (2.0.1-r1) (16/35) Purging py3-trustme (0.9.0-r1) (17/35) Purging py3-idna (3.4-r2) (18/35) Purging py3-openssl (22.1.0-r0) (19/35) Purging py3-service_identity (21.1.0-r2) (20/35) Purging py3-six (1.16.0-r3) (21/35) Purging py3-asn1-modules (0.2.8-r2) (22/35) Purging py3-asn1 (0.4.8-r2) (23/35) Purging py3-attrs (22.1.0-r0) (24/35) Purging py3-characteristic (14.3.0-r8) (25/35) Purging py3-cryptography (38.0.2-r0) (26/35) Purging py3-cffi (1.15.1-r0) (27/35) Purging py3-cparser (2.21-r0) (28/35) Purging python3 (3.10.8-r3) (29/35) Purging libbz2 (1.0.8-r3) (30/35) Purging libffi (3.4.3-r0) (31/35) Purging gdbm (1.23-r0) (32/35) Purging xz-libs (5.2.7-r0) (33/35) Purging mpdecimal (2.5.1-r1) (34/35) Purging readline (8.2.0-r0) (35/35) Purging sqlite-libs (3.39.4-r0) Executing busybox-1.35.0-r27.trigger OK: 220 MiB in 93 packages