-
-
Notifications
You must be signed in to change notification settings - Fork 3.6k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Build: allow partial override of build steps #11710
Merged
Merged
Changes from 9 commits
Commits
Show all changes
20 commits
Select commit
Hold shift + click to select a range
3b947be
Build: allow partial override of build steps
stsewd 004a3aa
Fix tests
stsewd 3a61248
Update schema
stsewd 39d25e5
Merge branch 'main' into build-override
stsewd 6228aeb
Tests
stsewd 6cd3ad7
Tests
stsewd 0034f53
Test empty overrides
stsewd 8cc5421
Maybe is tox?
stsewd 8e0c438
Updates from review
stsewd 82877fa
Merge branch 'main' into build-override
stsewd 3ef8fe6
Allow formats with build.jobs.build.*
stsewd d4b53b8
Merge branch 'main' into build-override
stsewd 5a8a52e
Remove unused variable
stsewd 890552d
Format
stsewd 806ff86
Use old method for now
stsewd 0c5fea8
Use conditional
stsewd c8cba44
Move all actions to their method
stsewd c0b463c
Unused variable
stsewd 1edef9c
Merge branch 'main' into build-override
stsewd f22413d
Fix
stsewd File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -16,6 +16,7 @@ | |
from .find import find_one | ||
from .models import ( | ||
BuildJobs, | ||
BuildJobsBuildTypes, | ||
BuildTool, | ||
BuildWithOs, | ||
Conda, | ||
|
@@ -101,6 +102,9 @@ def __init__(self, raw_config, source_file, base_path=None): | |
|
||
self._config = {} | ||
|
||
self.is_using_build_commands = False | ||
self.is_using_build_jobs = False | ||
|
||
@contextmanager | ||
def catch_validation_error(self, key): | ||
"""Catch a ``ConfigValidationError`` and raises a ``ConfigError`` error.""" | ||
|
@@ -175,10 +179,6 @@ def validate(self): | |
def is_using_conda(self): | ||
return self.python_interpreter in ("conda", "mamba") | ||
|
||
@property | ||
def is_using_build_commands(self): | ||
return self.build.commands != [] | ||
|
||
@property | ||
def is_using_setup_py_install(self): | ||
"""Check if this project is using `setup.py install` as installation method.""" | ||
|
@@ -250,6 +250,7 @@ def validate(self): | |
self._config["sphinx"] = self.validate_sphinx() | ||
self._config["submodules"] = self.validate_submodules() | ||
self._config["search"] = self.validate_search() | ||
self.validate_incompatible_keys() | ||
self.validate_keys() | ||
|
||
def validate_formats(self): | ||
|
@@ -318,11 +319,9 @@ def validate_build_config_with_os(self): | |
# ones, we could validate the value of each of them is a list of | ||
# commands. However, I don't think we should validate the "command" | ||
# looks like a real command. | ||
valid_jobs = list(BuildJobs.model_fields.keys()) | ||
for job in jobs.keys(): | ||
validate_choice( | ||
job, | ||
BuildJobs.__slots__, | ||
) | ||
validate_choice(job, valid_jobs) | ||
|
||
commands = [] | ||
with self.catch_validation_error("build.commands"): | ||
|
@@ -345,7 +344,20 @@ def validate_build_config_with_os(self): | |
}, | ||
) | ||
|
||
if commands: | ||
self.is_using_build_commands = True | ||
else: | ||
self.is_using_build_jobs = True | ||
|
||
build["jobs"] = {} | ||
|
||
with self.catch_validation_error("build.jobs.build"): | ||
build["jobs"]["build"] = self.validate_build_jobs_build(jobs) | ||
# Remove the build.jobs.build key from the build.jobs dict, | ||
# since it's the only key that should be a dictionary, | ||
# it was already validated above. | ||
jobs.pop("build", None) | ||
|
||
for job, job_commands in jobs.items(): | ||
with self.catch_validation_error(f"build.jobs.{job}"): | ||
build["jobs"][job] = [ | ||
|
@@ -370,6 +382,29 @@ def validate_build_config_with_os(self): | |
build["apt_packages"] = self.validate_apt_packages() | ||
return build | ||
|
||
def validate_build_jobs_build(self, build_jobs): | ||
# The build.jobs.build key is optional. | ||
if "build" not in build_jobs: | ||
return None | ||
|
||
result = {} | ||
build_jobs_build = build_jobs["build"] | ||
validate_dict(build_jobs_build) | ||
|
||
if not "html" in build_jobs_build: | ||
raise ConfigError(message_id=ConfigError.HTML_BUILD_STEP_REQUIRED) | ||
|
||
allowed_build_types = list(BuildJobsBuildTypes.model_fields.keys()) | ||
for build_type, build_commands in build_jobs_build.items(): | ||
validate_choice(build_type, allowed_build_types) | ||
with self.catch_validation_error(f"build.jobs.build.{build_type}"): | ||
result[build_type] = [ | ||
validate_string(build_command) | ||
for build_command in validate_list(build_commands) | ||
] | ||
|
||
return result | ||
|
||
def validate_apt_packages(self): | ||
apt_packages = [] | ||
with self.catch_validation_error("build.apt_packages"): | ||
|
@@ -692,6 +727,15 @@ def validate_search(self): | |
|
||
return search | ||
|
||
def validate_incompatible_keys(self): | ||
# `formats` and `build.jobs.build.*` can't be used together. | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I would remove this restriction. It seems pretty common to use the default PDF builder (via |
||
build_overridden = ( | ||
self.is_using_build_jobs and self.build.jobs.build is not None | ||
) | ||
with self.catch_validation_error("formats"): | ||
if build_overridden and "formats" in self.source_config: | ||
raise ConfigError(message_id=ConfigError.FORMATS_AND_BUILD_JOBS_BUILD) | ||
|
||
def validate_keys(self): | ||
""" | ||
Checks that we don't have extra keys (invalid ones). | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.
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.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think
build.jobs.build.html
shouldn't be mandatory. That means that users cannot override only any of the other formats likebuild.jobs.build.pdf
orbuild.jobs.build.epub
.