narrow protobuf dependencies to exclude protobuf >= 4 #2720
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
This is a stop-gap until the generated code can be updated with a newer
version of protoc, as required by the protobuf 4.x release.
Description
protobuf
4.x requires that the generated files be generated with a newer version of protoc than has been used.This is a historical breakage (i.e. affects previously released versions), so this is a simple fix that could be trivially backported to previous releases if desired.
Many existing
protobuf
dependencies are already more-tightly defined, so I didn't touch those.Fixes #2717
Type of change
Please delete options that are not relevant.
How Has This Been Tested?
Pip test
In a clean venv, install the changed packages and force protobuf>4 (i.e. the incompatible version)
This succeeds in main.
With this PR, the same command fails (as expected)
Note that right now, this test must explicitly specify
protobuf>4
because the protobuf 4.x release package has been yanked, so it's no longer selected by default. Had this not been done, the test for this PR would have successfully installed, but chosen an earlier version of protobuf.Does This PR Require a Contrib Repo Change?
There's a matching PR at open-telemetry/opentelemetry-python-contrib#1109 though.
Checklist: