2026-03-13T20:26:58,730 Created temporary directory: /tmp/pip-ephem-wheel-cache-kol4rdcc 2026-03-13T20:26:58,731 Created temporary directory: /tmp/pip-build-tracker-rrdd3271 2026-03-13T20:26:58,732 Initialized build tracking at /tmp/pip-build-tracker-rrdd3271 2026-03-13T20:26:58,733 Created build tracker: /tmp/pip-build-tracker-rrdd3271 2026-03-13T20:26:58,733 Entered build tracker: /tmp/pip-build-tracker-rrdd3271 2026-03-13T20:26:58,734 Created temporary directory: /tmp/pip-wheel-gjy7n5q5 2026-03-13T20:26:58,737 DEPRECATION: --no-binary currently disables reading from the cache of locally built wheels. In the future --no-binary will not influence the wheel cache. pip 23.1 will enforce this behaviour change. A possible replacement is to use the --no-cache-dir option. You can use the flag --use-feature=no-binary-enable-wheel-cache to test the upcoming behaviour. Discussion can be found at https://github.com/pypa/pip/issues/11453 2026-03-13T20:26:58,739 Created temporary directory: /tmp/pip-ephem-wheel-cache-cbjo5950 2026-03-13T20:26:58,763 Looking in indexes: https://pypi.org/simple, https://www.piwheels.org/simple 2026-03-13T20:26:58,767 2 location(s) to search for versions of crowdsourcehinter-xblock: 2026-03-13T20:26:58,767 * https://pypi.org/simple/crowdsourcehinter-xblock/ 2026-03-13T20:26:58,767 * https://www.piwheels.org/simple/crowdsourcehinter-xblock/ 2026-03-13T20:26:58,768 Fetching project page and analyzing links: https://pypi.org/simple/crowdsourcehinter-xblock/ 2026-03-13T20:26:58,768 Getting page https://pypi.org/simple/crowdsourcehinter-xblock/ 2026-03-13T20:26:58,770 Found index url https://pypi.org/simple 2026-03-13T20:26:58,979 Fetched page https://pypi.org/simple/crowdsourcehinter-xblock/ as application/vnd.pypi.simple.v1+json 2026-03-13T20:26:58,982 Found link https://files.pythonhosted.org/packages/e3/a2/7ee8e9d5c11e4ceb3eb74d43dae997296b18cf4ffaa0e29133d306b53ee7/crowdsourcehinter-xblock-0.6.tar.gz (from https://pypi.org/simple/crowdsourcehinter-xblock/), version: 0.6 2026-03-13T20:26:58,983 Skipping link: No binaries permitted for crowdsourcehinter-xblock: https://files.pythonhosted.org/packages/91/4d/a6a177ad4018d59ddb1284da7676cbe2946bf09ec5e155005bbb36c92499/crowdsourcehinter_xblock-0.6-py3-none-any.whl (from https://pypi.org/simple/crowdsourcehinter-xblock/) 2026-03-13T20:26:58,983 Found link https://files.pythonhosted.org/packages/f7/c9/424df7f25fe8140266f179a689d12e3f24f5f144c017e1925a2b0d5a76c5/crowdsourcehinter-xblock-0.7.tar.gz (from https://pypi.org/simple/crowdsourcehinter-xblock/), version: 0.7 2026-03-13T20:26:58,984 Skipping link: No binaries permitted for crowdsourcehinter-xblock: https://files.pythonhosted.org/packages/43/83/d59d97ef60e5d3c43dcb6fc77fad7984acae63f6af22d7ad265165b0937c/crowdsourcehinter_xblock-0.7-py3-none-any.whl (from https://pypi.org/simple/crowdsourcehinter-xblock/) 2026-03-13T20:26:58,985 Skipping link: No binaries permitted for crowdsourcehinter-xblock: https://files.pythonhosted.org/packages/51/5a/227f247132fd4406ccfd75c31ed4ef6d3e7fe7b28a01ef3ccdbc007da249/crowdsourcehinter_xblock-0.8-py3-none-any.whl (from https://pypi.org/simple/crowdsourcehinter-xblock/) 2026-03-13T20:26:58,986 Found link https://files.pythonhosted.org/packages/59/57/f0255fd6ae745cd2af8784caea866f3a18c45c4fbd4574a18396e71c757f/crowdsourcehinter_xblock-0.8.tar.gz (from https://pypi.org/simple/crowdsourcehinter-xblock/), version: 0.8 2026-03-13T20:26:58,986 Skipping link: No binaries permitted for crowdsourcehinter-xblock: https://files.pythonhosted.org/packages/f4/13/4f5576d7e9ab9b5a178e383ce2987da747c654bf7c9d3f5c3ad6c22d397b/crowdsourcehinter_xblock-1.0.0-py3-none-any.whl (from https://pypi.org/simple/crowdsourcehinter-xblock/) 2026-03-13T20:26:58,987 Found link https://files.pythonhosted.org/packages/18/cc/4d9733ae1e7b8606b16a7e3cf31f9a6a79f5d28f0503a2fccf5171bb3a3e/crowdsourcehinter_xblock-1.0.0.tar.gz (from https://pypi.org/simple/crowdsourcehinter-xblock/), version: 1.0.0 2026-03-13T20:26:58,988 Fetching project page and analyzing links: https://www.piwheels.org/simple/crowdsourcehinter-xblock/ 2026-03-13T20:26:58,989 Getting page https://www.piwheels.org/simple/crowdsourcehinter-xblock/ 2026-03-13T20:26:58,990 Found index url https://www.piwheels.org/simple 2026-03-13T20:26:59,141 Fetched page https://www.piwheels.org/simple/crowdsourcehinter-xblock/ as text/html 2026-03-13T20:26:59,143 Skipping link: No binaries permitted for crowdsourcehinter-xblock: https://archive1.piwheels.org/simple/crowdsourcehinter-xblock/crowdsourcehinter_xblock-0.6-py3-none-any.whl#sha256=3682f88bf3b076e1087b93ca374287c805801ad352f81f1d6832f85504b0bb0f (from https://www.piwheels.org/simple/crowdsourcehinter-xblock/) 2026-03-13T20:26:59,143 Skipping link: not a file: https://www.piwheels.org/simple/crowdsourcehinter-xblock/ 2026-03-13T20:26:59,144 Skipping link: not a file: https://pypi.org/simple/crowdsourcehinter-xblock/ 2026-03-13T20:26:59,164 Given no hashes to check 1 links for project 'crowdsourcehinter-xblock': discarding no candidates 2026-03-13T20:26:59,184 Collecting crowdsourcehinter-xblock==1.0.0 2026-03-13T20:26:59,186 Created temporary directory: /tmp/pip-unpack-5cp2bkd7 2026-03-13T20:26:59,321 Downloading crowdsourcehinter_xblock-1.0.0.tar.gz (285 kB) 2026-03-13T20:26:59,482 Added crowdsourcehinter-xblock==1.0.0 from https://files.pythonhosted.org/packages/18/cc/4d9733ae1e7b8606b16a7e3cf31f9a6a79f5d28f0503a2fccf5171bb3a3e/crowdsourcehinter_xblock-1.0.0.tar.gz to build tracker '/tmp/pip-build-tracker-rrdd3271' 2026-03-13T20:26:59,484 Running setup.py (path:/tmp/pip-wheel-gjy7n5q5/crowdsourcehinter-xblock_44a52e19376745408d7e1e0292400fdc/setup.py) egg_info for package crowdsourcehinter-xblock 2026-03-13T20:26:59,484 Created temporary directory: /tmp/pip-pip-egg-info-g1uwnh6h 2026-03-13T20:26:59,485 Preparing metadata (setup.py): started 2026-03-13T20:26:59,486 Running command python setup.py egg_info 2026-03-13T20:27:00,022 Traceback (most recent call last): 2026-03-13T20:27:00,022 File "", line 2, in 2026-03-13T20:27:00,023 File "", line 34, in 2026-03-13T20:27:00,023 File "/tmp/pip-wheel-gjy7n5q5/crowdsourcehinter-xblock_44a52e19376745408d7e1e0292400fdc/setup.py", line 119, in 2026-03-13T20:27:00,024 install_requires=load_requirements('requirements/base.in'), 2026-03-13T20:27:00,025 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2026-03-13T20:27:00,026 File "/tmp/pip-wheel-gjy7n5q5/crowdsourcehinter-xblock_44a52e19376745408d7e1e0292400fdc/setup.py", line 62, in load_requirements 2026-03-13T20:27:00,027 with open(path) as reqs: 2026-03-13T20:27:00,028 ^^^^^^^^^^ 2026-03-13T20:27:00,029 FileNotFoundError: [Errno 2] No such file or directory: 'requirements/base.in' 2026-03-13T20:27:00,092 ERROR: [present-rich] python setup.py egg_info exited with 1 2026-03-13T20:27:00,105 [bold magenta]full command[/]: [blue]/usr/bin/python3 -c ' 2026-03-13T20:27:00,105 exec(compile('"'"''"'"''"'"' 2026-03-13T20:27:00,105 # This is -- a caller that pip uses to run setup.py 2026-03-13T20:27:00,105 # 2026-03-13T20:27:00,105 # - It imports setuptools before invoking setup.py, to enable projects that directly 2026-03-13T20:27:00,105 # import from `distutils.core` to work with newer packaging standards. 2026-03-13T20:27:00,105 # - It provides a clear error message when setuptools is not installed. 2026-03-13T20:27:00,105 # - It sets `sys.argv[0]` to the underlying `setup.py`, when invoking `setup.py` so 2026-03-13T20:27:00,105 # setuptools doesn'"'"'t think the script is `-c`. This avoids the following warning: 2026-03-13T20:27:00,105 # manifest_maker: standard file '"'"'-c'"'"' not found". 2026-03-13T20:27:00,105 # - It generates a shim setup.py, for handling setup.cfg-only projects. 2026-03-13T20:27:00,105 import os, sys, tokenize 2026-03-13T20:27:00,105 2026-03-13T20:27:00,105 try: 2026-03-13T20:27:00,105 import setuptools 2026-03-13T20:27:00,105 except ImportError as error: 2026-03-13T20:27:00,105 print( 2026-03-13T20:27:00,105 "ERROR: Can not execute `setup.py` since setuptools is not available in " 2026-03-13T20:27:00,105 "the build environment.", 2026-03-13T20:27:00,105 file=sys.stderr, 2026-03-13T20:27:00,105 ) 2026-03-13T20:27:00,105 sys.exit(1) 2026-03-13T20:27:00,105 2026-03-13T20:27:00,105 __file__ = %r 2026-03-13T20:27:00,105 sys.argv[0] = __file__ 2026-03-13T20:27:00,105 2026-03-13T20:27:00,105 if os.path.exists(__file__): 2026-03-13T20:27:00,105 filename = __file__ 2026-03-13T20:27:00,105 with tokenize.open(__file__) as f: 2026-03-13T20:27:00,105 setup_py_code = f.read() 2026-03-13T20:27:00,105 else: 2026-03-13T20:27:00,105 filename = "" 2026-03-13T20:27:00,105 setup_py_code = "from setuptools import setup; setup()" 2026-03-13T20:27:00,105 2026-03-13T20:27:00,105 exec(compile(setup_py_code, filename, "exec")) 2026-03-13T20:27:00,105 '"'"''"'"''"'"' % ('"'"'/tmp/pip-wheel-gjy7n5q5/crowdsourcehinter-xblock_44a52e19376745408d7e1e0292400fdc/setup.py'"'"',), "", "exec"))' egg_info --egg-base /tmp/pip-pip-egg-info-g1uwnh6h[/] 2026-03-13T20:27:00,105 [bold magenta]cwd[/]: /tmp/pip-wheel-gjy7n5q5/crowdsourcehinter-xblock_44a52e19376745408d7e1e0292400fdc/ 2026-03-13T20:27:00,106 Preparing metadata (setup.py): finished with status 'error' 2026-03-13T20:27:00,107 ERROR: [present-rich] metadata generation failed 2026-03-13T20:27:00,113 Exception information: 2026-03-13T20:27:00,113 Traceback (most recent call last): 2026-03-13T20:27:00,113 File "/usr/lib/python3/dist-packages/pip/_internal/operations/build/metadata_legacy.py", line 64, in generate_metadata 2026-03-13T20:27:00,113 call_subprocess( 2026-03-13T20:27:00,113 File "/usr/lib/python3/dist-packages/pip/_internal/utils/subprocess.py", line 224, in call_subprocess 2026-03-13T20:27:00,113 raise error 2026-03-13T20:27:00,113 pip._internal.exceptions.InstallationSubprocessError: python setup.py egg_info exited with 1 2026-03-13T20:27:00,113 2026-03-13T20:27:00,113 The above exception was the direct cause of the following exception: 2026-03-13T20:27:00,113 2026-03-13T20:27:00,113 Traceback (most recent call last): 2026-03-13T20:27:00,113 File "/usr/lib/python3/dist-packages/pip/_internal/cli/base_command.py", line 160, in exc_logging_wrapper 2026-03-13T20:27:00,113 status = run_func(*args) 2026-03-13T20:27:00,113 ^^^^^^^^^^^^^^^ 2026-03-13T20:27:00,113 File "/usr/lib/python3/dist-packages/pip/_internal/cli/req_command.py", line 247, in wrapper 2026-03-13T20:27:00,113 return func(self, options, args) 2026-03-13T20:27:00,113 ^^^^^^^^^^^^^^^^^^^^^^^^^ 2026-03-13T20:27:00,113 File "/usr/lib/python3/dist-packages/pip/_internal/commands/wheel.py", line 170, in run 2026-03-13T20:27:00,113 requirement_set = resolver.resolve(reqs, check_supported_wheels=True) 2026-03-13T20:27:00,113 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2026-03-13T20:27:00,113 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/resolver.py", line 92, in resolve 2026-03-13T20:27:00,113 result = self._result = resolver.resolve( 2026-03-13T20:27:00,113 ^^^^^^^^^^^^^^^^^ 2026-03-13T20:27:00,113 File "/usr/lib/python3/dist-packages/pip/_vendor/resolvelib/resolvers.py", line 481, in resolve 2026-03-13T20:27:00,113 state = resolution.resolve(requirements, max_rounds=max_rounds) 2026-03-13T20:27:00,113 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2026-03-13T20:27:00,113 File "/usr/lib/python3/dist-packages/pip/_vendor/resolvelib/resolvers.py", line 348, in resolve 2026-03-13T20:27:00,113 self._add_to_criteria(self.state.criteria, r, parent=None) 2026-03-13T20:27:00,113 File "/usr/lib/python3/dist-packages/pip/_vendor/resolvelib/resolvers.py", line 172, in _add_to_criteria 2026-03-13T20:27:00,113 if not criterion.candidates: 2026-03-13T20:27:00,113 File "/usr/lib/python3/dist-packages/pip/_vendor/resolvelib/structs.py", line 151, in __bool__ 2026-03-13T20:27:00,113 return bool(self._sequence) 2026-03-13T20:27:00,113 ^^^^^^^^^^^^^^^^^^^^ 2026-03-13T20:27:00,113 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/found_candidates.py", line 155, in __bool__ 2026-03-13T20:27:00,113 return any(self) 2026-03-13T20:27:00,113 ^^^^^^^^^ 2026-03-13T20:27:00,113 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/found_candidates.py", line 143, in 2026-03-13T20:27:00,113 return (c for c in iterator if id(c) not in self._incompatible_ids) 2026-03-13T20:27:00,113 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2026-03-13T20:27:00,113 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/found_candidates.py", line 47, in _iter_built 2026-03-13T20:27:00,113 candidate = func() 2026-03-13T20:27:00,113 ^^^^^^ 2026-03-13T20:27:00,113 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/factory.py", line 206, in _make_candidate_from_link 2026-03-13T20:27:00,113 self._link_candidate_cache[link] = LinkCandidate( 2026-03-13T20:27:00,113 ^^^^^^^^^^^^^^ 2026-03-13T20:27:00,113 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/candidates.py", line 297, in __init__ 2026-03-13T20:27:00,113 super().__init__( 2026-03-13T20:27:00,113 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/candidates.py", line 162, in __init__ 2026-03-13T20:27:00,113 self.dist = self._prepare() 2026-03-13T20:27:00,113 ^^^^^^^^^^^^^^^ 2026-03-13T20:27:00,113 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/candidates.py", line 231, in _prepare 2026-03-13T20:27:00,113 dist = self._prepare_distribution() 2026-03-13T20:27:00,113 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2026-03-13T20:27:00,113 File "/usr/lib/python3/dist-packages/pip/_internal/resolution/resolvelib/candidates.py", line 308, in _prepare_distribution 2026-03-13T20:27:00,113 return preparer.prepare_linked_requirement(self._ireq, parallel_builds=True) 2026-03-13T20:27:00,113 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2026-03-13T20:27:00,113 File "/usr/lib/python3/dist-packages/pip/_internal/operations/prepare.py", line 491, in prepare_linked_requirement 2026-03-13T20:27:00,113 return self._prepare_linked_requirement(req, parallel_builds) 2026-03-13T20:27:00,113 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2026-03-13T20:27:00,113 File "/usr/lib/python3/dist-packages/pip/_internal/operations/prepare.py", line 577, in _prepare_linked_requirement 2026-03-13T20:27:00,113 dist = _get_prepared_distribution( 2026-03-13T20:27:00,113 ^^^^^^^^^^^^^^^^^^^^^^^^^^^ 2026-03-13T20:27:00,113 File "/usr/lib/python3/dist-packages/pip/_internal/operations/prepare.py", line 69, in _get_prepared_distribution 2026-03-13T20:27:00,113 abstract_dist.prepare_distribution_metadata( 2026-03-13T20:27:00,113 File "/usr/lib/python3/dist-packages/pip/_internal/distributions/sdist.py", line 61, in prepare_distribution_metadata 2026-03-13T20:27:00,113 self.req.prepare_metadata() 2026-03-13T20:27:00,113 File "/usr/lib/python3/dist-packages/pip/_internal/req/req_install.py", line 545, in prepare_metadata 2026-03-13T20:27:00,113 self.metadata_directory = generate_metadata_legacy( 2026-03-13T20:27:00,113 ^^^^^^^^^^^^^^^^^^^^^^^^^ 2026-03-13T20:27:00,113 File "/usr/lib/python3/dist-packages/pip/_internal/operations/build/metadata_legacy.py", line 71, in generate_metadata 2026-03-13T20:27:00,113 raise MetadataGenerationFailed(package_details=details) from error 2026-03-13T20:27:00,113 pip._internal.exceptions.MetadataGenerationFailed: metadata generation failed 2026-03-13T20:27:00,126 Removed crowdsourcehinter-xblock==1.0.0 from https://files.pythonhosted.org/packages/18/cc/4d9733ae1e7b8606b16a7e3cf31f9a6a79f5d28f0503a2fccf5171bb3a3e/crowdsourcehinter_xblock-1.0.0.tar.gz from build tracker '/tmp/pip-build-tracker-rrdd3271' 2026-03-13T20:27:00,127 Removed build tracker: '/tmp/pip-build-tracker-rrdd3271'