>>> py3-async-lru: Building community/py3-async-lru 2.2.0-r0 (using abuild 3.16.0-r0) started Mon, 23 Feb 2026 19:51:25 +0000 >>> py3-async-lru: Validating /home/buildozer/aports/community/py3-async-lru/APKBUILD... >>> py3-async-lru: Analyzing dependencies... >>> py3-async-lru: Installing for build: build-base py3-gpep517 py3-setuptools py3-wheel py3-pytest-asyncio py3-pytest-cov py3-pytest-timeout ( 1/42) Installing libbz2 (1.0.8-r6) ( 2/42) Installing libffi (3.5.2-r0) ( 3/42) Installing gdbm (1.26-r0) ( 4/42) Installing xz-libs (5.8.2-r0) ( 5/42) Installing mpdecimal (4.0.1-r0) ( 6/42) Installing libpanelw (6.6_p20251231-r0) ( 7/42) Installing sqlite-libs (3.51.2-r1) ( 8/42) Installing python3 (3.12.12-r0) ( 9/42) Installing python3-pycache-pyc0 (3.12.12-r0) (10/42) Installing pyc (3.12.12-r0) (11/42) Installing py3-installer-pyc (0.7.0-r2) (12/42) Installing py3-gpep517-pyc (19-r1) (13/42) Installing python3-pyc (3.12.12-r0) (14/42) Installing py3-installer (0.7.0-r2) (15/42) Installing py3-gpep517 (19-r1) (16/42) Installing py3-parsing (3.3.2-r0) (17/42) Installing py3-parsing-pyc (3.3.2-r0) (18/42) Installing py3-packaging (25.0-r0) (19/42) Installing py3-packaging-pyc (25.0-r0) (20/42) Installing py3-setuptools (82.0.0-r0) (21/42) Installing py3-setuptools-pyc (82.0.0-r0) (22/42) Installing py3-wheel (0.46.1-r0) (23/42) Installing py3-wheel-pyc (0.46.1-r0) (24/42) Installing py3-iniconfig (2.3.0-r0) (25/42) Installing py3-iniconfig-pyc (2.3.0-r0) (26/42) Installing py3-pluggy (1.6.0-r0) (27/42) Installing py3-pluggy-pyc (1.6.0-r0) (28/42) Installing py3-py (1.11.0-r4) (29/42) Installing py3-py-pyc (1.11.0-r4) (30/42) Installing py3-pygments (2.19.2-r0) (31/42) Installing py3-pygments-pyc (2.19.2-r0) (32/42) Installing py3-pytest (9.0.2-r0) (33/42) Installing py3-pytest-pyc (9.0.2-r0) (34/42) Installing py3-pytest-asyncio (0.25.0-r1) (35/42) Installing py3-pytest-asyncio-pyc (0.25.0-r1) (36/42) Installing py3-coverage (7.13.4-r0) (37/42) Installing py3-coverage-pyc (7.13.4-r0) (38/42) Installing py3-pytest-cov (5.0.0-r1) (39/42) Installing py3-pytest-cov-pyc (5.0.0-r1) (40/42) Installing py3-pytest-timeout (2.4.0-r0) (41/42) Installing py3-pytest-timeout-pyc (2.4.0-r0) (42/42) Installing .makedepends-py3-async-lru (20260223.195128) Executing busybox-1.37.0-r31.trigger OK: 419.6 MiB in 145 packages >>> py3-async-lru: Cleaning up srcdir >>> py3-async-lru: Cleaning up pkgdir >>> py3-async-lru: Cleaning up tmpdir >>> py3-async-lru: Fetching https://distfiles.alpinelinux.org/distfiles/edge/async_lru-2.2.0.tar.gz Connecting to distfiles.alpinelinux.org (172.105.82.32:443) saving to '/var/cache/distfiles/edge/async_lru-2.2.0.tar.gz.part' async_lru-2.2.0.tar. 100% |********************************| 14654 0:00:00 ETA '/var/cache/distfiles/edge/async_lru-2.2.0.tar.gz.part' saved /var/cache/distfiles/edge/async_lru-2.2.0.tar.gz: OK >>> py3-async-lru: Fetching https://distfiles.alpinelinux.org/distfiles/edge/async_lru-2.2.0.tar.gz /var/cache/distfiles/edge/async_lru-2.2.0.tar.gz: OK >>> py3-async-lru: Unpacking /var/cache/distfiles/edge/async_lru-2.2.0.tar.gz... 2026-02-23 19:52:03,257 gpep517 INFO Building wheel via backend setuptools.build_meta:__legacy__ /usr/lib/python3.12/site-packages/setuptools/dist.py:765: SetuptoolsDeprecationWarning: License classifiers are deprecated. !! ******************************************************************************** Please consider removing the following classifiers in favor of a SPDX license expression: License :: OSI Approved :: MIT License See https://packaging.python.org/en/latest/guides/writing-pyproject-toml/#license for details. ******************************************************************************** !! self._finalize_license_expression() 2026-02-23 19:52:03,410 root INFO running bdist_wheel 2026-02-23 19:52:03,534 root INFO running build 2026-02-23 19:52:03,535 root INFO running build_py 2026-02-23 19:52:03,561 root INFO creating build/lib/async_lru 2026-02-23 19:52:03,562 root INFO copying async_lru/__init__.py -> build/lib/async_lru 2026-02-23 19:52:03,566 root INFO copying async_lru/py.typed -> build/lib/async_lru 2026-02-23 19:52:03,608 root INFO installing to build/bdist.linux-riscv64/wheel 2026-02-23 19:52:03,608 root INFO running install 2026-02-23 19:52:03,672 root INFO running install_lib 2026-02-23 19:52:03,691 root INFO creating build/bdist.linux-riscv64/wheel 2026-02-23 19:52:03,693 root INFO creating build/bdist.linux-riscv64/wheel/async_lru 2026-02-23 19:52:03,694 root INFO copying build/lib/async_lru/__init__.py -> build/bdist.linux-riscv64/wheel/./async_lru 2026-02-23 19:52:03,695 root INFO copying build/lib/async_lru/py.typed -> build/bdist.linux-riscv64/wheel/./async_lru 2026-02-23 19:52:03,696 root INFO running install_egg_info 2026-02-23 19:52:03,718 root INFO running egg_info 2026-02-23 19:52:03,735 root INFO writing async_lru.egg-info/PKG-INFO 2026-02-23 19:52:03,739 root INFO writing dependency_links to async_lru.egg-info/dependency_links.txt 2026-02-23 19:52:03,742 root INFO writing requirements to async_lru.egg-info/requires.txt 2026-02-23 19:52:03,743 root INFO writing top-level names to async_lru.egg-info/top_level.txt 2026-02-23 19:52:03,764 root INFO reading manifest file 'async_lru.egg-info/SOURCES.txt' 2026-02-23 19:52:03,768 root INFO reading manifest template 'MANIFEST.in' 2026-02-23 19:52:03,772 root WARNING warning: no previously-included files matching '__pycache__' found under directory '*' 2026-02-23 19:52:03,774 root WARNING warning: no previously-included files matching '*.py[co]' found under directory '*' 2026-02-23 19:52:03,774 root INFO adding license file 'LICENSE' 2026-02-23 19:52:03,780 root INFO writing manifest file 'async_lru.egg-info/SOURCES.txt' 2026-02-23 19:52:03,781 root INFO Copying async_lru.egg-info to build/bdist.linux-riscv64/wheel/./async_lru-2.2.0-py3.12.egg-info 2026-02-23 19:52:03,786 root INFO running install_scripts 2026-02-23 19:52:03,791 root INFO creating build/bdist.linux-riscv64/wheel/async_lru-2.2.0.dist-info/WHEEL 2026-02-23 19:52:03,794 wheel INFO creating '/home/buildozer/aports/community/py3-async-lru/src/async_lru-2.2.0/.dist/.tmp-9ps3pfo9/async_lru-2.2.0-py3-none-any.whl' and adding 'build/bdist.linux-riscv64/wheel' to it 2026-02-23 19:52:03,795 wheel INFO adding 'async_lru/__init__.py' 2026-02-23 19:52:03,797 wheel INFO adding 'async_lru/py.typed' 2026-02-23 19:52:03,799 wheel INFO adding 'async_lru-2.2.0.dist-info/licenses/LICENSE' 2026-02-23 19:52:03,800 wheel INFO adding 'async_lru-2.2.0.dist-info/METADATA' 2026-02-23 19:52:03,801 wheel INFO adding 'async_lru-2.2.0.dist-info/WHEEL' 2026-02-23 19:52:03,802 wheel INFO adding 'async_lru-2.2.0.dist-info/top_level.txt' 2026-02-23 19:52:03,803 wheel INFO adding 'async_lru-2.2.0.dist-info/RECORD' 2026-02-23 19:52:03,804 root INFO removing build/bdist.linux-riscv64/wheel 2026-02-23 19:52:03,807 gpep517 INFO The backend produced .dist/async_lru-2.2.0-py3-none-any.whl async_lru-2.2.0-py3-none-any.whl ============================= test session starts ============================== platform linux -- Python 3.12.12, pytest-9.0.2, pluggy-1.6.0 -- /home/buildozer/aports/community/py3-async-lru/src/async_lru-2.2.0/.testenv/bin/python3 cachedir: .pytest_cache rootdir: /home/buildozer/aports/community/py3-async-lru/src/async_lru-2.2.0 configfile: setup.cfg testpaths: tests/ plugins: asyncio-0.25.0, cov-5.0.0, timeout-2.4.0 asyncio: mode=Mode.AUTO, asyncio_default_fixture_loop_scope=None timeout: 15.0s timeout method: signal timeout func_only: False collecting ... collected 59 items tests/test_basic.py::test_alru_cache_not_callable PASSED tests/test_basic.py::test_alru_cache_not_coroutine PASSED tests/test_basic.py::test_alru_cache_deco PASSED tests/test_basic.py::test_alru_cache_deco_called PASSED tests/test_basic.py::test_alru_cache_fn_called PASSED tests/test_basic.py::test_alru_cache_partial PASSED tests/test_basic.py::test_alru_cache_await_same_result_async PASSED tests/test_basic.py::test_alru_cache_await_same_result_coroutine PASSED tests/test_basic.py::test_alru_cache_dict_not_shared PASSED tests/test_basic.py::test_alru_cache_parameters PASSED tests/test_basic.py::test_alru_cache_method PASSED tests/test_basic.py::test_alru_cache_classmethod PASSED tests/test_basic.py::test_invalidate_cache_for_method PASSED tests/test_cache_clear.py::test_cache_clear PASSED tests/test_cache_clear.py::test_cache_clear_pending_task PASSED tests/test_cache_clear.py::test_cache_clear_ttl_callback PASSED tests/test_cache_info.py::test_cache_info PASSED tests/test_cache_invalidate.py::test_cache_invalidate PASSED tests/test_cache_invalidate.py::test_cache_invalidate_multiple_args PASSED tests/test_cache_invalidate.py::test_cache_invalidate_multiple_args_different_order PASSED tests/test_cancel.py::test_cancel[0] PASSED tests/test_cancel.py::test_cancel[1] PASSED tests/test_cancel.py::test_cancel[2] PASSED tests/test_cancel.py::test_cancel[3] PASSED tests/test_cancel.py::test_cancel_single_waiter_triggers_handle_cancelled_error PASSED tests/test_close.py::test_cache_close PASSED tests/test_exception.py::test_alru_exception PASSED tests/test_exception.py::test_alru_exception_reference_cleanup PASSED tests/test_internals.py::test_done_callback_cancelled PASSED tests/test_internals.py::test_done_callback_exception PASSED tests/test_internals.py::test_done_callback_exception_logs PASSED tests/test_internals.py::test_cache_invalidate_typed PASSED tests/test_internals.py::test_cache_invalidate_not_typed PASSED tests/test_internals.py::test_cache_clear PASSED tests/test_internals.py::test_cache_info PASSED tests/test_internals.py::test_cache_hit PASSED tests/test_internals.py::test_cache_miss PASSED tests/test_internals.py::test_forbid_call_closed PASSED tests/test_partialmethod.py::test_partialmethod_basic PASSED tests/test_partialmethod.py::test_partialmethod_partial PASSED tests/test_readme_examples.py::test_readme_example_per_thread_caching PASSED tests/test_size.py::test_alru_cache_removing_lru_keys PASSED tests/test_size.py::test_alru_cache_removing_lru_keys_with_full_displacement PASSED tests/test_size.py::test_alru_cache_none_max_size PASSED tests/test_size.py::test_alru_cache_zero_max_size PASSED tests/test_thread_safety.py::test_cross_loop_access_raises_error PASSED tests/test_thread_safety.py::test_invalid_key_does_not_bind_loop PASSED tests/test_thread_safety.py::test_same_loop_access_works PASSED tests/test_thread_safety.py::test_cross_loop_cache_close_raises_error PASSED tests/test_thread_safety.py::test_sync_methods_work_without_loop_check PASSED tests/test_thread_safety.py::test_concurrent_same_loop_works PASSED tests/test_ttl.py::test_ttl_infinite_cache PASSED tests/test_ttl.py::test_ttl_limited_cache PASSED tests/test_ttl.py::test_ttl_with_explicit_invalidation PASSED tests/test_ttl.py::test_ttl_concurrent PASSED tests/test_ttl.py::test_ttl_with_jitter_basic PASSED tests/test_ttl.py::test_ttl_with_jitter_zero PASSED tests/test_ttl.py::test_jitter_without_ttl_raises_error PASSED tests/test_ttl.py::test_jitter_negative_raises_error PASSED ---------- coverage: platform linux, python 3.12.12-final-0 ---------- Name Stmts Miss Branch BrPart Cover ------------------------------------------------------------------ async_lru/__init__.py 235 22 62 8 90% tests/conftest.py 10 0 0 0 100% tests/test_basic.py 138 1 12 6 95% tests/test_cache_clear.py 39 0 0 0 100% tests/test_cache_info.py 26 0 0 0 100% tests/test_cache_invalidate.py 61 0 8 0 100% tests/test_cancel.py 32 0 6 0 100% tests/test_close.py 25 1 0 0 96% tests/test_exception.py 32 0 2 0 100% tests/test_internals.py 133 0 6 0 100% tests/test_partialmethod.py 28 0 0 0 100% tests/test_readme_examples.py 36 0 8 0 100% tests/test_size.py 47 0 8 0 100% tests/test_thread_safety.py 91 0 0 0 100% tests/test_ttl.py 75 0 0 0 100% ------------------------------------------------------------------ TOTAL 1008 24 112 14 97% Coverage HTML written to dir htmlcov ============================== 59 passed in 9.79s ============================== >>> py3-async-lru: Entering fakeroot... >>> py3-async-lru-pyc*: Running split function pyc... 'usr/lib/python3.12/site-packages/async_lru/__pycache__' -> '/home/buildozer/aports/community/py3-async-lru/pkg/py3-async-lru-pyc/usr/lib/python3.12/site-packages/async_lru/__pycache__' >>> py3-async-lru-pyc*: Preparing subpackage py3-async-lru-pyc... >>> py3-async-lru-pyc*: Running postcheck for py3-async-lru-pyc >>> py3-async-lru*: Running postcheck for py3-async-lru >>> py3-async-lru*: Preparing package py3-async-lru... >>> py3-async-lru-pyc*: Tracing dependencies... python3~3.12 >>> py3-async-lru-pyc*: Package size: 18.0 KB >>> py3-async-lru-pyc*: Compressing data... >>> py3-async-lru-pyc*: Create checksum... >>> py3-async-lru-pyc*: Create py3-async-lru-pyc-2.2.0-r0.apk >>> py3-async-lru*: Tracing dependencies... python3~3.12 >>> py3-async-lru*: Package size: 20.7 KB >>> py3-async-lru*: Compressing data... >>> py3-async-lru*: Create checksum... >>> py3-async-lru*: Create py3-async-lru-2.2.0-r0.apk >>> py3-async-lru: Build complete at Mon, 23 Feb 2026 19:52:49 +0000 elapsed time 0h 1m 24s >>> py3-async-lru: Cleaning up srcdir >>> py3-async-lru: Cleaning up pkgdir >>> py3-async-lru: Cleaning up tmpdir >>> py3-async-lru: Uninstalling dependencies... ( 1/42) Purging .makedepends-py3-async-lru (20260223.195128) ( 2/42) Purging py3-gpep517-pyc (19-r1) ( 3/42) Purging py3-gpep517 (19-r1) ( 4/42) Purging py3-installer-pyc (0.7.0-r2) ( 5/42) Purging py3-installer (0.7.0-r2) ( 6/42) Purging py3-setuptools-pyc (82.0.0-r0) ( 7/42) Purging py3-setuptools (82.0.0-r0) ( 8/42) Purging py3-wheel-pyc (0.46.1-r0) ( 9/42) Purging py3-wheel (0.46.1-r0) (10/42) Purging py3-pytest-asyncio-pyc (0.25.0-r1) (11/42) Purging py3-pytest-asyncio (0.25.0-r1) (12/42) Purging py3-pytest-cov-pyc (5.0.0-r1) (13/42) Purging py3-pytest-cov (5.0.0-r1) (14/42) Purging py3-coverage-pyc (7.13.4-r0) (15/42) Purging py3-coverage (7.13.4-r0) (16/42) Purging py3-pytest-timeout-pyc (2.4.0-r0) (17/42) Purging py3-pytest-timeout (2.4.0-r0) (18/42) Purging py3-pytest-pyc (9.0.2-r0) (19/42) Purging py3-pytest (9.0.2-r0) (20/42) Purging py3-iniconfig-pyc (2.3.0-r0) (21/42) Purging py3-iniconfig (2.3.0-r0) (22/42) Purging py3-packaging-pyc (25.0-r0) (23/42) Purging py3-packaging (25.0-r0) (24/42) Purging py3-parsing-pyc (3.3.2-r0) (25/42) Purging py3-parsing (3.3.2-r0) (26/42) Purging py3-pluggy-pyc (1.6.0-r0) (27/42) Purging py3-pluggy (1.6.0-r0) (28/42) Purging py3-py-pyc (1.11.0-r4) (29/42) Purging py3-py (1.11.0-r4) (30/42) Purging py3-pygments-pyc (2.19.2-r0) (31/42) Purging py3-pygments (2.19.2-r0) (32/42) Purging python3-pyc (3.12.12-r0) (33/42) Purging python3-pycache-pyc0 (3.12.12-r0) (34/42) Purging pyc (3.12.12-r0) (35/42) Purging python3 (3.12.12-r0) (36/42) Purging gdbm (1.26-r0) (37/42) Purging libbz2 (1.0.8-r6) (38/42) Purging libffi (3.5.2-r0) (39/42) Purging libpanelw (6.6_p20251231-r0) (40/42) Purging mpdecimal (4.0.1-r0) (41/42) Purging sqlite-libs (3.51.2-r1) (42/42) Purging xz-libs (5.8.2-r0) Executing busybox-1.37.0-r31.trigger OK: 362.1 MiB in 103 packages >>> py3-async-lru: Updating the community/riscv64 repository index... >>> py3-async-lru: Signing the index...