Skip to content

Loading rules_python should not depend on known python versions #3633

@mdorner

Description

@mdorner

🐞 bug report

Affected Rule

The issue is caused by the rule:

python = use_extension("@rules_python//python/extensions:python.bzl", "python")

Loading python seems to check the system python version. This makes it impossible to use rules_python if the version is not in its version dict:

        File "$BUILD/external/rules_python+/python/private/python_register_toolchains.bzl", line 106, column 31, in python_register_toolchains
                sha256 = tool_versions[python_version]["sha256"].get(platform, None)
Error: key "3.14.0b2" not found in dictionary
ERROR: Analysis of target '@@rules_python+//python/bin:repl' failed; build aborted: 
  error evaluating module extension @@rules_python+//python/extensions:python.bzl%python

Note that this happens when loading the python extension, which is required to configure the python version, creating a catch 22.

Is this a regression?

I have found other occurrences (1,2) of the error message (as below) but I don't think it was traced to this before. It it likely a regression that happens every now and then when some python version gets a weird id and due to the hard coded map of versions in rules_python.

Description

Nothing that depends on rules_python builds. Simplest example
bazel run @rules_python//python/bin:repl

🔬 Minimal Reproduction

This depends on your system python, so it may be best to reproduce in a container. I am running Manjaro with python up to date. The exact python version is 3.14.2 (main, Jan 2 2026, 14:27:39) [GCC 15.2.1 20251112].

Relevant package information (from pacman -Qi python):


Name            : python
Version         : 3.14.2-2
Architecture    : x86_64
Build Date      : Fri 02 Jan 2026 03:27:39 PM CET
Install Date    : Wed 11 Feb 2026 10:13:47 PM CET

Here's my entire python MODULE.bazel setup section (tried older versions of rules_python as well):


bazel_dep(name = "rules_python", version = "1.9.0-rc0")

python = use_extension("@rules_python//python/extensions:python.bzl", "python")
python.toolchain(
    python_version = "3.13",
)
use_repo(python, "python_toolchains")
register_toolchains("@python_toolchains//:all")

🔥 Exception or Error


$ bazel run @rules_python//python/bin:repl 
Starting local Bazel server (8.5.1) and connecting to it...
ERROR: $BUILD/external/rules_python+/python/private/python_register_toolchains.bzl:106:31: Traceback (most recent call last):
        File "$BUILD/external/rules_python+/python/private/python.bzl", line 273, column 53, in _python_impl
                register_result = python_register_toolchains(
        File "$BUILD/external/rules_python+/python/private/python_register_toolchains.bzl", line 106, column 31, in python_register_toolchains
                sha256 = tool_versions[python_version]["sha256"].get(platform, None)
Error: key "3.14.0b2" not found in dictionary
ERROR: Analysis of target '@@rules_python+//python/bin:repl' failed; build aborted: error evaluating module extension @@rules_python+//python/extensions:python.bzl%python

The expectation would be that the unknown python version is ignored as long as a valid python version is configured via python.toolchain(version=$KNOWN_VERSION}). Whatever else depends on the system python version before is quite likely an isolation failure wrt. reproducibility.

🌍 Your Environment

Operating System:
Linux $HOSTNAME 6.18.8-1-MANJARO #1 SMP PREEMPT_DYNAMIC Fri, 30 Jan 2026 23:06:21 +0000 x86_64 GNU/Linux

Output of bazel version:
bazel 8.5.1

Confirmed on 9.0.0 as well

Rules_python version:
1.9.0-rc0, 1.84.0

Anything else relevant?

Metadata

Metadata

Assignees

No one assigned

    Type

    No type

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions