>>> py3-proto-plus: Building community/py3-proto-plus 1.26.1-r0 (using abuild 3.15.0_rc3-r1) started Thu, 01 May 2025 01:57:11 +0000 >>> py3-proto-plus: Validating /home/buildozer/aports/community/py3-proto-plus/APKBUILD... >>> py3-proto-plus: Analyzing dependencies... >>> py3-proto-plus: Installing for build: build-base python3 py3-protobuf py3-gpep517 py3-setuptools py3-wheel py3-googleapis-common-protos py3-pytest py3-tz (1/37) Installing libffi (3.4.8-r0) (2/37) Installing gdbm (1.24-r0) (3/37) Installing mpdecimal (4.0.0-r0) (4/37) Installing libpanelw (6.5_p20250412-r0) (5/37) Installing sqlite-libs (3.49.1-r1) (6/37) Installing python3 (3.12.10-r0) (7/37) Installing python3-pycache-pyc0 (3.12.10-r0) (8/37) Installing pyc (3.12.10-r0) (9/37) Installing python3-pyc (3.12.10-r0) (10/37) Installing tzdata (2025b-r0) (11/37) Installing py3-protobuf (4.25.6-r0) (12/37) Installing py3-protobuf-pyc (4.25.6-r0) (13/37) Installing py3-installer (0.7.0-r2) (14/37) Installing py3-installer-pyc (0.7.0-r2) (15/37) Installing py3-gpep517 (16-r0) (16/37) Installing py3-gpep517-pyc (16-r0) (17/37) Installing py3-parsing (3.2.0-r0) (18/37) Installing py3-parsing-pyc (3.2.0-r0) (19/37) Installing py3-packaging (25.0-r0) (20/37) Installing py3-packaging-pyc (25.0-r0) (21/37) Installing py3-setuptools (77.0.3-r0) (22/37) Installing py3-setuptools-pyc (77.0.3-r0) (23/37) Installing py3-wheel (0.43.0-r0) (24/37) Installing py3-wheel-pyc (0.43.0-r0) (25/37) Installing py3-googleapis-common-protos (1.70.0-r0) (26/37) Installing py3-googleapis-common-protos-pyc (1.70.0-r0) (27/37) Installing py3-iniconfig (2.1.0-r0) (28/37) Installing py3-iniconfig-pyc (2.1.0-r0) (29/37) Installing py3-pluggy (1.5.0-r0) (30/37) Installing py3-pluggy-pyc (1.5.0-r0) (31/37) Installing py3-py (1.11.0-r4) (32/37) Installing py3-py-pyc (1.11.0-r4) (33/37) Installing py3-pytest (8.3.5-r0) (34/37) Installing py3-pytest-pyc (8.3.5-r0) (35/37) Installing py3-tz (2025.2-r0) (36/37) Installing py3-tz-pyc (2025.2-r0) (37/37) Installing .makedepends-py3-proto-plus (20250501.015714) Executing busybox-1.37.0-r16.trigger OK: 397 MiB in 147 packages >>> py3-proto-plus: Cleaning up srcdir >>> py3-proto-plus: Cleaning up pkgdir >>> py3-proto-plus: Cleaning up tmpdir >>> py3-proto-plus: Fetching https://distfiles.alpinelinux.org/distfiles/edge/proto_plus-1.26.1.tar.gz % Total % Received % Xferd Average Speed Time Time Time Current Dload Upload Total Spent Left Speed 0 0 0 0 0 0 0 0 --:--:-- --:--:-- --:--:-- 0 0 0 0 0 0 0 0 0 --:--:-- --:--:-- --:--:-- 0 curl: (22) The requested URL returned error: 404 >>> py3-proto-plus: Fetching https://files.pythonhosted.org/packages/source/p/proto_plus/proto_plus-1.26.1.tar.gz % Total % Received % Xferd Average Speed Time Time Time Current Dload Upload Total Spent Left Speed 0 0 0 0 0 0 0 0 --:--:-- --:--:-- --:--:-- 0 0 0 0 0 0 0 0 0 --:--:-- --:--:-- --:--:-- 0 100 56142 100 56142 0 0 385k 0 --:--:-- --:--:-- --:--:-- 385k >>> py3-proto-plus: Fetching https://distfiles.alpinelinux.org/distfiles/edge/proto_plus-1.26.1.tar.gz >>> py3-proto-plus: Checking sha512sums... proto_plus-1.26.1.tar.gz: OK >>> py3-proto-plus: Unpacking /var/cache/distfiles/edge/proto_plus-1.26.1.tar.gz... 2025-05-01 01:57:18,807 gpep517 INFO Building wheel via backend setuptools.build_meta /usr/lib/python3.12/site-packages/setuptools/config/_apply_pyprojecttoml.py:82: SetuptoolsDeprecationWarning: `project.license` as a TOML table is deprecated !! ******************************************************************************** Please use a simple string containing a SPDX expression for `project.license`. You can also use `project.license-files`. By 2026-Feb-18, you need to update your project and remove deprecated calls or your builds will no longer be supported. See https://packaging.python.org/en/latest/guides/writing-pyproject-toml/#license for details. ******************************************************************************** !! corresp(dist, value, root_dir) /usr/lib/python3.12/site-packages/setuptools/config/_apply_pyprojecttoml.py:61: SetuptoolsDeprecationWarning: License classifiers are deprecated. !! ******************************************************************************** Please consider removing the following classifiers in favor of a SPDX license expression: License :: OSI Approved :: Apache Software License See https://packaging.python.org/en/latest/guides/writing-pyproject-toml/#license for details. ******************************************************************************** !! dist._finalize_license_expression() /usr/lib/python3.12/site-packages/setuptools/dist.py:760: SetuptoolsDeprecationWarning: License classifiers are deprecated. !! ******************************************************************************** Please consider removing the following classifiers in favor of a SPDX license expression: License :: OSI Approved :: Apache Software License See https://packaging.python.org/en/latest/guides/writing-pyproject-toml/#license for details. ******************************************************************************** !! self._finalize_license_expression() 2025-05-01 01:57:19,210 root INFO running bdist_wheel 2025-05-01 01:57:19,293 root INFO running build 2025-05-01 01:57:19,294 root INFO running build_py 2025-05-01 01:57:19,312 root INFO creating build/lib/proto 2025-05-01 01:57:19,314 root INFO copying proto/primitives.py -> build/lib/proto 2025-05-01 01:57:19,316 root INFO copying proto/__init__.py -> build/lib/proto 2025-05-01 01:57:19,318 root INFO copying proto/fields.py -> build/lib/proto 2025-05-01 01:57:19,319 root INFO copying proto/utils.py -> build/lib/proto 2025-05-01 01:57:19,321 root INFO copying proto/version.py -> build/lib/proto 2025-05-01 01:57:19,322 root INFO copying proto/modules.py -> build/lib/proto 2025-05-01 01:57:19,324 root INFO copying proto/_package_info.py -> build/lib/proto 2025-05-01 01:57:19,325 root INFO copying proto/message.py -> build/lib/proto 2025-05-01 01:57:19,327 root INFO copying proto/_file_info.py -> build/lib/proto 2025-05-01 01:57:19,328 root INFO copying proto/enums.py -> build/lib/proto 2025-05-01 01:57:19,330 root INFO copying proto/datetime_helpers.py -> build/lib/proto 2025-05-01 01:57:19,332 root INFO creating build/lib/proto/marshal 2025-05-01 01:57:19,333 root INFO copying proto/marshal/marshal.py -> build/lib/proto/marshal 2025-05-01 01:57:19,334 root INFO copying proto/marshal/__init__.py -> build/lib/proto/marshal 2025-05-01 01:57:19,336 root INFO copying proto/marshal/compat.py -> build/lib/proto/marshal 2025-05-01 01:57:19,338 root INFO creating build/lib/proto/marshal/rules 2025-05-01 01:57:19,339 root INFO copying proto/marshal/rules/__init__.py -> build/lib/proto/marshal/rules 2025-05-01 01:57:19,340 root INFO copying proto/marshal/rules/stringy_numbers.py -> build/lib/proto/marshal/rules 2025-05-01 01:57:19,341 root INFO copying proto/marshal/rules/field_mask.py -> build/lib/proto/marshal/rules 2025-05-01 01:57:19,343 root INFO copying proto/marshal/rules/message.py -> build/lib/proto/marshal/rules 2025-05-01 01:57:19,344 root INFO copying proto/marshal/rules/struct.py -> build/lib/proto/marshal/rules 2025-05-01 01:57:19,346 root INFO copying proto/marshal/rules/enums.py -> build/lib/proto/marshal/rules 2025-05-01 01:57:19,347 root INFO copying proto/marshal/rules/wrappers.py -> build/lib/proto/marshal/rules 2025-05-01 01:57:19,348 root INFO copying proto/marshal/rules/dates.py -> build/lib/proto/marshal/rules 2025-05-01 01:57:19,350 root INFO copying proto/marshal/rules/bytes.py -> build/lib/proto/marshal/rules 2025-05-01 01:57:19,351 root INFO creating build/lib/proto/marshal/collections 2025-05-01 01:57:19,352 root INFO copying proto/marshal/collections/maps.py -> build/lib/proto/marshal/collections 2025-05-01 01:57:19,354 root INFO copying proto/marshal/collections/__init__.py -> build/lib/proto/marshal/collections 2025-05-01 01:57:19,355 root INFO copying proto/marshal/collections/repeated.py -> build/lib/proto/marshal/collections 2025-05-01 01:57:19,356 root INFO running egg_info 2025-05-01 01:57:19,373 root INFO writing proto_plus.egg-info/PKG-INFO 2025-05-01 01:57:19,377 root INFO writing dependency_links to proto_plus.egg-info/dependency_links.txt 2025-05-01 01:57:19,380 root INFO writing requirements to proto_plus.egg-info/requires.txt 2025-05-01 01:57:19,381 root INFO writing top-level names to proto_plus.egg-info/top_level.txt 2025-05-01 01:57:19,408 root INFO reading manifest file 'proto_plus.egg-info/SOURCES.txt' 2025-05-01 01:57:19,417 root INFO reading manifest template 'MANIFEST.in' 2025-05-01 01:57:19,426 root WARNING warning: no previously-included files matching '*.py[co]' found anywhere in distribution 2025-05-01 01:57:19,427 root WARNING warning: no previously-included files matching '__pycache__' found anywhere in distribution 2025-05-01 01:57:19,427 root INFO adding license file 'LICENSE' 2025-05-01 01:57:19,437 root INFO writing manifest file 'proto_plus.egg-info/SOURCES.txt' 2025-05-01 01:57:19,478 root INFO installing to build/bdist.linux-riscv64/wheel 2025-05-01 01:57:19,479 root INFO running install 2025-05-01 01:57:19,542 root INFO running install_lib 2025-05-01 01:57:19,559 root INFO creating build/bdist.linux-riscv64/wheel 2025-05-01 01:57:19,560 root INFO creating build/bdist.linux-riscv64/wheel/proto 2025-05-01 01:57:19,561 root INFO copying build/lib/proto/primitives.py -> build/bdist.linux-riscv64/wheel/./proto 2025-05-01 01:57:19,562 root INFO copying build/lib/proto/__init__.py -> build/bdist.linux-riscv64/wheel/./proto 2025-05-01 01:57:19,563 root INFO copying build/lib/proto/fields.py -> build/bdist.linux-riscv64/wheel/./proto 2025-05-01 01:57:19,565 root INFO copying build/lib/proto/utils.py -> build/bdist.linux-riscv64/wheel/./proto 2025-05-01 01:57:19,566 root INFO copying build/lib/proto/version.py -> build/bdist.linux-riscv64/wheel/./proto 2025-05-01 01:57:19,567 root INFO copying build/lib/proto/modules.py -> build/bdist.linux-riscv64/wheel/./proto 2025-05-01 01:57:19,568 root INFO copying build/lib/proto/_package_info.py -> build/bdist.linux-riscv64/wheel/./proto 2025-05-01 01:57:19,569 root INFO copying build/lib/proto/message.py -> build/bdist.linux-riscv64/wheel/./proto 2025-05-01 01:57:19,570 root INFO creating build/bdist.linux-riscv64/wheel/proto/marshal 2025-05-01 01:57:19,571 root INFO copying build/lib/proto/marshal/marshal.py -> build/bdist.linux-riscv64/wheel/./proto/marshal 2025-05-01 01:57:19,572 root INFO copying build/lib/proto/marshal/__init__.py -> build/bdist.linux-riscv64/wheel/./proto/marshal 2025-05-01 01:57:19,573 root INFO copying build/lib/proto/marshal/compat.py -> build/bdist.linux-riscv64/wheel/./proto/marshal 2025-05-01 01:57:19,575 root INFO creating build/bdist.linux-riscv64/wheel/proto/marshal/rules 2025-05-01 01:57:19,576 root INFO copying build/lib/proto/marshal/rules/__init__.py -> build/bdist.linux-riscv64/wheel/./proto/marshal/rules 2025-05-01 01:57:19,577 root INFO copying build/lib/proto/marshal/rules/stringy_numbers.py -> build/bdist.linux-riscv64/wheel/./proto/marshal/rules 2025-05-01 01:57:19,578 root INFO copying build/lib/proto/marshal/rules/field_mask.py -> build/bdist.linux-riscv64/wheel/./proto/marshal/rules 2025-05-01 01:57:19,579 root INFO copying build/lib/proto/marshal/rules/message.py -> build/bdist.linux-riscv64/wheel/./proto/marshal/rules 2025-05-01 01:57:19,580 root INFO copying build/lib/proto/marshal/rules/struct.py -> build/bdist.linux-riscv64/wheel/./proto/marshal/rules 2025-05-01 01:57:19,581 root INFO copying build/lib/proto/marshal/rules/enums.py -> build/bdist.linux-riscv64/wheel/./proto/marshal/rules 2025-05-01 01:57:19,582 root INFO copying build/lib/proto/marshal/rules/wrappers.py -> build/bdist.linux-riscv64/wheel/./proto/marshal/rules 2025-05-01 01:57:19,583 root INFO copying build/lib/proto/marshal/rules/dates.py -> build/bdist.linux-riscv64/wheel/./proto/marshal/rules 2025-05-01 01:57:19,584 root INFO copying build/lib/proto/marshal/rules/bytes.py -> build/bdist.linux-riscv64/wheel/./proto/marshal/rules 2025-05-01 01:57:19,585 root INFO creating build/bdist.linux-riscv64/wheel/proto/marshal/collections 2025-05-01 01:57:19,587 root INFO copying build/lib/proto/marshal/collections/maps.py -> build/bdist.linux-riscv64/wheel/./proto/marshal/collections 2025-05-01 01:57:19,588 root INFO copying build/lib/proto/marshal/collections/__init__.py -> build/bdist.linux-riscv64/wheel/./proto/marshal/collections 2025-05-01 01:57:19,589 root INFO copying build/lib/proto/marshal/collections/repeated.py -> build/bdist.linux-riscv64/wheel/./proto/marshal/collections 2025-05-01 01:57:19,590 root INFO copying build/lib/proto/_file_info.py -> build/bdist.linux-riscv64/wheel/./proto 2025-05-01 01:57:19,591 root INFO copying build/lib/proto/enums.py -> build/bdist.linux-riscv64/wheel/./proto 2025-05-01 01:57:19,592 root INFO copying build/lib/proto/datetime_helpers.py -> build/bdist.linux-riscv64/wheel/./proto 2025-05-01 01:57:19,593 root INFO running install_egg_info 2025-05-01 01:57:19,610 root INFO Copying proto_plus.egg-info to build/bdist.linux-riscv64/wheel/./proto_plus-1.26.1-py3.12.egg-info 2025-05-01 01:57:19,615 root INFO running install_scripts 2025-05-01 01:57:19,621 root INFO creating build/bdist.linux-riscv64/wheel/proto_plus-1.26.1.dist-info/WHEEL 2025-05-01 01:57:19,623 wheel INFO creating '/home/buildozer/aports/community/py3-proto-plus/src/proto_plus-1.26.1/.dist/.tmp-5if3vs05/proto_plus-1.26.1-py3-none-any.whl' and adding 'build/bdist.linux-riscv64/wheel' to it 2025-05-01 01:57:19,625 wheel INFO adding 'proto/__init__.py' 2025-05-01 01:57:19,627 wheel INFO adding 'proto/_file_info.py' 2025-05-01 01:57:19,628 wheel INFO adding 'proto/_package_info.py' 2025-05-01 01:57:19,629 wheel INFO adding 'proto/datetime_helpers.py' 2025-05-01 01:57:19,631 wheel INFO adding 'proto/enums.py' 2025-05-01 01:57:19,632 wheel INFO adding 'proto/fields.py' 2025-05-01 01:57:19,634 wheel INFO adding 'proto/message.py' 2025-05-01 01:57:19,636 wheel INFO adding 'proto/modules.py' 2025-05-01 01:57:19,637 wheel INFO adding 'proto/primitives.py' 2025-05-01 01:57:19,638 wheel INFO adding 'proto/utils.py' 2025-05-01 01:57:19,639 wheel INFO adding 'proto/version.py' 2025-05-01 01:57:19,640 wheel INFO adding 'proto/marshal/__init__.py' 2025-05-01 01:57:19,642 wheel INFO adding 'proto/marshal/compat.py' 2025-05-01 01:57:19,643 wheel INFO adding 'proto/marshal/marshal.py' 2025-05-01 01:57:19,644 wheel INFO adding 'proto/marshal/collections/__init__.py' 2025-05-01 01:57:19,645 wheel INFO adding 'proto/marshal/collections/maps.py' 2025-05-01 01:57:19,647 wheel INFO adding 'proto/marshal/collections/repeated.py' 2025-05-01 01:57:19,648 wheel INFO adding 'proto/marshal/rules/__init__.py' 2025-05-01 01:57:19,649 wheel INFO adding 'proto/marshal/rules/bytes.py' 2025-05-01 01:57:19,650 wheel INFO adding 'proto/marshal/rules/dates.py' 2025-05-01 01:57:19,652 wheel INFO adding 'proto/marshal/rules/enums.py' 2025-05-01 01:57:19,653 wheel INFO adding 'proto/marshal/rules/field_mask.py' 2025-05-01 01:57:19,654 wheel INFO adding 'proto/marshal/rules/message.py' 2025-05-01 01:57:19,655 wheel INFO adding 'proto/marshal/rules/stringy_numbers.py' 2025-05-01 01:57:19,656 wheel INFO adding 'proto/marshal/rules/struct.py' 2025-05-01 01:57:19,658 wheel INFO adding 'proto/marshal/rules/wrappers.py' 2025-05-01 01:57:19,660 wheel INFO adding 'proto_plus-1.26.1.dist-info/licenses/LICENSE' 2025-05-01 01:57:19,661 wheel INFO adding 'proto_plus-1.26.1.dist-info/METADATA' 2025-05-01 01:57:19,662 wheel INFO adding 'proto_plus-1.26.1.dist-info/WHEEL' 2025-05-01 01:57:19,663 wheel INFO adding 'proto_plus-1.26.1.dist-info/top_level.txt' 2025-05-01 01:57:19,665 wheel INFO adding 'proto_plus-1.26.1.dist-info/RECORD' 2025-05-01 01:57:19,666 root INFO removing build/bdist.linux-riscv64/wheel 2025-05-01 01:57:19,672 gpep517 INFO The backend produced .dist/proto_plus-1.26.1-py3-none-any.whl proto_plus-1.26.1-py3-none-any.whl ============================= test session starts ============================== platform linux -- Python 3.12.10, pytest-8.3.5, pluggy-1.5.0 -- /home/buildozer/aports/community/py3-proto-plus/src/proto_plus-1.26.1/.testenv/bin/python3 cachedir: .pytest_cache rootdir: /home/buildozer/aports/community/py3-proto-plus/src/proto_plus-1.26.1 configfile: pyproject.toml collecting ... collected 268 items tests/test_datetime_helpers.py::test_from_microseconds PASSED [ 0%] tests/test_datetime_helpers.py::test_to_rfc3339 PASSED [ 0%] tests/test_datetime_helpers.py::test_to_rfc3339_with_utc PASSED [ 1%] tests/test_datetime_helpers.py::test_to_rfc3339_with_non_utc PASSED [ 1%] tests/test_datetime_helpers.py::test_to_rfc3339_with_non_utc_ignore_zone PASSED [ 1%] tests/test_datetime_helpers.py::test_ctor_wo_nanos PASSED [ 2%] tests/test_datetime_helpers.py::test_ctor_w_nanos PASSED [ 2%] tests/test_datetime_helpers.py::test_ctor_w_micros_positional_and_nanos PASSED [ 2%] tests/test_datetime_helpers.py::test_ctor_w_micros_keyword_and_nanos PASSED [ 3%] tests/test_datetime_helpers.py::test_rfc3339_wo_nanos PASSED [ 3%] tests/test_datetime_helpers.py::test_rfc3339_wo_nanos_w_leading_zero PASSED [ 4%] tests/test_datetime_helpers.py::test_rfc3339_w_nanos PASSED [ 4%] tests/test_datetime_helpers.py::test_rfc3339_w_nanos_w_leading_zero PASSED [ 4%] tests/test_datetime_helpers.py::test_rfc3339_w_nanos_no_trailing_zeroes PASSED [ 5%] tests/test_datetime_helpers.py::test_rfc3339_w_nanos_w_leading_zero_and_no_trailing_zeros PASSED [ 5%] tests/test_datetime_helpers.py::test_from_rfc3339_w_invalid PASSED [ 5%] tests/test_datetime_helpers.py::test_from_rfc3339_wo_fraction PASSED [ 6%] tests/test_datetime_helpers.py::test_from_rfc3339_w_partial_precision PASSED [ 6%] tests/test_datetime_helpers.py::test_from_rfc3339_w_full_precision PASSED [ 7%] tests/test_datetime_helpers.py::test_from_rfc3339_test_nanoseconds[12345678-123456780] PASSED [ 7%] tests/test_datetime_helpers.py::test_from_rfc3339_test_nanoseconds[1234567-123456700] PASSED [ 7%] tests/test_datetime_helpers.py::test_from_rfc3339_test_nanoseconds[123456-123456000] PASSED [ 8%] tests/test_datetime_helpers.py::test_from_rfc3339_test_nanoseconds[12345-123450000] PASSED [ 8%] tests/test_datetime_helpers.py::test_from_rfc3339_test_nanoseconds[1234-123400000] PASSED [ 8%] tests/test_datetime_helpers.py::test_from_rfc3339_test_nanoseconds[123-123000000] PASSED [ 9%] tests/test_datetime_helpers.py::test_from_rfc3339_test_nanoseconds[12-120000000] PASSED [ 9%] tests/test_datetime_helpers.py::test_from_rfc3339_test_nanoseconds[1-100000000] PASSED [ 10%] tests/test_datetime_helpers.py::test_timestamp_pb_wo_nanos_naive PASSED [ 10%] tests/test_datetime_helpers.py::test_timestamp_pb_w_nanos PASSED [ 10%] tests/test_datetime_helpers.py::test_from_timestamp_pb_wo_nanos PASSED [ 11%] tests/test_datetime_helpers.py::test_replace PASSED [ 11%] tests/test_datetime_helpers.py::test_from_timestamp_pb_w_nanos PASSED [ 11%] tests/test_enum_total_ordering.py::test_total_ordering_w_same_enum_type PASSED [ 12%] tests/test_enum_total_ordering.py::test_total_ordering_w_other_enum_type PASSED [ 12%] tests/test_enum_total_ordering.py::test_total_ordering_w_int[-1] PASSED [ 13%] tests/test_enum_total_ordering.py::test_total_ordering_w_int[0] PASSED [ 13%] tests/test_enum_total_ordering.py::test_total_ordering_w_int[1] PASSED [ 13%] tests/test_enum_total_ordering.py::test_total_ordering_w_int[2] PASSED [ 14%] tests/test_enum_total_ordering.py::test_hashing PASSED [ 14%] tests/test_fields_bytes.py::test_bytes_init PASSED [ 14%] tests/test_fields_bytes.py::test_bytes_rmw PASSED [ 15%] tests/test_fields_bytes.py::test_bytes_del PASSED [ 15%] tests/test_fields_bytes.py::test_bytes_string_distinct PASSED [ 16%] tests/test_fields_bytes.py::test_bytes_to_dict_bidi PASSED [ 16%] tests/test_fields_composite.py::test_composite_init PASSED [ 16%] tests/test_fields_composite.py::test_composite_inner_rmw PASSED [ 17%] tests/test_fields_composite.py::test_composite_empty_inner_rmw PASSED [ 17%] tests/test_fields_composite.py::test_composite_outer_rmw PASSED [ 17%] tests/test_fields_composite.py::test_composite_dict_write PASSED [ 18%] tests/test_fields_composite.py::test_composite_del PASSED [ 18%] tests/test_fields_composite_string_ref.py::test_composite_forward_ref PASSED [ 19%] tests/test_fields_composite_string_ref.py::test_composite_forward_ref_with_package PASSED [ 19%] tests/test_fields_composite_string_ref.py::test_composite_backward_ref PASSED [ 19%] tests/test_fields_composite_string_ref.py::test_composite_multi_ref PASSED [ 20%] tests/test_fields_composite_string_ref.py::test_composite_self_ref PASSED [ 20%] tests/test_fields_enum.py::test_outer_enum_init PASSED [ 20%] tests/test_fields_enum.py::test_outer_enum_init_int PASSED [ 21%] tests/test_fields_enum.py::test_outer_enum_init_str PASSED [ 21%] tests/test_fields_enum.py::test_outer_enum_init_dict PASSED [ 22%] tests/test_fields_enum.py::test_outer_enum_init_dict_str PASSED [ 22%] tests/test_fields_enum.py::test_outer_enum_init_pb2 PASSED [ 22%] tests/test_fields_enum.py::test_outer_enum_unset PASSED [ 23%] tests/test_fields_enum.py::test_outer_enum_write PASSED [ 23%] tests/test_fields_enum.py::test_outer_enum_write_int PASSED [ 23%] tests/test_fields_enum.py::test_outer_enum_write_str PASSED [ 24%] tests/test_fields_enum.py::test_inner_enum_init PASSED [ 24%] tests/test_fields_enum.py::test_inner_enum_write PASSED [ 25%] tests/test_fields_enum.py::test_enum_del PASSED [ 25%] tests/test_fields_enum.py::test_nested_enum_from_string PASSED [ 25%] tests/test_fields_enum.py::test_enum_field_by_string PASSED [ 26%] tests/test_fields_enum.py::test_enum_field_by_string_with_package PASSED [ 26%] tests/test_fields_enum.py::test_enums_in_different_files PASSED [ 26%] tests/test_fields_enum.py::test_enums_in_one_file PASSED [ 27%] tests/test_fields_enum.py::test_unwrapped_enum_fields PASSED [ 27%] tests/test_fields_enum.py::test_enum_alias_good PASSED [ 27%] tests/test_fields_int.py::test_int_init PASSED [ 28%] tests/test_fields_int.py::test_int_rmw PASSED [ 28%] tests/test_fields_int.py::test_int_del PASSED [ 29%] tests/test_fields_int.py::test_int_size PASSED [ 29%] tests/test_fields_int.py::test_int_unsigned PASSED [ 29%] tests/test_fields_int.py::test_field_descriptor_idempotent PASSED [ 30%] tests/test_fields_int.py::test_int64_dict_round_trip PASSED [ 30%] tests/test_fields_map_composite.py::test_composite_map PASSED [ 30%] tests/test_fields_map_composite.py::test_composite_map_dict PASSED [ 31%] tests/test_fields_map_composite.py::test_composite_map_set PASSED [ 31%] tests/test_fields_map_composite.py::test_composite_map_deep_set PASSED [ 32%] tests/test_fields_map_composite.py::test_composite_map_del PASSED [ 32%] tests/test_fields_map_scalar.py::test_basic_map PASSED [ 32%] tests/test_fields_map_scalar.py::test_basic_map_with_underscore_field_name PASSED [ 33%] tests/test_fields_map_scalar.py::test_basic_map_assignment PASSED [ 33%] tests/test_fields_map_scalar.py::test_basic_map_deletion PASSED [ 33%] tests/test_fields_mitigate_collision.py::test_fields_mitigate_collision PASSED [ 34%] tests/test_fields_oneof.py::test_oneof PASSED [ 34%] tests/test_fields_oneof.py::test_multiple_oneofs PASSED [ 35%] tests/test_fields_optional.py::test_optional_init PASSED [ 35%] tests/test_fields_optional.py::test_optional_and_oneof PASSED [ 35%] tests/test_fields_repeated_composite.py::test_repeated_composite_init PASSED [ 36%] tests/test_fields_repeated_composite.py::test_repeated_composite_equality PASSED [ 36%] tests/test_fields_repeated_composite.py::test_repeated_composite_init_struct PASSED [ 36%] tests/test_fields_repeated_composite.py::test_repeated_composite_falsy_behavior PASSED [ 37%] tests/test_fields_repeated_composite.py::test_repeated_composite_marshaled PASSED [ 37%] tests/test_fields_repeated_composite.py::test_repeated_composite_enum PASSED [ 38%] tests/test_fields_repeated_composite.py::test_repeated_composite_outer_write PASSED [ 38%] tests/test_fields_repeated_composite.py::test_repeated_composite_append PASSED [ 38%] tests/test_fields_repeated_composite.py::test_repeated_composite_insert PASSED [ 39%] tests/test_fields_repeated_composite.py::test_repeated_composite_iadd PASSED [ 39%] tests/test_fields_repeated_composite.py::test_repeated_composite_set_index PASSED [ 39%] tests/test_fields_repeated_composite.py::test_repeated_composite_set_index_error PASSED [ 40%] tests/test_fields_repeated_composite.py::test_repeated_composite_set_slice_less PASSED [ 40%] tests/test_fields_repeated_composite.py::test_repeated_composite_set_slice_more PASSED [ 41%] tests/test_fields_repeated_composite.py::test_repeated_composite_set_slice_not_iterable PASSED [ 41%] tests/test_fields_repeated_composite.py::test_repeated_composite_set_extended_slice PASSED [ 41%] tests/test_fields_repeated_composite.py::test_repeated_composite_set_extended_slice_wrong_length PASSED [ 42%] tests/test_fields_repeated_composite.py::test_repeated_composite_set_wrong_key_type PASSED [ 42%] tests/test_fields_repeated_composite.py::test_repeated_composite_set_wrong_value_type PASSED [ 42%] tests/test_fields_repeated_scalar.py::test_repeated_scalar_init PASSED [ 43%] tests/test_fields_repeated_scalar.py::test_repeated_scalar_append PASSED [ 43%] tests/test_fields_repeated_scalar.py::test_repeated_scalar_iadd PASSED [ 44%] tests/test_fields_repeated_scalar.py::test_repeated_scalar_setitem PASSED [ 44%] tests/test_fields_repeated_scalar.py::test_repeated_scalar_overwrite PASSED [ 44%] tests/test_fields_repeated_scalar.py::test_repeated_scalar_eq_ne PASSED [ 45%] tests/test_fields_repeated_scalar.py::test_repeated_scalar_del PASSED [ 45%] tests/test_fields_repeated_scalar.py::test_repeated_scalar_delitem PASSED [ 45%] tests/test_fields_repeated_scalar.py::test_repeated_scalar_sort PASSED [ 46%] tests/test_fields_repeated_scalar.py::test_repeated_scalar_wrong_type PASSED [ 46%] tests/test_fields_string.py::test_string_init PASSED [ 47%] tests/test_fields_string.py::test_string_rmw PASSED [ 47%] tests/test_fields_string.py::test_string_del PASSED [ 47%] tests/test_file_info_salting.py::test_fallback_salt_is_appended_to_filename PASSED [ 48%] tests/test_file_info_salting.py::test_none_fallback_salt_is_appended_to_filename_as_empty PASSED [ 48%] tests/test_file_info_salting_with_manifest.py::test_no_salt_is_appended_to_filename_with_manifest PASSED [ 48%] tests/test_file_info_salting_with_manifest.py::test_none_fallback_salt_is_appended_to_filename_as_empty PASSED [ 49%] tests/test_json.py::test_message_to_json PASSED [ 49%] tests/test_json.py::test_message_to_json_no_indent PASSED [ 50%] tests/test_json.py::test_message_from_json PASSED [ 50%] tests/test_json.py::test_message_json_round_trip PASSED [ 50%] tests/test_json.py::test_json_stringy_enums PASSED [ 51%] tests/test_json.py::test_json_default_enums PASSED [ 51%] tests/test_json.py::test_json_default_values PASSED [ 51%] tests/test_json.py::test_json_unknown_field PASSED [ 52%] tests/test_json.py::test_json_snake_case PASSED [ 52%] tests/test_json.py::test_json_name PASSED [ 52%] tests/test_json.py::test_json_sort_keys PASSED [ 53%] tests/test_json.py::test_json_float_precision PASSED [ 53%] tests/test_marshal_field_mask.py::test_field_mask_read PASSED [ 54%] tests/test_marshal_field_mask.py::test_field_mask_write_string PASSED [ 54%] tests/test_marshal_field_mask.py::test_field_mask_write_pb2 PASSED [ 54%] tests/test_marshal_field_mask.py::test_field_mask_absence PASSED [ 55%] tests/test_marshal_field_mask.py::test_timestamp_del PASSED [ 55%] tests/test_marshal_field_mask.py::test_timestamp_to_python_idempotent PASSED [ 55%] tests/test_marshal_register.py::test_registration PASSED [ 56%] tests/test_marshal_register.py::test_invalid_marshal_class PASSED [ 56%] tests/test_marshal_register.py::test_invalid_marshal_rule PASSED [ 57%] tests/test_marshal_strict.py::test_strict_to_proto PASSED [ 57%] tests/test_marshal_stringy_numbers.py::test_marshal_to_proto_stringy_numbers[3-0-0] PASSED [ 57%] tests/test_marshal_stringy_numbers.py::test_marshal_to_proto_stringy_numbers[3-4294967296-4294967296] PASSED [ 58%] tests/test_marshal_stringy_numbers.py::test_marshal_to_proto_stringy_numbers[18--4294967296--4294967296_0] PASSED [ 58%] tests/test_marshal_stringy_numbers.py::test_marshal_to_proto_stringy_numbers[3-None-None] PASSED [ 58%] tests/test_marshal_stringy_numbers.py::test_marshal_to_proto_stringy_numbers[4-0-0] PASSED [ 59%] tests/test_marshal_stringy_numbers.py::test_marshal_to_proto_stringy_numbers[4-4294967296-4294967296] PASSED [ 59%] tests/test_marshal_stringy_numbers.py::test_marshal_to_proto_stringy_numbers[4-None-None] PASSED [ 60%] tests/test_marshal_stringy_numbers.py::test_marshal_to_proto_stringy_numbers[18-0-0] PASSED [ 60%] tests/test_marshal_stringy_numbers.py::test_marshal_to_proto_stringy_numbers[18-4294967296-4294967296] PASSED [ 60%] tests/test_marshal_stringy_numbers.py::test_marshal_to_proto_stringy_numbers[18--4294967296--4294967296_1] PASSED [ 61%] tests/test_marshal_stringy_numbers.py::test_marshal_to_proto_stringy_numbers[18-None-None] PASSED [ 61%] tests/test_marshal_stringy_numbers.py::test_marshal_to_proto_stringy_numbers[6-0-0] PASSED [ 61%] tests/test_marshal_stringy_numbers.py::test_marshal_to_proto_stringy_numbers[6-4294967296-4294967296] PASSED [ 62%] tests/test_marshal_stringy_numbers.py::test_marshal_to_proto_stringy_numbers[6--4294967296--4294967296] PASSED [ 62%] tests/test_marshal_stringy_numbers.py::test_marshal_to_proto_stringy_numbers[6-None-None] PASSED [ 63%] tests/test_marshal_stringy_numbers.py::test_marshal_to_proto_stringy_numbers[16-0-0] PASSED [ 63%] tests/test_marshal_stringy_numbers.py::test_marshal_to_proto_stringy_numbers[16-4294967296-4294967296] PASSED [ 63%] tests/test_marshal_stringy_numbers.py::test_marshal_to_proto_stringy_numbers[16--4294967296--4294967296] PASSED [ 64%] tests/test_marshal_stringy_numbers.py::test_marshal_to_proto_stringy_numbers[16-None-None] PASSED [ 64%] tests/test_marshal_types_dates.py::test_timestamp_read PASSED [ 64%] tests/test_marshal_types_dates.py::test_timestamp_write_init PASSED [ 65%] tests/test_marshal_types_dates.py::test_timestamp_write PASSED [ 65%] tests/test_marshal_types_dates.py::test_timestamp_write_pb2 PASSED [ 66%] tests/test_marshal_types_dates.py::test_timestamp_write_string PASSED [ 66%] tests/test_marshal_types_dates.py::test_timestamp_rmw_nanos PASSED [ 66%] tests/test_marshal_types_dates.py::test_timestamp_absence PASSED [ 67%] tests/test_marshal_types_dates.py::test_timestamp_del PASSED [ 67%] tests/test_marshal_types_dates.py::test_duration_read PASSED [ 67%] tests/test_marshal_types_dates.py::test_duration_write_init PASSED [ 68%] tests/test_marshal_types_dates.py::test_duration_write PASSED [ 68%] tests/test_marshal_types_dates.py::test_duration_write_pb2 PASSED [ 69%] tests/test_marshal_types_dates.py::test_duration_write_string PASSED [ 69%] tests/test_marshal_types_dates.py::test_duration_write_string_nested PASSED [ 69%] tests/test_marshal_types_dates.py::test_duration_del PASSED [ 70%] tests/test_marshal_types_dates.py::test_duration_nanos_rmw PASSED [ 70%] tests/test_marshal_types_dates.py::test_timestamp_to_python_idempotent PASSED [ 70%] tests/test_marshal_types_dates.py::test_duration_to_python_idempotent PASSED [ 71%] tests/test_marshal_types_dates.py::test_vanilla_datetime_construction PASSED [ 71%] tests/test_marshal_types_enum.py::test_to_proto PASSED [ 72%] tests/test_marshal_types_enum.py::test_to_python PASSED [ 72%] tests/test_marshal_types_enum.py::test_to_python_unknown_value PASSED [ 72%] tests/test_marshal_types_enum.py::test_enum_append PASSED [ 73%] tests/test_marshal_types_enum.py::test_enum_map_insert PASSED [ 73%] tests/test_marshal_types_message.py::test_to_proto PASSED [ 73%] tests/test_marshal_types_message.py::test_to_python PASSED [ 74%] tests/test_marshal_types_struct.py::test_value_primitives_read PASSED [ 74%] tests/test_marshal_types_struct.py::test_value_absent PASSED [ 75%] tests/test_marshal_types_struct.py::test_value_primitives_rmw PASSED [ 75%] tests/test_marshal_types_struct.py::test_value_write_pb PASSED [ 75%] tests/test_marshal_types_struct.py::test_value_lists_read PASSED [ 76%] tests/test_marshal_types_struct.py::test_value_lists_null PASSED [ 76%] tests/test_marshal_types_struct.py::test_value_struct_null PASSED [ 76%] tests/test_marshal_types_struct.py::test_value_lists_rmw PASSED [ 77%] tests/test_marshal_types_struct.py::test_value_lists_nested PASSED [ 77%] tests/test_marshal_types_struct.py::test_value_lists_struct PASSED [ 77%] tests/test_marshal_types_struct.py::test_value_lists_detachment PASSED [ 78%] tests/test_marshal_types_struct.py::test_value_structs_read PASSED [ 78%] tests/test_marshal_types_struct.py::test_value_structs_rmw PASSED [ 79%] tests/test_marshal_types_struct.py::test_value_structs_nested PASSED [ 79%] tests/test_marshal_types_struct.py::test_value_invalid_value PASSED [ 79%] tests/test_marshal_types_struct.py::test_value_unset PASSED [ 80%] tests/test_marshal_types_struct.py::test_list_value_read PASSED [ 80%] tests/test_marshal_types_struct.py::test_list_value_pb PASSED [ 80%] tests/test_marshal_types_struct.py::test_list_value_reassignment PASSED [ 81%] tests/test_marshal_types_struct.py::test_list_value_invalid PASSED [ 81%] tests/test_marshal_types_struct.py::test_struct_read PASSED [ 82%] tests/test_marshal_types_struct.py::test_struct_pb PASSED [ 82%] tests/test_marshal_types_struct.py::test_struct_reassignment PASSED [ 82%] tests/test_marshal_types_struct.py::test_struct_nested PASSED [ 83%] tests/test_marshal_types_wrappers_bool.py::test_bool_value_init PASSED [ 83%] tests/test_marshal_types_wrappers_bool.py::test_bool_value_init_dict PASSED [ 83%] tests/test_marshal_types_wrappers_bool.py::test_bool_value_distinction_from_bool PASSED [ 84%] tests/test_marshal_types_wrappers_bool.py::test_bool_value_rmw PASSED [ 84%] tests/test_marshal_types_wrappers_bool.py::test_bool_value_write_bool_value PASSED [ 85%] tests/test_marshal_types_wrappers_bool.py::test_bool_value_del PASSED [ 85%] tests/test_marshal_types_wrappers_bool.py::test_multiple_types PASSED [ 85%] tests/test_marshal_types_wrappers_bool.py::test_bool_value_to_python PASSED [ 86%] tests/test_message.py::test_message_constructor_instance PASSED [ 86%] tests/test_message.py::test_message_constructor_underlying_pb2 PASSED [ 86%] tests/test_message.py::test_message_constructor_underlying_pb2_and_kwargs PASSED [ 87%] tests/test_message.py::test_message_constructor_dict PASSED [ 87%] tests/test_message.py::test_message_constructor_kwargs PASSED [ 88%] tests/test_message.py::test_message_constructor_invalid PASSED [ 88%] tests/test_message.py::test_message_constructor_explicit_qualname PASSED [ 88%] tests/test_message.py::test_message_contains_primitive PASSED [ 89%] tests/test_message.py::test_message_contains_composite PASSED [ 89%] tests/test_message.py::test_message_contains_repeated_primitive PASSED [ 89%] tests/test_message.py::test_message_contains_repeated_composite PASSED [ 90%] tests/test_message.py::test_message_eq_primitives PASSED [ 90%] tests/test_message.py::test_message_serialize PASSED [ 91%] tests/test_message.py::test_message_dict_serialize PASSED [ 91%] tests/test_message.py::test_message_deserialize PASSED [ 91%] tests/test_message.py::test_message_pb PASSED [ 92%] tests/test_message.py::test_invalid_field_access PASSED [ 92%] tests/test_message.py::test_setattr PASSED [ 92%] tests/test_message.py::test_serialize_to_dict PASSED [ 93%] tests/test_message.py::test_serialize_to_dict_float_precision PASSED [ 93%] tests/test_message.py::test_unknown_field_deserialize PASSED [ 94%] tests/test_message.py::test_unknown_field_deserialize_keep_fields PASSED [ 94%] tests/test_message.py::test_unknown_field_from_dict PASSED [ 94%] tests/test_message.py::test_copy_from PASSED [ 95%] tests/test_message.py::test_dir PASSED [ 95%] tests/test_message.py::test_dir_message_base PASSED [ 95%] tests/test_message_filename.py::test_filename_includes_classname_salt PASSED [ 96%] tests/test_message_filename_with_and_without_manifest.py::test_manifest_causes_exclusion_of_classname_salt PASSED [ 96%] tests/test_message_filename_with_manifest.py::test_manifest_causes_exclusion_of_classname_salt PASSED [ 97%] tests/test_message_nested.py::test_singly_nested_message PASSED [ 97%] tests/test_message_nested.py::test_multiply_nested_message PASSED [ 97%] tests/test_message_nested.py::test_forking_nested_messages PASSED [ 98%] tests/test_message_pickling.py::test_pickling PASSED [ 98%] tests/test_modules.py::test_module_package PASSED [ 98%] tests/test_modules.py::test_module_package_cross_api PASSED [ 99%] tests/test_modules.py::test_module_package_explicit_marshal PASSED [ 99%] tests/test_modules.py::test_module_manifest PASSED [100%] ============================= 268 passed in 7.55s ============================== >>> py3-proto-plus: Entering fakeroot... >>> py3-proto-plus-pyc*: Running split function pyc... 'usr/lib/python3.12/site-packages/proto/__pycache__' -> '/home/buildozer/aports/community/py3-proto-plus/pkg/py3-proto-plus-pyc/usr/lib/python3.12/site-packages/proto/__pycache__' 'usr/lib/python3.12/site-packages/proto/marshal/__pycache__' -> '/home/buildozer/aports/community/py3-proto-plus/pkg/py3-proto-plus-pyc/usr/lib/python3.12/site-packages/proto/marshal/__pycache__' 'usr/lib/python3.12/site-packages/proto/marshal/rules/__pycache__' -> '/home/buildozer/aports/community/py3-proto-plus/pkg/py3-proto-plus-pyc/usr/lib/python3.12/site-packages/proto/marshal/rules/__pycache__' 'usr/lib/python3.12/site-packages/proto/marshal/collections/__pycache__' -> '/home/buildozer/aports/community/py3-proto-plus/pkg/py3-proto-plus-pyc/usr/lib/python3.12/site-packages/proto/marshal/collections/__pycache__' >>> py3-proto-plus-pyc*: Preparing subpackage py3-proto-plus-pyc... >>> py3-proto-plus-pyc*: Running postcheck for py3-proto-plus-pyc >>> py3-proto-plus*: Running postcheck for py3-proto-plus >>> py3-proto-plus*: Preparing package py3-proto-plus... >>> py3-proto-plus-pyc*: Tracing dependencies... python3 py3-protobuf python3~3.12 >>> py3-proto-plus-pyc*: Package size: 118.2 KB >>> py3-proto-plus-pyc*: Compressing data... >>> py3-proto-plus-pyc*: Create checksum... >>> py3-proto-plus-pyc*: Create py3-proto-plus-pyc-1.26.1-r0.apk >>> py3-proto-plus*: Tracing dependencies... python3 py3-protobuf python3~3.12 >>> py3-proto-plus*: Package size: 133.0 KB >>> py3-proto-plus*: Compressing data... >>> py3-proto-plus*: Create checksum... >>> py3-proto-plus*: Create py3-proto-plus-1.26.1-r0.apk >>> py3-proto-plus: Build complete at Thu, 01 May 2025 01:57:32 +0000 elapsed time 0h 0m 21s >>> py3-proto-plus: Cleaning up srcdir >>> py3-proto-plus: Cleaning up pkgdir >>> py3-proto-plus: Uninstalling dependencies... (1/37) Purging .makedepends-py3-proto-plus (20250501.015714) (2/37) Purging py3-gpep517-pyc (16-r0) (3/37) Purging py3-gpep517 (16-r0) (4/37) Purging py3-installer-pyc (0.7.0-r2) (5/37) Purging py3-installer (0.7.0-r2) (6/37) Purging py3-setuptools-pyc (77.0.3-r0) (7/37) Purging py3-setuptools (77.0.3-r0) (8/37) Purging py3-wheel-pyc (0.43.0-r0) (9/37) Purging py3-wheel (0.43.0-r0) (10/37) Purging py3-googleapis-common-protos-pyc (1.70.0-r0) (11/37) Purging py3-googleapis-common-protos (1.70.0-r0) (12/37) Purging py3-protobuf-pyc (4.25.6-r0) (13/37) Purging py3-protobuf (4.25.6-r0) (14/37) Purging tzdata (2025b-r0) (15/37) Purging py3-pytest-pyc (8.3.5-r0) (16/37) Purging py3-pytest (8.3.5-r0) (17/37) Purging py3-iniconfig-pyc (2.1.0-r0) (18/37) Purging py3-iniconfig (2.1.0-r0) (19/37) Purging py3-packaging-pyc (25.0-r0) (20/37) Purging py3-packaging (25.0-r0) (21/37) Purging py3-parsing-pyc (3.2.0-r0) (22/37) Purging py3-parsing (3.2.0-r0) (23/37) Purging py3-pluggy-pyc (1.5.0-r0) (24/37) Purging py3-pluggy (1.5.0-r0) (25/37) Purging py3-py-pyc (1.11.0-r4) (26/37) Purging py3-py (1.11.0-r4) (27/37) Purging py3-tz-pyc (2025.2-r0) (28/37) Purging py3-tz (2025.2-r0) (29/37) Purging python3-pyc (3.12.10-r0) (30/37) Purging python3-pycache-pyc0 (3.12.10-r0) (31/37) Purging pyc (3.12.10-r0) (32/37) Purging python3 (3.12.10-r0) (33/37) Purging gdbm (1.24-r0) (34/37) Purging libffi (3.4.8-r0) (35/37) Purging libpanelw (6.5_p20250412-r0) (36/37) Purging mpdecimal (4.0.0-r0) (37/37) Purging sqlite-libs (3.49.1-r1) Executing busybox-1.37.0-r16.trigger OK: 343 MiB in 110 packages >>> py3-proto-plus: Updating the community/riscv64 repository index... >>> py3-proto-plus: Signing the index...