2025-08-31T02:50:14,761 Created temporary directory: /tmp/pip-build-tracker-rjtkpqfh 2025-08-31T02:50:14,763 Initialized build tracking at /tmp/pip-build-tracker-rjtkpqfh 2025-08-31T02:50:14,763 Created build tracker: /tmp/pip-build-tracker-rjtkpqfh 2025-08-31T02:50:14,764 Entered build tracker: /tmp/pip-build-tracker-rjtkpqfh 2025-08-31T02:50:14,765 Created temporary directory: /tmp/pip-wheel-bkyrzelf 2025-08-31T02:50:14,769 Created temporary directory: /tmp/pip-ephem-wheel-cache-270_fly7 2025-08-31T02:50:14,818 Looking in indexes: https://pypi.org/simple, https://www.piwheels.org/simple 2025-08-31T02:50:14,821 2 location(s) to search for versions of keypractice: 2025-08-31T02:50:14,821 * https://pypi.org/simple/keypractice/ 2025-08-31T02:50:14,821 * https://www.piwheels.org/simple/keypractice/ 2025-08-31T02:50:14,822 Fetching project page and analyzing links: https://pypi.org/simple/keypractice/ 2025-08-31T02:50:14,823 Getting page https://pypi.org/simple/keypractice/ 2025-08-31T02:50:14,825 Found index url https://pypi.org/simple/ 2025-08-31T02:50:14,974 Fetched page https://pypi.org/simple/keypractice/ as application/vnd.pypi.simple.v1+json 2025-08-31T02:50:14,977 Skipping link: No binaries permitted for keypractice: https://files.pythonhosted.org/packages/8e/9a/80ab456c8e1451141d4d8933832de2d414987c74e07f99be38f3c057e869/keypractice-0.1.0-py3-none-any.whl (from https://pypi.org/simple/keypractice/) (requires-python:>=3.7) 2025-08-31T02:50:14,978 Found link https://files.pythonhosted.org/packages/aa/0a/973e767d20888c4ccfd73f66a1f711c0e48a0d6e3981704af201b5a0f49c/keypractice-0.1.0.tar.gz (from https://pypi.org/simple/keypractice/) (requires-python:>=3.7), version: 0.1.0 2025-08-31T02:50:14,979 Skipping link: No binaries permitted for keypractice: https://files.pythonhosted.org/packages/b2/a3/014d98ca4e3b1c3303e23cc8e9bc6fa262a23c1547d103709fc5093d8795/keypractice-0.1.2-py3-none-any.whl (from https://pypi.org/simple/keypractice/) (requires-python:>=3.7) 2025-08-31T02:50:14,979 Found link https://files.pythonhosted.org/packages/1d/fe/db431c26803b413f14942d061dd1df8f843a605a98f57277edeacba8886c/keypractice-0.1.2.tar.gz (from https://pypi.org/simple/keypractice/) (requires-python:>=3.7), version: 0.1.2 2025-08-31T02:50:14,980 Skipping link: No binaries permitted for keypractice: https://files.pythonhosted.org/packages/d0/bc/81513fb55b596fff4eca44139ed31d958b2abbab45ddb4847ec2131ea17f/keypractice-0.1.3-py3-none-any.whl (from https://pypi.org/simple/keypractice/) (requires-python:>=3.7) 2025-08-31T02:50:14,981 Found link https://files.pythonhosted.org/packages/6d/a8/25ef70ed9f5d8b3000955d9e54a54794e343508e190f1cd365f59d629b71/keypractice-0.1.3.tar.gz (from https://pypi.org/simple/keypractice/) (requires-python:>=3.7), version: 0.1.3 2025-08-31T02:50:14,981 Skipping link: No binaries permitted for keypractice: https://files.pythonhosted.org/packages/14/e0/b431db39531c2696844f65ae537010a31156329391b3bc2d8eb8d63df4ed/keypractice-0.1.4-py3-none-any.whl (from https://pypi.org/simple/keypractice/) (requires-python:>=3.7) 2025-08-31T02:50:14,982 Found link https://files.pythonhosted.org/packages/b7/ab/1bdbfce911b90057fc786993ee5dc1b299f54a32141aeed887a314450785/keypractice-0.1.4.tar.gz (from https://pypi.org/simple/keypractice/) (requires-python:>=3.7), version: 0.1.4 2025-08-31T02:50:14,983 Skipping link: No binaries permitted for keypractice: https://files.pythonhosted.org/packages/71/e9/eb0ed79c8f47dd512471b0fc5a38b92baba3c1030fb414d5d1187a4ecf67/keypractice-0.1.5-py3-none-any.whl (from https://pypi.org/simple/keypractice/) (requires-python:>=3.7) 2025-08-31T02:50:14,983 Found link https://files.pythonhosted.org/packages/36/28/a34cc4506dd354e27ce5c1a162976f25c81f3bda09e1e4bc1bdcb4634306/keypractice-0.1.5.tar.gz (from https://pypi.org/simple/keypractice/) (requires-python:>=3.7), version: 0.1.5 2025-08-31T02:50:14,984 Skipping link: No binaries permitted for keypractice: https://files.pythonhosted.org/packages/21/af/1ef9d80988c538092fd52e3515b06efde5b4421d62c2a8fcdf86d0736e74/keypractice-0.1.6-py3-none-any.whl (from https://pypi.org/simple/keypractice/) (requires-python:>=3.7) 2025-08-31T02:50:14,984 Found link https://files.pythonhosted.org/packages/dc/91/74b36ef47718cc6a94c063c33dc755fe55d240e75256a46f24270e38d9fb/keypractice-0.1.6.tar.gz (from https://pypi.org/simple/keypractice/) (requires-python:>=3.7), version: 0.1.6 2025-08-31T02:50:14,985 Skipping link: No binaries permitted for keypractice: https://files.pythonhosted.org/packages/68/0d/719584943b450aaf94bf6ba30281ad95849a9205567e48d560702b70841c/keypractice-0.1.7-py3-none-any.whl (from https://pypi.org/simple/keypractice/) (requires-python:>=3.7) 2025-08-31T02:50:14,986 Found link https://files.pythonhosted.org/packages/78/57/c30e76b1e8ac848a922db8cd71a6756514987560f392ace183de380ebc98/keypractice-0.1.7.tar.gz (from https://pypi.org/simple/keypractice/) (requires-python:>=3.7), version: 0.1.7 2025-08-31T02:50:14,986 Skipping link: No binaries permitted for keypractice: https://files.pythonhosted.org/packages/45/44/0d53300c12eeca30b67cb99660e5eb2f915c6ffd0bc43e86352d11256ccd/keypractice-0.1.8-py3-none-any.whl (from https://pypi.org/simple/keypractice/) (requires-python:>=3.7) 2025-08-31T02:50:14,987 Found link https://files.pythonhosted.org/packages/05/76/8708bd1f64781506a0829dbb4ce72985266a79238841c0f145e9514692ff/keypractice-0.1.8.tar.gz (from https://pypi.org/simple/keypractice/) (requires-python:>=3.7), version: 0.1.8 2025-08-31T02:50:14,988 Skipping link: No binaries permitted for keypractice: https://files.pythonhosted.org/packages/73/c8/e2caa2c47780fa8564042f6b0ff11a02f8a30e24cff42b695ede41ba9ed8/keypractice-0.1.9-py3-none-any.whl (from https://pypi.org/simple/keypractice/) (requires-python:>=3.7) 2025-08-31T02:50:14,988 Found link https://files.pythonhosted.org/packages/f6/74/989f43f3361fb38406674efb7a42918e6fd0ceda4186ad4d54edf9785ccd/keypractice-0.1.9.tar.gz (from https://pypi.org/simple/keypractice/) (requires-python:>=3.7), version: 0.1.9 2025-08-31T02:50:14,989 Skipping link: No binaries permitted for keypractice: https://files.pythonhosted.org/packages/ae/6b/6486d8ddafb8afe8f837dfa5acc4608faa14f7dc6bae9c8ab3b348664f09/keypractice-0.1.10-py3-none-any.whl (from https://pypi.org/simple/keypractice/) (requires-python:>=3.7) 2025-08-31T02:50:14,989 Found link https://files.pythonhosted.org/packages/6a/a3/d495f6e8bdc4b97192df5ccf03b7c8abef2b2f5c1bb8c8d65438cf586c01/keypractice-0.1.10.tar.gz (from https://pypi.org/simple/keypractice/) (requires-python:>=3.7), version: 0.1.10 2025-08-31T02:50:14,990 Skipping link: No binaries permitted for keypractice: https://files.pythonhosted.org/packages/17/47/77ad8987baaddae0fa69618b9a01397133bd29c88057aadc08b7f6f16266/keypractice-0.1.11-py3-none-any.whl (from https://pypi.org/simple/keypractice/) (requires-python:>=3.7) 2025-08-31T02:50:14,990 Found link https://files.pythonhosted.org/packages/e6/be/97696e0f9e74b19138a1e335f791c006fc544414b762176c2de84ea2f8b6/keypractice-0.1.11.tar.gz (from https://pypi.org/simple/keypractice/) (requires-python:>=3.7), version: 0.1.11 2025-08-31T02:50:14,991 Fetching project page and analyzing links: https://www.piwheels.org/simple/keypractice/ 2025-08-31T02:50:14,992 Getting page https://www.piwheels.org/simple/keypractice/ 2025-08-31T02:50:14,993 Found index url https://www.piwheels.org/simple/ 2025-08-31T02:50:15,156 Fetched page https://www.piwheels.org/simple/keypractice/ as text/html 2025-08-31T02:50:15,159 Skipping link: No binaries permitted for keypractice: https://www.piwheels.org/simple/keypractice/keypractice-0.1.6-py3-none-any.whl#sha256=35c839923c69e957a49e1bdf419fecaed0abfb0ed08596fa4943777877450760 (from https://www.piwheels.org/simple/keypractice/) (requires-python:>=3.7) 2025-08-31T02:50:15,160 Skipping link: No binaries permitted for keypractice: https://www.piwheels.org/simple/keypractice/keypractice-0.1.5-py3-none-any.whl#sha256=0c87d6cbefc51963e6cd122e4ca58853e0f690edd66734497b596b58ca3362d2 (from https://www.piwheels.org/simple/keypractice/) (requires-python:>=3.7) 2025-08-31T02:50:15,160 Skipping link: No binaries permitted for keypractice: https://www.piwheels.org/simple/keypractice/keypractice-0.1.4-py3-none-any.whl#sha256=526155d7572583ac35efe4cb3dbb4456426f4d1b9a70c6d8c10456b62b0940e7 (from https://www.piwheels.org/simple/keypractice/) (requires-python:>=3.7) 2025-08-31T02:50:15,161 Skipping link: No binaries permitted for keypractice: https://www.piwheels.org/simple/keypractice/keypractice-0.1.3-py3-none-any.whl#sha256=315b13756b89907eeb178ed8ac8496990083a5a3c05354eb4fd61203be292906 (from https://www.piwheels.org/simple/keypractice/) (requires-python:>=3.7) 2025-08-31T02:50:15,162 Skipping link: No binaries permitted for keypractice: https://www.piwheels.org/simple/keypractice/keypractice-0.1.2-py3-none-any.whl#sha256=76e811b93b1b8df9123367c220d9be3004cd73fc4724ecff26556dedaade5425 (from https://www.piwheels.org/simple/keypractice/) (requires-python:>=3.7) 2025-08-31T02:50:15,162 Skipping link: No binaries permitted for keypractice: https://www.piwheels.org/simple/keypractice/keypractice-0.1.0-py3-none-any.whl#sha256=e7e5be8c6eb852aec045993cf26e52593256669118d9bc2d9aa2847e6e1c3522 (from https://www.piwheels.org/simple/keypractice/) (requires-python:>=3.7) 2025-08-31T02:50:15,163 Skipping link: not a file: https://www.piwheels.org/simple/keypractice/ 2025-08-31T02:50:15,163 Skipping link: not a file: https://pypi.org/simple/keypractice/ 2025-08-31T02:50:15,181 Given no hashes to check 1 links for project 'keypractice': discarding no candidates 2025-08-31T02:50:15,183 Collecting keypractice==0.1.8 2025-08-31T02:50:15,186 Created temporary directory: /tmp/pip-unpack-hdes_c4q 2025-08-31T02:50:15,404 Downloading keypractice-0.1.8.tar.gz (5.0 kB) 2025-08-31T02:50:15,449 Added keypractice==0.1.8 from https://files.pythonhosted.org/packages/05/76/8708bd1f64781506a0829dbb4ce72985266a79238841c0f145e9514692ff/keypractice-0.1.8.tar.gz to build tracker '/tmp/pip-build-tracker-rjtkpqfh' 2025-08-31T02:50:15,450 Running setup.py (path:/tmp/pip-wheel-bkyrzelf/keypractice_181329928b9348c6b5cd966df5aca267/setup.py) egg_info for package keypractice 2025-08-31T02:50:15,452 Created temporary directory: /tmp/pip-pip-egg-info-k6t7bh4m 2025-08-31T02:50:15,452 Preparing metadata (setup.py): started 2025-08-31T02:50:15,453 Running command python setup.py egg_info 2025-08-31T02:50:16,337 running egg_info 2025-08-31T02:50:16,367 creating /tmp/pip-pip-egg-info-k6t7bh4m/keypractice.egg-info 2025-08-31T02:50:16,368 writing /tmp/pip-pip-egg-info-k6t7bh4m/keypractice.egg-info/PKG-INFO 2025-08-31T02:50:16,372 writing dependency_links to /tmp/pip-pip-egg-info-k6t7bh4m/keypractice.egg-info/dependency_links.txt 2025-08-31T02:50:16,373 writing entry points to /tmp/pip-pip-egg-info-k6t7bh4m/keypractice.egg-info/entry_points.txt 2025-08-31T02:50:16,375 writing requirements to /tmp/pip-pip-egg-info-k6t7bh4m/keypractice.egg-info/requires.txt 2025-08-31T02:50:16,376 writing top-level names to /tmp/pip-pip-egg-info-k6t7bh4m/keypractice.egg-info/top_level.txt 2025-08-31T02:50:16,378 writing manifest file '/tmp/pip-pip-egg-info-k6t7bh4m/keypractice.egg-info/SOURCES.txt' 2025-08-31T02:50:16,470 reading manifest file '/tmp/pip-pip-egg-info-k6t7bh4m/keypractice.egg-info/SOURCES.txt' 2025-08-31T02:50:16,472 reading manifest template 'MANIFEST.in' 2025-08-31T02:50:16,477 writing manifest file '/tmp/pip-pip-egg-info-k6t7bh4m/keypractice.egg-info/SOURCES.txt' 2025-08-31T02:50:16,581 Preparing metadata (setup.py): finished with status 'done' 2025-08-31T02:50:16,585 Source in /tmp/pip-wheel-bkyrzelf/keypractice_181329928b9348c6b5cd966df5aca267 has version 0.1.8, which satisfies requirement keypractice==0.1.8 from https://files.pythonhosted.org/packages/05/76/8708bd1f64781506a0829dbb4ce72985266a79238841c0f145e9514692ff/keypractice-0.1.8.tar.gz 2025-08-31T02:50:16,586 Removed keypractice==0.1.8 from https://files.pythonhosted.org/packages/05/76/8708bd1f64781506a0829dbb4ce72985266a79238841c0f145e9514692ff/keypractice-0.1.8.tar.gz from build tracker '/tmp/pip-build-tracker-rjtkpqfh' 2025-08-31T02:50:16,592 Created temporary directory: /tmp/pip-unpack-u33q0h9c 2025-08-31T02:50:16,594 Created temporary directory: /tmp/pip-unpack-dxgxifoy 2025-08-31T02:50:16,595 Building wheels for collected packages: keypractice 2025-08-31T02:50:16,600 Created temporary directory: /tmp/pip-wheel-hkbkjw30 2025-08-31T02:50:16,600 DEPRECATION: Building 'keypractice' using the legacy setup.py bdist_wheel mechanism, which will be removed in a future version. pip 25.3 will enforce this behaviour change. A possible replacement is to use the standardized build interface by setting the `--use-pep517` option, (possibly combined with `--no-build-isolation`), or adding a `pyproject.toml` file to the source tree of 'keypractice'. Discussion can be found at https://github.com/pypa/pip/issues/6334 2025-08-31T02:50:16,602 Building wheel for keypractice (setup.py): started 2025-08-31T02:50:16,603 Destination directory: /tmp/pip-wheel-hkbkjw30 2025-08-31T02:50:16,603 Running command python setup.py bdist_wheel 2025-08-31T02:50:17,483 running bdist_wheel 2025-08-31T02:50:17,625 running build 2025-08-31T02:50:17,625 running build_py 2025-08-31T02:50:17,657 creating build/lib/keypractice 2025-08-31T02:50:17,660 copying keypractice/analytics.py -> build/lib/keypractice 2025-08-31T02:50:17,663 copying keypractice/__init__.py -> build/lib/keypractice 2025-08-31T02:50:17,665 copying keypractice/core.py -> build/lib/keypractice 2025-08-31T02:50:17,667 copying keypractice/__main__.py -> build/lib/keypractice 2025-08-31T02:50:17,669 running egg_info 2025-08-31T02:50:17,698 writing keypractice.egg-info/PKG-INFO 2025-08-31T02:50:17,701 writing dependency_links to keypractice.egg-info/dependency_links.txt 2025-08-31T02:50:17,703 writing entry points to keypractice.egg-info/entry_points.txt 2025-08-31T02:50:17,704 writing requirements to keypractice.egg-info/requires.txt 2025-08-31T02:50:17,706 writing top-level names to keypractice.egg-info/top_level.txt 2025-08-31T02:50:17,738 reading manifest file 'keypractice.egg-info/SOURCES.txt' 2025-08-31T02:50:17,741 reading manifest template 'MANIFEST.in' 2025-08-31T02:50:17,746 writing manifest file 'keypractice.egg-info/SOURCES.txt' 2025-08-31T02:50:17,748 /usr/local/lib/python3.11/dist-packages/setuptools/command/build_py.py:212: _Warning: Package 'keypractice.data' is absent from the `packages` configuration. 2025-08-31T02:50:17,749 !! 2025-08-31T02:50:17,750 ******************************************************************************** 2025-08-31T02:50:17,750 ############################ 2025-08-31T02:50:17,751 # Package would be ignored # 2025-08-31T02:50:17,751 ############################ 2025-08-31T02:50:17,752 Python recognizes 'keypractice.data' as an importable package[^1], 2025-08-31T02:50:17,753 but it is absent from setuptools' `packages` configuration. 2025-08-31T02:50:17,753 This leads to an ambiguous overall configuration. If you want to distribute this 2025-08-31T02:50:17,754 package, please make sure that 'keypractice.data' is explicitly added 2025-08-31T02:50:17,754 to the `packages` configuration field. 2025-08-31T02:50:17,756 Alternatively, you can also rely on setuptools' discovery methods 2025-08-31T02:50:17,756 (for example by using `find_namespace_packages(...)`/`find_namespace:` 2025-08-31T02:50:17,757 instead of `find_packages(...)`/`find:`). 2025-08-31T02:50:17,758 You can read more about "package discovery" on setuptools documentation page: 2025-08-31T02:50:17,759 - https://setuptools.pypa.io/en/latest/userguide/package_discovery.html 2025-08-31T02:50:17,760 If you don't want 'keypractice.data' to be distributed and are 2025-08-31T02:50:17,761 already explicitly excluding 'keypractice.data' via 2025-08-31T02:50:17,762 `find_namespace_packages(...)/find_namespace` or `find_packages(...)/find`, 2025-08-31T02:50:17,762 you can try to use `exclude_package_data`, or `include-package-data=False` in 2025-08-31T02:50:17,763 combination with a more fine grained `package-data` configuration. 2025-08-31T02:50:17,764 You can read more about "package data files" on setuptools documentation page: 2025-08-31T02:50:17,765 - https://setuptools.pypa.io/en/latest/userguide/datafiles.html 2025-08-31T02:50:17,766 [^1]: For Python, any directory (with suitable naming) can be imported, 2025-08-31T02:50:17,767 even if it does not contain any `.py` files. 2025-08-31T02:50:17,767 On the other hand, currently there is no concept of package data 2025-08-31T02:50:17,768 directory, all directories are treated like packages. 2025-08-31T02:50:17,768 ******************************************************************************** 2025-08-31T02:50:17,769 !! 2025-08-31T02:50:17,770 check.warn(importable) 2025-08-31T02:50:17,770 creating build/lib/keypractice/data 2025-08-31T02:50:17,771 copying keypractice/data/analytics.json -> build/lib/keypractice/data 2025-08-31T02:50:17,785 /usr/local/lib/python3.11/dist-packages/setuptools/_distutils/cmd.py:90: SetuptoolsDeprecationWarning: setup.py install is deprecated. 2025-08-31T02:50:17,786 !! 2025-08-31T02:50:17,787 ******************************************************************************** 2025-08-31T02:50:17,788 Please avoid running ``setup.py`` directly. 2025-08-31T02:50:17,788 Instead, use pypa/build, pypa/installer or other 2025-08-31T02:50:17,789 standards-based tools. 2025-08-31T02:50:17,790 By 2025-Oct-31, you need to update your project and remove deprecated calls 2025-08-31T02:50:17,790 or your builds will no longer be supported. 2025-08-31T02:50:17,791 See https://blog.ganssle.io/articles/2021/10/setup-py-deprecated.html for details. 2025-08-31T02:50:17,792 ******************************************************************************** 2025-08-31T02:50:17,793 !! 2025-08-31T02:50:17,794 self.initialize_options() 2025-08-31T02:50:17,819 installing to build/bdist.linux-armv7l/wheel 2025-08-31T02:50:17,819 running install 2025-08-31T02:50:17,843 running install_lib 2025-08-31T02:50:17,872 creating build/bdist.linux-armv7l/wheel 2025-08-31T02:50:17,875 creating build/bdist.linux-armv7l/wheel/keypractice 2025-08-31T02:50:17,876 copying build/lib/keypractice/analytics.py -> build/bdist.linux-armv7l/wheel/./keypractice 2025-08-31T02:50:17,879 copying build/lib/keypractice/__init__.py -> build/bdist.linux-armv7l/wheel/./keypractice 2025-08-31T02:50:17,881 copying build/lib/keypractice/core.py -> build/bdist.linux-armv7l/wheel/./keypractice 2025-08-31T02:50:17,883 creating build/bdist.linux-armv7l/wheel/keypractice/data 2025-08-31T02:50:17,885 copying build/lib/keypractice/data/analytics.json -> build/bdist.linux-armv7l/wheel/./keypractice/data 2025-08-31T02:50:17,887 copying build/lib/keypractice/__main__.py -> build/bdist.linux-armv7l/wheel/./keypractice 2025-08-31T02:50:17,889 running install_egg_info 2025-08-31T02:50:17,925 Copying keypractice.egg-info to build/bdist.linux-armv7l/wheel/./keypractice-0.1.8-py3.11.egg-info 2025-08-31T02:50:17,938 running install_scripts 2025-08-31T02:50:17,951 creating build/bdist.linux-armv7l/wheel/keypractice-0.1.8.dist-info/WHEEL 2025-08-31T02:50:17,954 creating '/tmp/pip-wheel-hkbkjw30/keypractice-0.1.8-py3-none-any.whl' and adding 'build/bdist.linux-armv7l/wheel' to it 2025-08-31T02:50:17,956 adding 'keypractice/__init__.py' 2025-08-31T02:50:17,958 adding 'keypractice/__main__.py' 2025-08-31T02:50:17,959 adding 'keypractice/analytics.py' 2025-08-31T02:50:17,961 adding 'keypractice/core.py' 2025-08-31T02:50:17,963 adding 'keypractice/data/analytics.json' 2025-08-31T02:50:17,965 adding 'keypractice-0.1.8.dist-info/METADATA' 2025-08-31T02:50:17,966 adding 'keypractice-0.1.8.dist-info/WHEEL' 2025-08-31T02:50:17,967 adding 'keypractice-0.1.8.dist-info/entry_points.txt' 2025-08-31T02:50:17,968 adding 'keypractice-0.1.8.dist-info/top_level.txt' 2025-08-31T02:50:17,969 adding 'keypractice-0.1.8.dist-info/RECORD' 2025-08-31T02:50:17,970 removing build/bdist.linux-armv7l/wheel 2025-08-31T02:50:18,080 Building wheel for keypractice (setup.py): finished with status 'done' 2025-08-31T02:50:18,086 Created wheel for keypractice: filename=keypractice-0.1.8-py3-none-any.whl size=5482 sha256=4afcc9f3359e3418c38ce4efd68a9b95bc5019d487cca82e6a783e83721d8520 2025-08-31T02:50:18,087 Stored in directory: /tmp/pip-ephem-wheel-cache-270_fly7/wheels/0a/21/e2/149dd1ef4056ba49b5b0d9dc8475d9a56fa6d6bc3ede26a6c7 2025-08-31T02:50:18,097 Successfully built keypractice 2025-08-31T02:50:18,101 Removed build tracker: '/tmp/pip-build-tracker-rjtkpqfh'