>>> py3-w3lib: Building community/py3-w3lib 2.1.2-r1 (using abuild 3.13.0-r3) started Wed, 01 May 2024 03:10:56 +0000 >>> py3-w3lib: Checking sanity of /home/buildozer/aports/community/py3-w3lib/APKBUILD... >>> py3-w3lib: Analyzing dependencies... >>> py3-w3lib: Installing for build: build-base python3 py3-setuptools py3-gpep517 py3-wheel py3-pytest (1/33) Installing libbz2 (1.0.8-r6) (2/33) Installing libffi (3.4.6-r0) (3/33) Installing gdbm (1.23-r1) (4/33) Installing xz-libs (5.6.1-r3) (5/33) Installing mpdecimal (4.0.0-r0) (6/33) Installing libpanelw (6.4_p20240330-r0) (7/33) Installing readline (8.2.10-r0) (8/33) Installing sqlite-libs (3.45.3-r0) (9/33) Installing python3 (3.12.3-r1) (10/33) Installing python3-pycache-pyc0 (3.12.3-r1) (11/33) Installing pyc (3.12.3-r1) (12/33) Installing python3-pyc (3.12.3-r1) (13/33) Installing py3-parsing (3.1.2-r1) (14/33) Installing py3-parsing-pyc (3.1.2-r1) (15/33) Installing py3-packaging (24.0-r1) (16/33) Installing py3-packaging-pyc (24.0-r1) (17/33) Installing py3-setuptools (69.5.1-r0) (18/33) Installing py3-setuptools-pyc (69.5.1-r0) (19/33) Installing py3-installer (0.7.0-r2) (20/33) Installing py3-installer-pyc (0.7.0-r2) (21/33) Installing py3-gpep517 (15-r2) (22/33) Installing py3-gpep517-pyc (15-r2) (23/33) Installing py3-wheel (0.42.0-r1) (24/33) Installing py3-wheel-pyc (0.42.0-r1) (25/33) Installing py3-iniconfig (2.0.0-r1) (26/33) Installing py3-iniconfig-pyc (2.0.0-r1) (27/33) Installing py3-pluggy (1.4.0-r1) (28/33) Installing py3-pluggy-pyc (1.4.0-r1) (29/33) Installing py3-py (1.11.0-r3) (30/33) Installing py3-py-pyc (1.11.0-r3) (31/33) Installing py3-pytest (8.1.1-r1) (32/33) Installing py3-pytest-pyc (8.1.1-r1) (33/33) Installing .makedepends-py3-w3lib (20240501.031100) Executing busybox-1.36.1-r26.trigger OK: 526 MiB in 140 packages >>> py3-w3lib: Cleaning up srcdir >>> py3-w3lib: Cleaning up pkgdir >>> py3-w3lib: Cleaning up tmpdir >>> py3-w3lib: Fetching https://distfiles.alpinelinux.org/distfiles/v3.20/py3-w3lib-2.1.2.tar.gz Connecting to distfiles.alpinelinux.org (172.105.82.32:443) saving to '/var/cache/distfiles/v3.20/py3-w3lib-2.1.2.tar.gz.part' py3-w3lib-2.1.2.tar. 100% |********************************| 51058 0:00:00 ETA '/var/cache/distfiles/v3.20/py3-w3lib-2.1.2.tar.gz.part' saved >>> py3-w3lib: Fetching https://distfiles.alpinelinux.org/distfiles/v3.20/py3-w3lib-2.1.2.tar.gz >>> py3-w3lib: Checking sha512sums... py3-w3lib-2.1.2.tar.gz: OK >>> py3-w3lib: Unpacking /var/cache/distfiles/v3.20/py3-w3lib-2.1.2.tar.gz... 2024-05-01 03:11:01,566 gpep517 INFO Building wheel via backend setuptools.build_meta:__legacy__ 2024-05-01 03:11:01,603 root INFO running bdist_wheel 2024-05-01 03:11:01,630 root INFO running build 2024-05-01 03:11:01,630 root INFO running build_py 2024-05-01 03:11:01,635 root INFO creating build 2024-05-01 03:11:01,635 root INFO creating build/lib 2024-05-01 03:11:01,635 root INFO creating build/lib/w3lib 2024-05-01 03:11:01,635 root INFO copying w3lib/url.py -> build/lib/w3lib 2024-05-01 03:11:01,636 root INFO copying w3lib/encoding.py -> build/lib/w3lib 2024-05-01 03:11:01,636 root INFO copying w3lib/util.py -> build/lib/w3lib 2024-05-01 03:11:01,637 root INFO copying w3lib/http.py -> build/lib/w3lib 2024-05-01 03:11:01,637 root INFO copying w3lib/__init__.py -> build/lib/w3lib 2024-05-01 03:11:01,637 root INFO copying w3lib/_url.py -> build/lib/w3lib 2024-05-01 03:11:01,638 root INFO copying w3lib/html.py -> build/lib/w3lib 2024-05-01 03:11:01,638 root INFO copying w3lib/_types.py -> build/lib/w3lib 2024-05-01 03:11:01,638 root INFO copying w3lib/_infra.py -> build/lib/w3lib 2024-05-01 03:11:01,638 root INFO running egg_info 2024-05-01 03:11:01,639 root INFO creating w3lib.egg-info 2024-05-01 03:11:01,641 root INFO writing w3lib.egg-info/PKG-INFO 2024-05-01 03:11:01,642 root INFO writing dependency_links to w3lib.egg-info/dependency_links.txt 2024-05-01 03:11:01,643 root INFO writing top-level names to w3lib.egg-info/top_level.txt 2024-05-01 03:11:01,643 root INFO writing manifest file 'w3lib.egg-info/SOURCES.txt' 2024-05-01 03:11:01,647 root INFO reading manifest file 'w3lib.egg-info/SOURCES.txt' 2024-05-01 03:11:01,647 root INFO reading manifest template 'MANIFEST.in' 2024-05-01 03:11:01,648 root WARNING warning: no files found matching '*.txt' under directory 'tests' 2024-05-01 03:11:01,649 root INFO adding license file 'LICENSE' 2024-05-01 03:11:01,650 root INFO writing manifest file 'w3lib.egg-info/SOURCES.txt' 2024-05-01 03:11:01,651 root INFO copying w3lib/py.typed -> build/lib/w3lib 2024-05-01 03:11:01,660 wheel INFO installing to build/bdist.linux-x86_64/wheel 2024-05-01 03:11:01,660 root INFO running install 2024-05-01 03:11:01,674 root INFO running install_lib 2024-05-01 03:11:01,677 root INFO creating build/bdist.linux-x86_64 2024-05-01 03:11:01,677 root INFO creating build/bdist.linux-x86_64/wheel 2024-05-01 03:11:01,677 root INFO creating build/bdist.linux-x86_64/wheel/w3lib 2024-05-01 03:11:01,677 root INFO copying build/lib/w3lib/url.py -> build/bdist.linux-x86_64/wheel/w3lib 2024-05-01 03:11:01,677 root INFO copying build/lib/w3lib/encoding.py -> build/bdist.linux-x86_64/wheel/w3lib 2024-05-01 03:11:01,678 root INFO copying build/lib/w3lib/util.py -> build/bdist.linux-x86_64/wheel/w3lib 2024-05-01 03:11:01,678 root INFO copying build/lib/w3lib/http.py -> build/bdist.linux-x86_64/wheel/w3lib 2024-05-01 03:11:01,678 root INFO copying build/lib/w3lib/__init__.py -> build/bdist.linux-x86_64/wheel/w3lib 2024-05-01 03:11:01,678 root INFO copying build/lib/w3lib/_url.py -> build/bdist.linux-x86_64/wheel/w3lib 2024-05-01 03:11:01,679 root INFO copying build/lib/w3lib/html.py -> build/bdist.linux-x86_64/wheel/w3lib 2024-05-01 03:11:01,679 root INFO copying build/lib/w3lib/_types.py -> build/bdist.linux-x86_64/wheel/w3lib 2024-05-01 03:11:01,679 root INFO copying build/lib/w3lib/py.typed -> build/bdist.linux-x86_64/wheel/w3lib 2024-05-01 03:11:01,679 root INFO copying build/lib/w3lib/_infra.py -> build/bdist.linux-x86_64/wheel/w3lib 2024-05-01 03:11:01,679 root INFO running install_egg_info 2024-05-01 03:11:01,683 root INFO Copying w3lib.egg-info to build/bdist.linux-x86_64/wheel/w3lib-2.1.2-py3.12.egg-info 2024-05-01 03:11:01,684 root INFO running install_scripts 2024-05-01 03:11:01,685 wheel INFO creating build/bdist.linux-x86_64/wheel/w3lib-2.1.2.dist-info/WHEEL 2024-05-01 03:11:01,686 wheel INFO creating '/home/buildozer/aports/community/py3-w3lib/src/w3lib-2.1.2/.dist/.tmp-un4z56n_/w3lib-2.1.2-py3-none-any.whl' and adding 'build/bdist.linux-x86_64/wheel' to it 2024-05-01 03:11:01,686 wheel INFO adding 'w3lib/__init__.py' 2024-05-01 03:11:01,686 wheel INFO adding 'w3lib/_infra.py' 2024-05-01 03:11:01,687 wheel INFO adding 'w3lib/_types.py' 2024-05-01 03:11:01,687 wheel INFO adding 'w3lib/_url.py' 2024-05-01 03:11:01,687 wheel INFO adding 'w3lib/encoding.py' 2024-05-01 03:11:01,687 wheel INFO adding 'w3lib/html.py' 2024-05-01 03:11:01,688 wheel INFO adding 'w3lib/http.py' 2024-05-01 03:11:01,688 wheel INFO adding 'w3lib/py.typed' 2024-05-01 03:11:01,688 wheel INFO adding 'w3lib/url.py' 2024-05-01 03:11:01,688 wheel INFO adding 'w3lib/util.py' 2024-05-01 03:11:01,689 wheel INFO adding 'w3lib-2.1.2.dist-info/LICENSE' 2024-05-01 03:11:01,689 wheel INFO adding 'w3lib-2.1.2.dist-info/METADATA' 2024-05-01 03:11:01,689 wheel INFO adding 'w3lib-2.1.2.dist-info/WHEEL' 2024-05-01 03:11:01,689 wheel INFO adding 'w3lib-2.1.2.dist-info/top_level.txt' 2024-05-01 03:11:01,690 wheel INFO adding 'w3lib-2.1.2.dist-info/RECORD' 2024-05-01 03:11:01,690 wheel INFO removing build/bdist.linux-x86_64/wheel 2024-05-01 03:11:01,691 gpep517 INFO The backend produced .dist/w3lib-2.1.2-py3-none-any.whl w3lib-2.1.2-py3-none-any.whl ============================= test session starts ============================== platform linux -- Python 3.12.3, pytest-8.1.1, pluggy-1.4.0 -- /home/buildozer/aports/community/py3-w3lib/src/w3lib-2.1.2/.testenv/bin/python3 cachedir: .pytest_cache rootdir: /home/buildozer/aports/community/py3-w3lib/src/w3lib-2.1.2 configfile: pytest.ini collecting ... collected 314 items tests/test_encoding.py::RequestEncodingTests::test_bom PASSED [ 0%] tests/test_encoding.py::RequestEncodingTests::test_html_body_declared_encoding PASSED [ 0%] tests/test_encoding.py::RequestEncodingTests::test_html_body_declared_encoding_unicode PASSED [ 0%] tests/test_encoding.py::RequestEncodingTests::test_http_encoding_header PASSED [ 1%] tests/test_encoding.py::CodecsEncodingTestCase::test_resolve_encoding PASSED [ 1%] tests/test_encoding.py::UnicodeDecodingTestCase::test_invalid_utf8 PASSED [ 1%] tests/test_encoding.py::UnicodeDecodingTestCase::test_utf8 PASSED [ 2%] tests/test_encoding.py::HtmlConversionTests::test_BOM PASSED [ 2%] tests/test_encoding.py::HtmlConversionTests::test_autodetect PASSED [ 2%] tests/test_encoding.py::HtmlConversionTests::test_content_type_and_conversion PASSED [ 3%] tests/test_encoding.py::HtmlConversionTests::test_default_encoding PASSED [ 3%] tests/test_encoding.py::HtmlConversionTests::test_empty_body PASSED [ 3%] tests/test_encoding.py::HtmlConversionTests::test_html_encoding PASSED [ 4%] tests/test_encoding.py::HtmlConversionTests::test_invalid_utf8_encoded_body_with_valid_utf8_BOM PASSED [ 4%] tests/test_encoding.py::HtmlConversionTests::test_python_crash PASSED [ 4%] tests/test_encoding.py::HtmlConversionTests::test_replace_wrong_encoding PASSED [ 5%] tests/test_encoding.py::HtmlConversionTests::test_unicode_body PASSED [ 5%] tests/test_encoding.py::HtmlConversionTests::test_utf16_32 PASSED [ 5%] tests/test_encoding.py::HtmlConversionTests::test_utf8_unexpected_end_of_data_with_valid_utf8_BOM PASSED [ 6%] tests/test_html.py::RemoveEntitiesTest::test_browser_hack PASSED [ 6%] tests/test_html.py::RemoveEntitiesTest::test_encoding PASSED [ 6%] tests/test_html.py::RemoveEntitiesTest::test_illegal_entities PASSED [ 7%] tests/test_html.py::RemoveEntitiesTest::test_keep_entities PASSED [ 7%] tests/test_html.py::RemoveEntitiesTest::test_missing_semicolon PASSED [ 7%] tests/test_html.py::RemoveEntitiesTest::test_regular PASSED [ 7%] tests/test_html.py::RemoveEntitiesTest::test_returns_unicode PASSED [ 8%] tests/test_html.py::ReplaceTagsTest::test_replace_tags PASSED [ 8%] tests/test_html.py::ReplaceTagsTest::test_replace_tags_multiline PASSED [ 8%] tests/test_html.py::ReplaceTagsTest::test_returns_unicode PASSED [ 9%] tests/test_html.py::RemoveCommentsTest::test_no_comments PASSED [ 9%] tests/test_html.py::RemoveCommentsTest::test_remove_comments PASSED [ 9%] tests/test_html.py::RemoveCommentsTest::test_returns_unicode PASSED [ 10%] tests/test_html.py::RemoveTagsTest::test_keep_argument PASSED [ 10%] tests/test_html.py::RemoveTagsTest::test_remove_empty_tags PASSED [ 10%] tests/test_html.py::RemoveTagsTest::test_remove_tags PASSED [ 11%] tests/test_html.py::RemoveTagsTest::test_remove_tags_with_attributes PASSED [ 11%] tests/test_html.py::RemoveTagsTest::test_remove_tags_without_tags PASSED [ 11%] tests/test_html.py::RemoveTagsTest::test_returns_unicode PASSED [ 12%] tests/test_html.py::RemoveTagsTest::test_uppercase_tags PASSED [ 12%] tests/test_html.py::RemoveTagsWithContentTest::test_empty_tags PASSED [ 12%] tests/test_html.py::RemoveTagsWithContentTest::test_returns_unicode PASSED [ 13%] tests/test_html.py::RemoveTagsWithContentTest::test_tags_with_shared_prefix PASSED [ 13%] tests/test_html.py::RemoveTagsWithContentTest::test_with_tags PASSED [ 13%] tests/test_html.py::RemoveTagsWithContentTest::test_without_tags PASSED [ 14%] tests/test_html.py::ReplaceEscapeCharsTest::test_returns_unicode PASSED [ 14%] tests/test_html.py::ReplaceEscapeCharsTest::test_with_escape_chars PASSED [ 14%] tests/test_html.py::ReplaceEscapeCharsTest::test_without_escape_chars PASSED [ 14%] tests/test_html.py::UnquoteMarkupTest::test_returns_unicode PASSED [ 15%] tests/test_html.py::UnquoteMarkupTest::test_unquote_markup PASSED [ 15%] tests/test_html.py::GetBaseUrlTest::test_attributes_before_href PASSED [ 15%] tests/test_html.py::GetBaseUrlTest::test_base_url_in_comment PASSED [ 16%] tests/test_html.py::GetBaseUrlTest::test_get_base_url PASSED [ 16%] tests/test_html.py::GetBaseUrlTest::test_get_base_url_latin1 PASSED [ 16%] tests/test_html.py::GetBaseUrlTest::test_get_base_url_latin1_percent PASSED [ 17%] tests/test_html.py::GetBaseUrlTest::test_get_base_url_utf8 PASSED [ 17%] tests/test_html.py::GetBaseUrlTest::test_no_scheme_url PASSED [ 17%] tests/test_html.py::GetBaseUrlTest::test_relative_url_with_absolute_path PASSED [ 18%] tests/test_html.py::GetBaseUrlTest::test_tag_name PASSED [ 18%] tests/test_html.py::GetMetaRefreshTest::test_commented_meta_refresh PASSED [ 18%] tests/test_html.py::GetMetaRefreshTest::test_entities_in_redirect_url PASSED [ 19%] tests/test_html.py::GetMetaRefreshTest::test_float_refresh_intervals PASSED [ 19%] tests/test_html.py::GetMetaRefreshTest::test_get_meta_refresh PASSED [ 19%] tests/test_html.py::GetMetaRefreshTest::test_html_comments_with_uncommented_meta_refresh PASSED [ 20%] tests/test_html.py::GetMetaRefreshTest::test_inside_noscript PASSED [ 20%] tests/test_html.py::GetMetaRefreshTest::test_inside_script PASSED [ 20%] tests/test_html.py::GetMetaRefreshTest::test_leading_newline_in_url PASSED [ 21%] tests/test_html.py::GetMetaRefreshTest::test_multiline PASSED [ 21%] tests/test_html.py::GetMetaRefreshTest::test_nonascii_url_latin1 PASSED [ 21%] tests/test_html.py::GetMetaRefreshTest::test_nonascii_url_latin1_query PASSED [ 21%] tests/test_html.py::GetMetaRefreshTest::test_nonascii_url_utf8 PASSED [ 22%] tests/test_html.py::GetMetaRefreshTest::test_redirections_in_different_ordering__in_meta_tag PASSED [ 22%] tests/test_html.py::GetMetaRefreshTest::test_relative_redirects PASSED [ 22%] tests/test_html.py::GetMetaRefreshTest::test_tag_name PASSED [ 23%] tests/test_html.py::GetMetaRefreshTest::test_without_url PASSED [ 23%] tests/test_http.py::HttpTests::test_basic_auth_header PASSED [ 23%] tests/test_http.py::HttpTests::test_basic_auth_header_encoding PASSED [ 24%] tests/test_http.py::HttpTests::test_headers_dict_to_raw PASSED [ 24%] tests/test_http.py::HttpTests::test_headers_dict_to_raw_listtuple PASSED [ 24%] tests/test_http.py::HttpTests::test_headers_dict_to_raw_wrong_values PASSED [ 25%] tests/test_http.py::HttpTests::test_headers_raw_dict_none PASSED [ 25%] tests/test_http.py::HttpTests::test_headers_raw_to_dict PASSED [ 25%] tests/test_url.py::test_safe_url_string_encoding[None--ValueError] XFAIL [ 26%] tests/test_url.py::test_safe_url_string_encoding[None-https://example.com-https://example.com] PASSED [ 26%] tests/test_url.py::test_safe_url_string_encoding[None-https://example.com/\xa9-https://example.com/%C2%A9] PASSED [ 26%] tests/test_url.py::test_safe_url_string_encoding[iso-8859-1-https://example.com/\xa9-https://example.com/%C2%A9] PASSED [ 27%] tests/test_url.py::test_safe_url_string_encoding[iso-8859-1-a://example.com?\xa9-a://example.com?%C2%A9] XFAIL [ 27%] tests/test_url.py::test_safe_url_string_encoding[iso-8859-1-ws://example.com?\xa9-ws://example.com?%C2%A9] XFAIL [ 27%] tests/test_url.py::test_safe_url_string_encoding[iso-8859-1-wss://example.com?\xa9-wss://example.com?%C2%A9] XFAIL [ 28%] tests/test_url.py::test_safe_url_string_encoding[iso-8859-1-https://example.com?\xa9-https://example.com?%A9] PASSED [ 28%] tests/test_url.py::test_safe_url_string_encoding[iso-8859-1-file://example.com?\xa9-file://example.com?%A9] PASSED [ 28%] tests/test_url.py::test_safe_url_string_encoding[iso-8859-1-ftp://example.com?\xa9-ftp://example.com?%A9] PASSED [ 28%] tests/test_url.py::test_safe_url_string_encoding[iso-8859-1-http://example.com?\xa9-http://example.com?%A9] PASSED [ 29%] tests/test_url.py::test_safe_url_string_encoding[iso-8859-1-https://example.com#\xa9-https://example.com#%C2%A9] XFAIL [ 29%] tests/test_url.py::test_safe_url_string_url[1-Exception] PASSED [ 29%] tests/test_url.py::test_safe_url_string_url[url1-Exception] PASSED [ 30%] tests/test_url.py::test_safe_url_string_url[-ValueError] XFAIL [ 30%] tests/test_url.py::test_safe_url_string_url[\x00https://example.com\x00-https://example.com] PASSED [ 30%] tests/test_url.py::test_safe_url_string_url[\x01https://example.com\x01-https://example.com] PASSED [ 31%] tests/test_url.py::test_safe_url_string_url[\x02https://example.com\x02-https://example.com] PASSED [ 31%] tests/test_url.py::test_safe_url_string_url[\x03https://example.com\x03-https://example.com] PASSED [ 31%] tests/test_url.py::test_safe_url_string_url[\x04https://example.com\x04-https://example.com] PASSED [ 32%] tests/test_url.py::test_safe_url_string_url[\x05https://example.com\x05-https://example.com] PASSED [ 32%] tests/test_url.py::test_safe_url_string_url[\x06https://example.com\x06-https://example.com] PASSED [ 32%] tests/test_url.py::test_safe_url_string_url[\x07https://example.com\x07-https://example.com] PASSED [ 33%] tests/test_url.py::test_safe_url_string_url[\x08https://example.com\x08-https://example.com] PASSED [ 33%] tests/test_url.py::test_safe_url_string_url[\x0bhttps://example.com\x0b-https://example.com] PASSED [ 33%] tests/test_url.py::test_safe_url_string_url[\x0chttps://example.com\x0c-https://example.com] PASSED [ 34%] tests/test_url.py::test_safe_url_string_url[\x0ehttps://example.com\x0e-https://example.com] PASSED [ 34%] tests/test_url.py::test_safe_url_string_url[\x0fhttps://example.com\x0f-https://example.com] PASSED [ 34%] tests/test_url.py::test_safe_url_string_url[\x10https://example.com\x10-https://example.com] PASSED [ 35%] tests/test_url.py::test_safe_url_string_url[\x11https://example.com\x11-https://example.com] PASSED [ 35%] tests/test_url.py::test_safe_url_string_url[\x12https://example.com\x12-https://example.com] PASSED [ 35%] tests/test_url.py::test_safe_url_string_url[\x13https://example.com\x13-https://example.com] PASSED [ 35%] tests/test_url.py::test_safe_url_string_url[\x14https://example.com\x14-https://example.com] PASSED [ 36%] tests/test_url.py::test_safe_url_string_url[\x15https://example.com\x15-https://example.com] PASSED [ 36%] tests/test_url.py::test_safe_url_string_url[\x16https://example.com\x16-https://example.com] PASSED [ 36%] tests/test_url.py::test_safe_url_string_url[\x17https://example.com\x17-https://example.com] PASSED [ 37%] tests/test_url.py::test_safe_url_string_url[\x18https://example.com\x18-https://example.com] PASSED [ 37%] tests/test_url.py::test_safe_url_string_url[\x19https://example.com\x19-https://example.com] PASSED [ 37%] tests/test_url.py::test_safe_url_string_url[\x1ahttps://example.com\x1a-https://example.com] PASSED [ 38%] tests/test_url.py::test_safe_url_string_url[\x1bhttps://example.com\x1b-https://example.com] PASSED [ 38%] tests/test_url.py::test_safe_url_string_url[\x1chttps://example.com\x1c-https://example.com] PASSED [ 38%] tests/test_url.py::test_safe_url_string_url[\x1dhttps://example.com\x1d-https://example.com] PASSED [ 39%] tests/test_url.py::test_safe_url_string_url[\x1ehttps://example.com\x1e-https://example.com] PASSED [ 39%] tests/test_url.py::test_safe_url_string_url[\x1fhttps://example.com\x1f-https://example.com] PASSED [ 39%] tests/test_url.py::test_safe_url_string_url[ https://example.com -https://example.com] PASSED [ 40%] tests/test_url.py::test_safe_url_string_url[\t\n\rh\t\n\rttps\t\n\r:\t\n\r/\t\n\r/\t\n\ra\t\n\rb\t\n\r:\t\n\ra\t\n\rb\t\n\r@\t\n\rexam\t\n\rple.com\t\n\r:\t\n\r1\t\n\r2\t\n\r/\t\n\ra\t\n\rb\t\n\r?\t\n\ra\t\n\rb\t\n\r#\t\n\ra\t\n\rb\t\n\r-https://ab:ab@example.com:12/ab?ab#ab] PASSED [ 40%] tests/test_url.py::test_safe_url_string_url[abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ://example.com-abcdefghijklmnopqrstuvwxyzabcdefghijklmnopqrstuvwxyz://example.com] PASSED [ 40%] tests/test_url.py::test_safe_url_string_url[aabcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+-.://example.com-aabcdefghijklmnopqrstuvwxyzabcdefghijklmnopqrstuvwxyz0123456789+-.://example.com] PASSED [ 41%] tests/test_url.py::test_safe_url_string_url[://example.com-ValueError] XFAIL [ 41%] tests/test_url.py::test_safe_url_string_url[!://example.com-ValueError] XFAIL [ 41%] tests/test_url.py::test_safe_url_string_url["://example.com-ValueError] XFAIL [ 42%] tests/test_url.py::test_safe_url_string_url[#://example.com-ValueError] XFAIL [ 42%] tests/test_url.py::test_safe_url_string_url[$://example.com-ValueError] XFAIL [ 42%] tests/test_url.py::test_safe_url_string_url[%://example.com-ValueError] XFAIL [ 42%] tests/test_url.py::test_safe_url_string_url[&://example.com-ValueError] XFAIL [ 43%] tests/test_url.py::test_safe_url_string_url['://example.com-ValueError] XFAIL [ 43%] tests/test_url.py::test_safe_url_string_url[(://example.com-ValueError] XFAIL [ 43%] tests/test_url.py::test_safe_url_string_url[)://example.com-ValueError] XFAIL [ 44%] tests/test_url.py::test_safe_url_string_url[*://example.com-ValueError] XFAIL [ 44%] tests/test_url.py::test_safe_url_string_url[+://example.com-ValueError] XFAIL [ 44%] tests/test_url.py::test_safe_url_string_url[,://example.com-ValueError] XFAIL [ 45%] tests/test_url.py::test_safe_url_string_url[-://example.com-ValueError] XFAIL [ 45%] tests/test_url.py::test_safe_url_string_url[.://example.com-ValueError] XFAIL [ 45%] tests/test_url.py::test_safe_url_string_url[/://example.com-ValueError] XFAIL [ 46%] tests/test_url.py::test_safe_url_string_url[0://example.com-ValueError] XFAIL [ 46%] tests/test_url.py::test_safe_url_string_url[1://example.com-ValueError] XFAIL [ 46%] tests/test_url.py::test_safe_url_string_url[2://example.com-ValueError] XFAIL [ 47%] tests/test_url.py::test_safe_url_string_url[3://example.com-ValueError] XFAIL [ 47%] tests/test_url.py::test_safe_url_string_url[4://example.com-ValueError] XFAIL [ 47%] tests/test_url.py::test_safe_url_string_url[5://example.com-ValueError] XFAIL [ 48%] tests/test_url.py::test_safe_url_string_url[6://example.com-ValueError] XFAIL [ 48%] tests/test_url.py::test_safe_url_string_url[7://example.com-ValueError] XFAIL [ 48%] tests/test_url.py::test_safe_url_string_url[8://example.com-ValueError] XFAIL [ 49%] tests/test_url.py::test_safe_url_string_url[9://example.com-ValueError] XFAIL [ 49%] tests/test_url.py::test_safe_url_string_url[;://example.com-ValueError] XFAIL [ 49%] tests/test_url.py::test_safe_url_string_url[<://example.com-ValueError] XFAIL [ 50%] tests/test_url.py::test_safe_url_string_url[=://example.com-ValueError] XFAIL [ 50%] tests/test_url.py::test_safe_url_string_url[>://example.com-ValueError] XFAIL [ 50%] tests/test_url.py::test_safe_url_string_url[?://example.com-ValueError] XFAIL [ 50%] tests/test_url.py::test_safe_url_string_url[@://example.com-ValueError] XFAIL [ 51%] tests/test_url.py::test_safe_url_string_url[[://example.com-ValueError] XFAIL [ 51%] tests/test_url.py::test_safe_url_string_url[\\://example.com-ValueError] XFAIL [ 51%] tests/test_url.py::test_safe_url_string_url[]://example.com-ValueError] XFAIL [ 52%] tests/test_url.py::test_safe_url_string_url[^://example.com-ValueError] XFAIL [ 52%] tests/test_url.py::test_safe_url_string_url[_://example.com-ValueError] XFAIL [ 52%] tests/test_url.py::test_safe_url_string_url[`://example.com-ValueError] XFAIL [ 53%] tests/test_url.py::test_safe_url_string_url[{://example.com-ValueError] XFAIL [ 53%] tests/test_url.py::test_safe_url_string_url[|://example.com-ValueError] XFAIL [ 53%] tests/test_url.py::test_safe_url_string_url[}://example.com-ValueError] XFAIL [ 54%] tests/test_url.py::test_safe_url_string_url[~://example.com-ValueError] XFAIL [ 54%] tests/test_url.py::test_safe_url_string_url[\x7f://example.com-ValueError] XFAIL [ 54%] tests/test_url.py::test_safe_url_string_url[\x80://example.com-ValueError] XFAIL [ 55%] tests/test_url.py::test_safe_url_string_url[a!"#$%&'()*,/;<=>?@[\\]^_`{|}~\x7f\x80://example.com-ValueError] XFAIL [ 55%] tests/test_url.py::test_safe_url_string_url[https://a@example.com-https://a@example.com] PASSED [ 55%] tests/test_url.py::test_safe_url_string_url[https://a:@example.com-https://a:@example.com] PASSED [ 56%] tests/test_url.py::test_safe_url_string_url[https://a:a@example.com-https://a:a@example.com] PASSED [ 56%] tests/test_url.py::test_safe_url_string_url[https://a%3A@example.com-https://a%3A@example.com] PASSED [ 56%] tests/test_url.py::test_safe_url_string_url[https://abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789-_.!~*'()&+$,:abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789-_.!~*'()&+$,@example.com-https://abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789-_.!~*'()&+$,:abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789-_.!~*'()&+$,@example.com] PASSED [ 57%] tests/test_url.py::test_safe_url_string_url[https://"%;<=>@^`{|}\x7f:"%;<=>@^`{|}\x7f:@example.com-https://%22%25%3B%3C%3D%3E%40%5E%60%7B%7C%7D%7F:%22%25%3B%3C%3D%3E%40%5E%60%7B%7C%7D%7F%3A@example.com] PASSED [ 57%] tests/test_url.py::test_safe_url_string_url[https://@\\example.com-ValueError] XFAIL [ 57%] tests/test_url.py::test_safe_url_string_url[https://\x80:\x80@example.com-https://%C2%80:%C2%80@example.com] PASSED [ 57%] tests/test_url.py::test_safe_url_string_url[https://example.com-https://example.com] PASSED [ 58%] tests/test_url.py::test_safe_url_string_url[https://.example-https://.example] PASSED [ 58%] tests/test_url.py::test_safe_url_string_url[https://\x80.example-ValueError] XFAIL [ 58%] tests/test_url.py::test_safe_url_string_url[https://%80.example-ValueError] XFAIL [ 59%] tests/test_url.py::test_safe_url_string_url[https://aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa.example-https://aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa.example] PASSED [ 59%] tests/test_url.py::test_safe_url_string_url[https://aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa.example-https://aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa.example] PASSED [ 59%] tests/test_url.py::test_safe_url_string_url[https://aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa.aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa.aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa.aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa.example-https://aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa.aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa.aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa.aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa.example] PASSED [ 60%] tests/test_url.py::test_safe_url_string_url[https://aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa.aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa.aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa.aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa.example-https://aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa.aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa.aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa.aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa.example] PASSED [ 60%] tests/test_url.py::test_safe_url_string_url[https://\xf1.example-https://xn--ida.example] PASSED [ 60%] tests/test_url.py::test_safe_url_string_url[http://192.168.0.0-http://192.168.0.0] PASSED [ 61%] tests/test_url.py::test_safe_url_string_url[http://192.168.0.256-ValueError] XFAIL [ 61%] tests/test_url.py::test_safe_url_string_url[http://192.168.0.0.0-ValueError] XFAIL [ 61%] tests/test_url.py::test_safe_url_string_url[http://[2a01:5cc0:1:2::4]-http://[2a01:5cc0:1:2::4]] XFAIL [ 62%] tests/test_url.py::test_safe_url_string_url[http://[2a01:5cc0:1:2:3:4]-ValueError] PASSED [ 62%] tests/test_url.py::test_safe_url_string_url[https://example.com:-https://example.com:] XFAIL [ 62%] tests/test_url.py::test_safe_url_string_url[https://example.com:1-https://example.com:1] PASSED [ 63%] tests/test_url.py::test_safe_url_string_url[https://example.com:443-https://example.com:443] PASSED [ 63%] tests/test_url.py::test_safe_url_string_url[https://example.com/-https://example.com/] PASSED [ 63%] tests/test_url.py::test_safe_url_string_url[https://example.com/a-https://example.com/a] PASSED [ 64%] tests/test_url.py::test_safe_url_string_url[https://example.com\\a-https://example.com/a] XFAIL [ 64%] tests/test_url.py::test_safe_url_string_url[https://example.com/a\\b-https://example.com/a/b] XFAIL [ 64%] tests/test_url.py::test_safe_url_string_url[https://example.com/abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789-_.!~*'():@&=+$,/;-https://example.com/abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789-_.!~*'():@&=+$,/;] PASSED [ 64%] tests/test_url.py::test_safe_url_string_url[https://example.com/"%<>[]^`{|}\x7f-https://example.com/%22%25%3C%3E%5B%5D%5E%60%7B%7C%7D%7F] XFAIL [ 65%] tests/test_url.py::test_safe_url_string_url[https://example.com/\xf1-https://example.com/%C3%B1] PASSED [ 65%] tests/test_url.py::test_safe_url_string_url[https://example.com/\xf1%C3%B1-https://example.com/%C3%B1%C3%B1] PASSED [ 65%] tests/test_url.py::test_safe_url_string_url[https://example.com?-https://example.com?] XFAIL [ 66%] tests/test_url.py::test_safe_url_string_url[https://example.com/?-https://example.com/?] XFAIL [ 66%] tests/test_url.py::test_safe_url_string_url[https://example.com?a-https://example.com?a] PASSED [ 66%] tests/test_url.py::test_safe_url_string_url[https://example.com?a=-https://example.com?a=] PASSED [ 67%] tests/test_url.py::test_safe_url_string_url[https://example.com?a=b-https://example.com?a=b] PASSED [ 67%] tests/test_url.py::test_safe_url_string_url[a://example.com?abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789-_.!~*'():@&=+$,/;?-a://example.com?abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789-_.!~*'():@&=+$,/;?] PASSED [ 67%] tests/test_url.py::test_safe_url_string_url[a://example.com?"%<>[\\]^`{|}\x7f-a://example.com?%22%25%3C%3E%5B%5C%5D%5E%60%7B%7C%7D%7F] XFAIL [ 68%] tests/test_url.py::test_safe_url_string_url[https://example.com?abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789-_.!~*():@&=+$,/;?-https://example.com?abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789-_.!~*():@&=+$,/;?] PASSED [ 68%] tests/test_url.py::test_safe_url_string_url[file://example.com?abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789-_.!~*():@&=+$,/;?-file://example.com?abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789-_.!~*():@&=+$,/;?] PASSED [ 68%] tests/test_url.py::test_safe_url_string_url[ftp://example.com?abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789-_.!~*():@&=+$,/;?-ftp://example.com?abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789-_.!~*():@&=+$,/;?] PASSED [ 69%] tests/test_url.py::test_safe_url_string_url[http://example.com?abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789-_.!~*():@&=+$,/;?-http://example.com?abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789-_.!~*():@&=+$,/;?] PASSED [ 69%] tests/test_url.py::test_safe_url_string_url[wss://example.com?abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789-_.!~*():@&=+$,/;?-wss://example.com?abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789-_.!~*():@&=+$,/;?] PASSED [ 69%] tests/test_url.py::test_safe_url_string_url[ws://example.com?abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789-_.!~*():@&=+$,/;?-ws://example.com?abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789-_.!~*():@&=+$,/;?] PASSED [ 70%] tests/test_url.py::test_safe_url_string_url[https://example.com?"%'<>[\\]^`{|}\x7f-https://example.com?%22%25%27%3C%3E%5B%5C%5D%5E%60%7B%7C%7D%7F] XFAIL [ 70%] tests/test_url.py::test_safe_url_string_url[file://example.com?"%'<>[\\]^`{|}\x7f-file://example.com?%22%25%27%3C%3E%5B%5C%5D%5E%60%7B%7C%7D%7F] XFAIL [ 70%] tests/test_url.py::test_safe_url_string_url[ftp://example.com?"%'<>[\\]^`{|}\x7f-ftp://example.com?%22%25%27%3C%3E%5B%5C%5D%5E%60%7B%7C%7D%7F] XFAIL [ 71%] tests/test_url.py::test_safe_url_string_url[http://example.com?"%'<>[\\]^`{|}\x7f-http://example.com?%22%25%27%3C%3E%5B%5C%5D%5E%60%7B%7C%7D%7F] XFAIL [ 71%] tests/test_url.py::test_safe_url_string_url[wss://example.com?"%'<>[\\]^`{|}\x7f-wss://example.com?%22%25%27%3C%3E%5B%5C%5D%5E%60%7B%7C%7D%7F] XFAIL [ 71%] tests/test_url.py::test_safe_url_string_url[ws://example.com?"%'<>[\\]^`{|}\x7f-ws://example.com?%22%25%27%3C%3E%5B%5C%5D%5E%60%7B%7C%7D%7F] XFAIL [ 71%] tests/test_url.py::test_safe_url_string_url[https://example.com?\xf1-https://example.com?%C3%B1] PASSED [ 72%] tests/test_url.py::test_safe_url_string_url[https://example.com?\xf1%C3%B1-https://example.com?%C3%B1%C3%B1] PASSED [ 72%] tests/test_url.py::test_safe_url_string_url[https://example.com#-https://example.com#] XFAIL [ 72%] tests/test_url.py::test_safe_url_string_url[https://example.com/#-https://example.com/#] XFAIL [ 73%] tests/test_url.py::test_safe_url_string_url[https://example.com?#-https://example.com?#] XFAIL [ 73%] tests/test_url.py::test_safe_url_string_url[https://example.com/?#-https://example.com/?#] XFAIL [ 73%] tests/test_url.py::test_safe_url_string_url[https://example.com#a-https://example.com#a] PASSED [ 74%] tests/test_url.py::test_safe_url_string_url[a://example.com#abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789-_.!~*'():@&=+$,/;?-a://example.com#abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789-_.!~*'():@&=+$,/;?] PASSED [ 74%] tests/test_url.py::test_safe_url_string_url[a://example.com#"#%<>[\\]^`{|}\x7f-a://example.com#%22%23%25%3C%3E%5B%5C%5D%5E%60%7B%7C%7D%7F] XFAIL [ 74%] tests/test_url.py::test_safe_url_string_url[https://example.com#\xf1-https://example.com#%C3%B1] PASSED [ 75%] tests/test_url.py::test_safe_url_string_url[https://example.com#\xf1%C3%B1-https://example.com#%C3%B1%C3%B1] PASSED [ 75%] tests/test_url.py::test_safe_url_string_url[https://\xf1:\xf1@\xf1.example:1/\xf1?\xf1#\xf1-https://%C3%B1:%C3%B1@xn--ida.example:1/%C3%B1?%C3%B1#%C3%B1] PASSED [ 75%] tests/test_url.py::UrlTests::test_add_or_replace_parameter PASSED [ 76%] tests/test_url.py::UrlTests::test_add_or_replace_parameter_fail XFAIL [ 76%] tests/test_url.py::UrlTests::test_add_or_replace_parameters PASSED [ 76%] tests/test_url.py::UrlTests::test_add_or_replace_parameters_does_not_change_input_param PASSED [ 77%] tests/test_url.py::UrlTests::test_any_to_uri PASSED [ 77%] tests/test_url.py::UrlTests::test_file_uri_to_path PASSED [ 77%] tests/test_url.py::UrlTests::test_is_url PASSED [ 78%] tests/test_url.py::UrlTests::test_path_to_file_uri PASSED [ 78%] tests/test_url.py::UrlTests::test_safe_download_url PASSED [ 78%] tests/test_url.py::UrlTests::test_safe_url_idna PASSED [ 78%] tests/test_url.py::UrlTests::test_safe_url_idna_encoding_failure PASSED [ 79%] tests/test_url.py::UrlTests::test_safe_url_port_number PASSED [ 79%] tests/test_url.py::UrlTests::test_safe_url_string PASSED [ 79%] tests/test_url.py::UrlTests::test_safe_url_string_bytes_input PASSED [ 80%] tests/test_url.py::UrlTests::test_safe_url_string_bytes_input_nonutf8 PASSED [ 80%] tests/test_url.py::UrlTests::test_safe_url_string_encode_idna_domain_with_port PASSED [ 80%] tests/test_url.py::UrlTests::test_safe_url_string_encode_idna_domain_with_username_and_empty_password_and_port_number PASSED [ 81%] tests/test_url.py::UrlTests::test_safe_url_string_encode_idna_domain_with_username_password_and_port_number PASSED [ 81%] tests/test_url.py::UrlTests::test_safe_url_string_misc PASSED [ 81%] tests/test_url.py::UrlTests::test_safe_url_string_preserve_nonfragment_hash PASSED [ 82%] tests/test_url.py::UrlTests::test_safe_url_string_quote_path PASSED [ 82%] tests/test_url.py::UrlTests::test_safe_url_string_remove_ascii_tab_and_newlines PASSED [ 82%] tests/test_url.py::UrlTests::test_safe_url_string_user_and_pass_percentage_encoded PASSED [ 83%] tests/test_url.py::UrlTests::test_safe_url_string_userinfo_unsafe_chars PASSED [ 83%] tests/test_url.py::UrlTests::test_safe_url_string_with_query PASSED [ 83%] tests/test_url.py::UrlTests::test_url_query_cleaner PASSED [ 84%] tests/test_url.py::UrlTests::test_url_query_cleaner_keep_fragments PASSED [ 84%] tests/test_url.py::UrlTests::test_url_query_parameter PASSED [ 84%] tests/test_url.py::UrlTests::test_url_query_parameter_2 PASSED [ 85%] tests/test_url.py::CanonicalizeUrlTest::test_append_missing_path PASSED [ 85%] tests/test_url.py::CanonicalizeUrlTest::test_canonicalize_idns PASSED [ 85%] tests/test_url.py::CanonicalizeUrlTest::test_canonicalize_parse_url PASSED [ 85%] tests/test_url.py::CanonicalizeUrlTest::test_canonicalize_url PASSED [ 86%] tests/test_url.py::CanonicalizeUrlTest::test_canonicalize_url_idempotence PASSED [ 86%] tests/test_url.py::CanonicalizeUrlTest::test_canonicalize_url_idna_exceptions PASSED [ 86%] tests/test_url.py::CanonicalizeUrlTest::test_canonicalize_url_unicode_path PASSED [ 87%] tests/test_url.py::CanonicalizeUrlTest::test_canonicalize_url_unicode_query_string PASSED [ 87%] tests/test_url.py::CanonicalizeUrlTest::test_canonicalize_url_unicode_query_string_wrong_encoding PASSED [ 87%] tests/test_url.py::CanonicalizeUrlTest::test_canonicalize_urlparsed PASSED [ 88%] tests/test_url.py::CanonicalizeUrlTest::test_domains_are_case_insensitive PASSED [ 88%] tests/test_url.py::CanonicalizeUrlTest::test_dont_convert_safe_characters PASSED [ 88%] tests/test_url.py::CanonicalizeUrlTest::test_keep_blank_values PASSED [ 89%] tests/test_url.py::CanonicalizeUrlTest::test_non_ascii_percent_encoding_in_paths PASSED [ 89%] tests/test_url.py::CanonicalizeUrlTest::test_non_ascii_percent_encoding_in_query_arguments PASSED [ 89%] tests/test_url.py::CanonicalizeUrlTest::test_normalize_percent_encoding_in_paths PASSED [ 90%] tests/test_url.py::CanonicalizeUrlTest::test_normalize_percent_encoding_in_query_arguments PASSED [ 90%] tests/test_url.py::CanonicalizeUrlTest::test_port_number PASSED [ 90%] tests/test_url.py::CanonicalizeUrlTest::test_preserve_nonfragment_hash PASSED [ 91%] tests/test_url.py::CanonicalizeUrlTest::test_quoted_slash_and_question_sign PASSED [ 91%] tests/test_url.py::CanonicalizeUrlTest::test_remove_fragments PASSED [ 91%] tests/test_url.py::CanonicalizeUrlTest::test_return_str PASSED [ 92%] tests/test_url.py::CanonicalizeUrlTest::test_safe_characters_unicode PASSED [ 92%] tests/test_url.py::CanonicalizeUrlTest::test_sorting PASSED [ 92%] tests/test_url.py::CanonicalizeUrlTest::test_spaces PASSED [ 92%] tests/test_url.py::CanonicalizeUrlTest::test_strip_spaces PASSED [ 93%] tests/test_url.py::CanonicalizeUrlTest::test_typical_usage PASSED [ 93%] tests/test_url.py::CanonicalizeUrlTest::test_urls_with_auth_and_ports PASSED [ 93%] tests/test_url.py::DataURITests::test_base64 PASSED [ 94%] tests/test_url.py::DataURITests::test_base64_spaces PASSED [ 94%] tests/test_url.py::DataURITests::test_bytes_uri PASSED [ 94%] tests/test_url.py::DataURITests::test_default_mediatype PASSED [ 95%] tests/test_url.py::DataURITests::test_default_mediatype_charset PASSED [ 95%] tests/test_url.py::DataURITests::test_mediatype_parameters PASSED [ 95%] tests/test_url.py::DataURITests::test_missing_comma PASSED [ 96%] tests/test_url.py::DataURITests::test_missing_scheme PASSED [ 96%] tests/test_url.py::DataURITests::test_scheme_case_insensitive PASSED [ 96%] tests/test_url.py::DataURITests::test_text_charset PASSED [ 97%] tests/test_url.py::DataURITests::test_text_uri PASSED [ 97%] tests/test_url.py::DataURITests::test_unicode_uri PASSED [ 97%] tests/test_url.py::DataURITests::test_wrong_base64_param PASSED [ 98%] tests/test_url.py::DataURITests::test_wrong_scheme PASSED [ 98%] tests/test_util.py::StrToUnicodeTestCase::test_deprecation PASSED [ 98%] tests/test_util.py::ToBytesTestCase::test_type_error PASSED [ 99%] tests/test_util.py::ToNativeStrTestCase::test_deprecation PASSED [ 99%] tests/test_util.py::ToUnicodeTestCase::test_type_error PASSED [ 99%] tests/test_util.py::UnicodeToStrTestCase::test_deprecation PASSED [100%] ======================= 238 passed, 76 xfailed in 5.03s ======================== >>> py3-w3lib: Entering fakeroot... >>> py3-w3lib-pyc*: Running split function pyc... '/home/buildozer/aports/community/py3-w3lib/pkg/py3-w3lib/usr/lib/python3.12/site-packages/w3lib/__pycache__' -> '/home/buildozer/aports/community/py3-w3lib/pkg/py3-w3lib-pyc/usr/lib/python3.12/site-packages/w3lib/__pycache__' >>> py3-w3lib-pyc*: Preparing subpackage py3-w3lib-pyc... >>> py3-w3lib-pyc*: Running postcheck for py3-w3lib-pyc >>> py3-w3lib*: Running postcheck for py3-w3lib >>> py3-w3lib*: Preparing package py3-w3lib... >>> py3-w3lib-pyc*: Tracing dependencies... python3 python3~3.12 >>> py3-w3lib-pyc*: Package size: 108.0 KB >>> py3-w3lib-pyc*: Compressing data... >>> py3-w3lib-pyc*: Create checksum... >>> py3-w3lib-pyc*: Create py3-w3lib-pyc-2.1.2-r1.apk >>> py3-w3lib*: Tracing dependencies... python3 python3~3.12 >>> py3-w3lib*: Package size: 120.0 KB >>> py3-w3lib*: Compressing data... >>> py3-w3lib*: Create checksum... >>> py3-w3lib*: Create py3-w3lib-2.1.2-r1.apk >>> py3-w3lib: Build complete at Wed, 01 May 2024 03:11:08 +0000 elapsed time 0h 0m 12s >>> py3-w3lib: Cleaning up srcdir >>> py3-w3lib: Cleaning up pkgdir >>> py3-w3lib: Uninstalling dependencies... (1/33) Purging .makedepends-py3-w3lib (20240501.031100) (2/33) Purging py3-setuptools-pyc (69.5.1-r0) (3/33) Purging py3-setuptools (69.5.1-r0) (4/33) Purging py3-gpep517-pyc (15-r2) (5/33) Purging py3-gpep517 (15-r2) (6/33) Purging py3-installer-pyc (0.7.0-r2) (7/33) Purging py3-installer (0.7.0-r2) (8/33) Purging py3-wheel-pyc (0.42.0-r1) (9/33) Purging py3-wheel (0.42.0-r1) (10/33) Purging py3-pytest-pyc (8.1.1-r1) (11/33) Purging py3-pytest (8.1.1-r1) (12/33) Purging py3-iniconfig-pyc (2.0.0-r1) (13/33) Purging py3-iniconfig (2.0.0-r1) (14/33) Purging py3-packaging-pyc (24.0-r1) (15/33) Purging py3-packaging (24.0-r1) (16/33) Purging py3-parsing-pyc (3.1.2-r1) (17/33) Purging py3-parsing (3.1.2-r1) (18/33) Purging py3-pluggy-pyc (1.4.0-r1) (19/33) Purging py3-pluggy (1.4.0-r1) (20/33) Purging py3-py-pyc (1.11.0-r3) (21/33) Purging py3-py (1.11.0-r3) (22/33) Purging python3-pyc (3.12.3-r1) (23/33) Purging python3-pycache-pyc0 (3.12.3-r1) (24/33) Purging pyc (3.12.3-r1) (25/33) Purging python3 (3.12.3-r1) (26/33) Purging gdbm (1.23-r1) (27/33) Purging libbz2 (1.0.8-r6) (28/33) Purging libffi (3.4.6-r0) (29/33) Purging libpanelw (6.4_p20240330-r0) (30/33) Purging mpdecimal (4.0.0-r0) (31/33) Purging readline (8.2.10-r0) (32/33) Purging sqlite-libs (3.45.3-r0) (33/33) Purging xz-libs (5.6.1-r3) Executing busybox-1.36.1-r26.trigger OK: 472 MiB in 107 packages >>> py3-w3lib: Updating the community/x86_64 repository index... >>> py3-w3lib: Signing the index...