The ergonomic and hermetic software build system for Python, Java, Scala, Go, and Shell. Pants lets you fearlessly scale up your codebase.
Project description
Pants is an Apache2 licensed build tool written in Python and Rust.
The latest documentation can be found at pantsbuild.org.
2.16.x Release Series
What's New
BUILD files
The new env function in BUILD files allows access to environment variables in BUILD files.
Run pants help symbols for documentation of all builtin symbols and macros provided by prelude files
which are usable in BUILD files.
The visibility rules syntax now supports matching on target names. The rules glob syntax also now uses the same syntax as target selectors.
Backends
Docker
The {pants.hash}
generation code was changed such that the generated hash for the same input will be different in pants 2.16.
Python
The Python backend added or improved support for various tools including:
-
pydocstyleis now supported for linting Python doc strings. Enable thepants.backend.python.lint.pydocstylebackend to add this support. -
ruffis now supported for linting and formatting Python code. Enable thepants.backend.experimental.python.lint.ruffbackend to add this support. -
pyenvis now supported as a way for Pants to provide a hermetic version of Python for each relevant Interpreter required to run user code. Enable thepants.backend.python.providers.experimental.pyenvbackend to add this support. -
Pants now understands how to parse dependencies of projects using the OpenStack/Stevedore ((https://github.com/openstack/stevedore) project. Enable the
pants.backend.python.framework.stevedorebackend to add this support. -
More Python target types now have the
environmentfield and thus can execute in non-local environments.
Deprecations:
-
The default value of
CPython>=3.7,<4for the[python].interpreter_constraintsoption is now deprecated and will be removed in Pants v2.17.x. This options sets Python interpreter constraints for Python-related targets which did not otherwise specify their own interpreter constraints. Instead of relying on this default, explicitly set the[python].interpreter_constraintsoption appropriately. We recommend constraining to a single interpreter minor version if you can, e.g.,interpreter_constraints = ['==3.11.*'], or at least a small number of interpreter minor versions, e.g.,interpreter_constraints = ['>=3.10,<3.12']. -
The special Python "tool lockfile" functionality is deprecated. Repos can now use regular "user lockfiles" to provide custom versions of tools.
Shell command improvements and support for ad-hoc tools
The Shell backend along with the new pants.backend.experimental.adhoc backend have received a number of improvements so that
Pants is able to invoke workflows that include tools for which Pants does not yet have a
dedicated backend.
In recognition of these improvements, the experimental_shell_command and experimental_run_shell_command target
types have graduated to no longer have the experimental_ prefix; use shell_command and run_shell_command
respectively instead.
The improvements include:
-
The
shell_commandcontinues to provide a way to run a tool for its side effects and capture outputs from the tool invocation for consumption as dependencies by other target types, but has had several improvements:- the
dependenciesfield has been deprecated, and separated into three fields:execution_dependenciesfor dependencies required to execute the command,output_dependenciesfor dependencies required to use the output, andrunnable_dependenciesfor targets that need to exist as directly executable on the sandbox'sPATH - the
outputsfield has been separated intooutput_filesandoutput_directories - the directory in which the command is invoked can be controlled via the new
workdirfield - the location of the output files when consumed as a dependency can be controlled via the new
root_output_directoryfield
- the
-
Preserving symlinks as symlinks in process output, rather than resolving them to their target file. This eliminates the need for work-arounds in
shell_commands that happen to generate semantically-relevant symlinks, such as the contents ofnode_modules/.binif usingshell_commandto invokenpm ciornpm install. -
The new
adhoc_tooltarget type supplied by theadhocbackend allows executing most "runnable" target types (those supported forpants rungoal) exported by another Pants backend in an execution sandbox goal, allowing you to capture their outputs to be captured. The outputs can then be consumed by another Pants target in a similar manner to theshell_commandtarget type. "Runnable" target types include:- Adhoc:
system_binary - Docker:
docker_image - Go:
go_binary - JVM:
jvm_artifact, anddeploy_jar - Python:
pex_binary,python_requirement,python_source, andpyoxidizer_binary
- Adhoc:
-
The new
system_binarytarget type supplied by theadhocbackend wraps any externally-managed tool so that the tool may be invoked as a "runnable" by theadhoc_tooltarget type, while also allowing tool versions to be pinned for reproducibility. -
Support for running in non-local environments as specified by the
environmentfield onshell_command,adhoc_tool, and related target types. -
Defining arbitrary shell commands as tests which can be invoked using
pants testvia the newexperimental_test_shell_commandtarget type. -
The
workdirfield torun_shell_commandhas been switched to match the documented behavior: it now runs from the same directory as theBUILDfile by default. To preserve the old behavior, explicitly setworkdir="/". The stabilisation also fixes other bugs with relative paths passed to theworkdirfield and thus may require updates.
Ad-hoc tool support, with the adhoc_tool or shell_command targets, can be used to compile third party
libraries in unsupported languages, run tools from ecosystems Pants doesn't yet directly support, and other similar code-generation tasks.
These targets can be used for first-party code generation, making use of existing backends that define
"runnable" targets if needed. For instance, exporting a OpenAPI schema from a Python API server, letting Pants
manage the interpreters and dependencies required.
Enable the pants.backend.experimental.adhoc backend to add the features supplied by the adhoc backend.
Enable the pants.backend.shell backend for the shell-related functionality including shell_command and
run_shell_command target types.
Go
The Go backend has received a large number of changes in order to be ready for Go v1.20 and to make continued progress on stabilizing the Go backend.
The main change is that Pants will now compile Go SDK packages from scratch and no longer rely on the prebuilt package archives distributed with the Go SDK. Go v1.20 will no longer ship with those prebuilt package archives, and so this change was necessary for Pants to continue to work with Go v1.20 and later releases. (It is also a correctness issue since Pants will now be able to apply compiler options consistently to both first-party Go code and Go SDK packages.)
The Pants team would appreciate if the community could try out 2.16.x with your Go code as an additional check to ensure there are no regressions.
The Go backend also now supports:
- Environments are supported via the
environmentfield available now ongo_binarytargets. - Code coverage can now analyze coverage for packages beyond just the package under test via the new
--go-test-cover-packagesoption. - Numerous bug fixes to the Cgo support.
- The data race detector is supported via the
racefield now available ongo_binarytargets. - Compiler and other flags may be set via the
compiler_flags,linker_flags, andassembler_flagsfields available on various target types.
Buf
Pants is now able to discover and supply configuration files for the Buf protobuf linter.
New: Preamble
The new "preamble" plugin allows formatting/linting files to ensure they start with specific text, such as a copyright header. Enable the
pants.backend.tools.preamble backend to add this support.
New: CUE
Pants now have basic support for the CUE language for defining, generating, and validating configuration data.
Enable the pants.backend.experimental.cue backend to use this support.
New: YamlLint
Pants now the supports the yamllint linter for YAML files. Enable the pants.backend.experimental.tools.yamllint backend to add this support.
New: AWS S3 support for URLs
Pants now supports referencing S3 URLs via the scheme (E.g. s3://), or authority (E.g. *.s3*amazonaws.com or s3.*amazonaws.com)
anywhere a URL can be specified.
Credentials are loaded similar to the AWS CLI (most regularly ~/.aws/credentials) and attached as headers in the request (which aren't cached or logged).
Enable the pants.backend.url_handlers.s3 backend to add this support.
New
Plugin API Changes
The URLDownloadHandler union has been added to allow plugins to modify native URL downloading, such as transforming the URL or attaching headers for auth.
The frozen_after_init decorator on dataclasses has been removed from many parts of the Pants codebase. Plugin authors should avoid use of this decorator because it will likely be removed in a future Pants version.
The deprecated Platform.current has been removed. Instead, have the affected rules take a Platform directly as a parameter and the engine will supply the relevant Platform instance.
The ToolCustomLockfile and ToolDefaultLockfile classes have been removed.
2.16.1rc0 (Jul 14, 2023)
Bug Fixes
-
Visibility: fix issue with using target type in verbose rule selector. (Cherry-pick of #19437) (#19457)
-
Fix helm documentation example (Cherry-pick of #19271) (#19310)
Documentation
-
Tweak getting-help docs (Cherry-pick of #19418) (#19420)
-
Refine
run_shell_commanddocs (Cherry-pick of #19413) (#19422) -
Add a sponsorships page to the docsite. (Cherry-pick of #19412) (#19417)
-
Get doc titles from the in-repo markdown files (Cherry-pick of #19311) (#19320)
-
docs: layout tweak of caching info, remove toolchain :( and additional info about bazel-remote-cache (Cherry-pick of #19299) (#19331)
2.16.0 (Jun 14, 2023)
The first stable release of the series, with no changes since the previous rc!
2.16.0rc7 (Jun 11, 2023)
Bug Fixes
- Fix S3 URL Handler for good (Cherry-pick of #19285) (#19288)
2.16.0rc6 (Jun 08, 2023)
Bug Fixes
-
Improve handling of additional files in Helm unit tests (Cherry-pick of #19263) (#19267)
-
Workaround
botocorebug in S3 URL Handler backend (Cherry-pick of #19056) (#19110)
2.16.0rc5 (Jun 01, 2023)
User API Changes
- Deprecate the
version/extra_requirementsoptions on python tools. (Cherry-pick of #19204) (#19210)
Bug Fixes
-
Scrub the Pyenv install dir before attempting an install. (Cherry-pick of #19193) (#19196)
-
Use
{bin_name()} runas$0inrun_shell_command(Cherry-pick of #19020) (#19036)
Documentation
-
Add
tobnito Maintainers (Cherry-pick of #19195) (#19206) -
Add
botocore-a-la-cartereference tos3URL Handler (Cherry-pick of #19055) (#19108) -
update scie-jump cache directory reference (Cherry-pick of #18485) (#19154)
2.16.0rc4 (May 25, 2023)
User API Changes
-
Terraform: Hashes for MacOS binaries have changed (Cherry-pick of #19004) (#19135)
-
Deprecate
[mypy].extra_type_stubsand its lockfile. (Cherry-pick of #19084) (#19086) -
Bring the tool
--exportoption deprecation forward. (Cherry-pick of #19079) (#19081)
Bug Fixes
- If a shebang already exists when adding a preamble, preserve it. (Cherry-pick of #19133) (#19137)
Documentation
-
add bazel-remote to list of compatible remote caches (Cherry-pick of #19041) (#19114)
-
Fix docs link to
pants_from_sourcesscript. (Cherry-pick of #19088) (#19090)
2.16.0rc3 (May 18, 2023)
User API Changes
- Support Python requirement target addrs in tool requirements. (Cherry-pick of #19014) (#19023)
Documentation
-
Clarify how to set $0 properly in
run_in_shell_command(Cherry-pick of #19019) (#19031) -
Docs tweaks for 2.16.x (Cherry-pick of #19009) (#19012)
2.16.0rc2 (May 11, 2023)
User API Changes
-
Use the resolve's ICs for tools. (Cherry-pick of #18776) (#18806)
-
Default to using the entire tool lockfile. (Cherry-pick of #18793) (#18807)
Bug Fixes
-
Require urllib3<2, to reduce installation issues (cherry-pick of #18959) (#18971)
-
Make
DigestSubsetsymlink-aware (Cherry-pick of #18963) (#18970) -
Do not choke on missing lockfiles. (Cherry-pick of #18940) (#18948)
-
Actually run deprecated targets fixer (Cherry-pick of #18860) (#18893)
-
Remove existing entry if any when materialising symlink (Cherry-pick of #18873) (#18878)
-
Ensure non-ambiguous args/env vars injection into PEXes (Cherry-pick of #18861) (#18877)
-
Patch
StreamingWorkunitContext.get_expanded_specs(). (Cherry-pick of #18713) (#18866) -
help backends: Only list enabled experimental backends unless advanced help. (Cherry-pick of #18821) (#18867)
-
Include
pants.backend.url_handlers.s3in pants distribution. (Cherry-pick of #18826) (#18870) -
Handle workdir="."/default properly in run_shell_command (Cherry-pick of #18840) (#18850)
-
Write adhoc_tool(stdout/stderr="...") relative to workdir, support absolute paths (Cherry-pick of #18814) (#18839)
-
Use build root as workdir for shell_command(workdir="") (Cherry-pick of #18813) (#18832)
Performance
- Optimize
TargetandFieldSetoperations (cherry-pick #18917) (#18944)
Documentation
-
update troubleshooting document about self-hosted action runner (Cherry-pick of #18900) (#18943)
-
doc: mention
use_local_aliasfor the[docker].registriesoption. (Cherry-pick of #18946) (#18950) -
Fix adhoc output_... example, document run_shell_command workdir changes (Cherry-pick of #18894) (#18910)
-
Include
symbolsas topic in usage help. (Cherry-pick of #18825) (#18869) -
Update mypy and pytest documentation to refer to install_from_resolve (Cherry pick of #18791) (#18858)
2.16.0rc1 (Apr 23, 2023)
User API Changes
- Upgrade Pex to 2.1.134. (Cherry-pick of #18785) (#18789)
Bug Fixes
-
The
OverridesField.compute_value()must return a hashable value. (Cherry-pick of #18787) (#18799) -
Makes
adhoc_toolactually respect theextra_env_varsfield; adds tests (Cherry-pick of #18692) (#18694) -
Use address as stable key when batching field sets in
lint/test(Cherry-pick of #18725) (#18734) -
Add
rufflint rules (Cherry-pick of #18716) (#18739) -
Fix
reprforFields that don't definedefault. (Cherry-pick of #18719) (#18724) -
Adds a fully-qualified path to a Python interpreter for
pex_binaryRunRequests (Cherry-pick of #18699) (#18700) -
Add timeout to remote store calls, and adjust name of cache timeout. (Cherry-pick of #18695) (#18697)
-
Bump minimum supported version of Pex to v2.1.129. (Cherry-pick of #18678) (#18687)
-
Fix JVM resource JAR creation on older Mac OSes (Cherry-pick of #18673) (#18676)
Documentation
-
Update linter documentation to refer to
install_from_resolve(Cherry-pick of #18781) (#18782) -
Add PEP 621
pyproject.tomlfile docs (Cherry-pick of #18672) (#18677) -
Improve lockfile consumption error message. (Cherry-pick of #18638) (#18653)
-
Document AWS CDK issue that multiple users have encountered. (Cherry-pick of #18656) (#18666)
-
Remove a python-specific tip from the general prereqs page. (Cherry-pick of #18637) (#18650)
2.16.0rc0 (Mar 31, 2023)
Bug fixes
-
Ensure that sandboxed processes exit before their sandboxes are clean… (#18640)
-
Plumb entire lockfile/internal only code through
create_pex_from_targets(Cherry-pick of #18622) (#18634) -
Fix PexPEX invocations (Cherry-pick of #18610) (#18633)
-
narrow pex_binary files warning (Cherry-pick of #18619) (#18628)
-
Improve debug information for docker auth, and expose an environment variable. (Cherry-pick of #18599) (#18604)
Documentation
-
Fix a string that should have been an f-string (Cherry-pick of #18608) (#18611)
-
Fix
./pants->pantsin some docs and help strings. (Cherry-pick of #18596) (#18606)
2.16.0a1 (Mar 24, 2023)
New Features
-
Always provide Python-for-Pants-scripts (Cherry-pick of #18433) (#18495)
-
Expose environment information on process metadata (Cherry-pick of #18458) (#18463)
User API Changes
-
Upgrade Pex to 2.1.130. (Cherry-pick of #18576) (#18578)
-
Deprecate old-style custom tool lockfiles. (#18494) (#18498)
-
Let a user resolve shadow a tool lockfile of the same name (Cherry-pick of #18481) (#18493)
-
Audit and update requirements for Python tools. (cherrypick #18431) (#18460)
Bug fixes
-
Ensure that a symlinked exported venv exists and is valid. (Cherry-pick of #18575) (#18585)
-
Fail fast for attempts to use
test --debugwith a docker environment (Cherry-pick of #18560) (#18568) -
Declare ruff outputs as files. (Cherry-pick of #18551) (#18557)
-
Add support for Docker registry auth (Cherry-pick of #18541) (#18549)
-
Fix Poetry req synthesis for URLs with markers. (Cherry-pick of #18535) (#18536)
-
Preserve environment variables in
pantsdto allow Docker auth. (Cherry-pick of #18465) (#18468) -
Only expose the equiv of
from typing import *in prelude files (Cherry-pick of #18452) (#18455) -
Support type hints in prelude files. (Cherry-pick of #18442) (#18449)
-
Synthesized lockfile targets should never err on missing lockfiles. (Cherry-pick of #18406) (#18447)
Documentation
-
First pass at
adhoc_tooldocumentation (Cherry-pick of #18531) (#18581) -
Update docs on running pants from sources with scie-pants. (Cherry-pick of #18513) (#18514)
-
Remove the superfluous updated: front matter from readme docs. (cherrypick of #18475) (#18476)
-
Expand lockfile documentation to its own page. (cherrypick of #18471) (#18474)
2.16.0a0 (Mar 06, 2023)
New Features
-
Allow python tools to be installed from a user resolve. (#18418)
-
golang: add support for passthrough args for gofmt (#18409)
-
Add the ability for Pants to provide Python via a union (with a pyenv impl) (#18352)
-
Add
sources_fingerprinttopeekon source-creating targets (#18383) -
New
BUILDfile symbols help info (#18378) -
Visibility: support matching on target names. (#18369)
-
Support for
peeking at dependency/dependents rules (#18112) -
Adds support for supplying "runnable" dependencies to the
execution_dependenciesfield (#18347) -
javascript: Support esm modules and commonjs specific javascript file extensions (#18208)
-
Adds
system_binarytarget, which can be used to reproducibly find a pre-installed binary for use withadhoc_tool(#18332) -
Enable running third-party Go
mainpackages (#17449)
User API Changes
-
Add
python311runtime topython_google_cloud_functiontarget (#18405) -
Delegate lockfile requirement validation to Pex when possible. (#18415)
-
Upgrade Pex to 2.1.126. (#18408)
-
Deprecate the default interpreter constraints. (#18390)
-
Give pantsd more RAM by default. (#18389)
Plugin API Changes
-
Support specifying a named resolve as the superset in a
PexRequirements. (#18397) -
Deprecate the
@rule_helperdecorator. (#18330) -
Get rid of the
LockfileContentclass (#18305)
Bug fixes
-
python: collect files with '[tool.ruff' sections as candidates for Ruff config files (#18413)
-
Fix OSError when running pants in systemd-nspawn container (#18398)
-
Fix
pathsissue with transitive excludes. (#18396) -
Fix export-codgen with multiple output types from same input type (#18373)
-
Errors in
--loopwait for changes rather than re-running immediately (#18367) -
Support using
env()in prelude macro files (#18273) -
Docker environment uses a volume for named caches (#18327)
-
Load
fromfilefiles relative to build root (#18311) -
Ensure that the pep-517 backend shim works on Python 2.7. (#18295)
Documentation
-
Update documentation on how to install the pants binary (#18372)
-
Some doc fixes suggested by users. (#18393)
-
docs: tidy up writing plugins tutorial (#18380)
-
docs: upgrade plugin writing tutorial to 2.15.0 (#18371)
-
Use valid container/app names in helm examples (#18358)
-
Remove defunct newsletter (#18355)
-
docs: mention code generation when troubleshooting missing imports from first-party code (#18073)
-
Fix documentation example for
python_awslambdatargets (#18302) -
Change bool values to lowercase in TOML snippets (#18299)
2.16.0.dev7 (Feb 17, 2023)
New Features
-
Allow exporting codegenerated files/resources (#18236)
-
python: teach tailor goal to create resource targets for py.typed marker files (#18174)
-
The beginnings of a Django plugin. (#18173)
-
Add backend for projects that use openstack/stevedore (#18132)
-
[python-infer]: allow ignoring unowned imports (#18094)
-
Print diff report when generating Python lockfiles. (#17347)
User API Changes
-
Deprecates
experimental_run_shell_commandin favour ofrun_shell_command(#18266) -
Deprecates
experimental_shell_command, replacing withshell_command(#18255) -
Extracts
backend.adhocpackage andbackend.experimental.adhocbackend foradhoc_tool(#18237) -
Upgrade Pex to 2.1.122. (#18230)
-
Relativize the pants_bin_name if necessary. (#18204)
-
Adjust the default for
root_output_directory(#18192) -
Visibility backend: adjust rule set selector syntax making path values default rather than target types. (#18154)
-
Adds fields to capture stdout/stderr to
experimental_run_in_sandbox(#18165) -
shell_command/run_in_sandboxworkdir/output dir adjustments (#18157) -
Default to the new "Dependents" header in the py_constraints report. (#18142)
Plugin API Changes
Bug fixes
-
go: support embed configuration in stdlib packages (#18271)
-
Upgrade to Lambdex 0.1.9 (#18257)
-
Delete override of expected
exename forshfmt. (#18258) -
Fix bootstrap issue with
__defaults__and environments. (#18251) -
Allow breakpoints to be hit when run_in_sandbox is False (#18244)
-
Avoid bind-mounts for docker environments on macOS (#18225)
-
Move ruff from fmt to fix (#18228)
-
Stream large remote cache downloads directly to disk (#18054)
-
BUILD file target field default should respect values from
__defaults__. (#18172) -
Fix published wheel RECORDs. (#18219)
-
Always explicitly shutdown executors (#18216)
-
go: upgrade golangci-lint to fix issue with Go v1.20 (#18207)
-
go: disable coverage redesign experiment on Go v1.20+ (#18205)
-
Use
EnvironmentAwarePackageRequestin many more contexts. (#18203) -
Have lambdex create a new output file. (#18200)
-
Shutdown all threads as part of Scheduler shutdown (#18166)
-
Fix the dep inference scripts source root bug. (#18164)
-
Add the
environmentfield to most Python binary target types (#18144) -
go: don't check for
Targetattribute on stdlib packages (#18148) -
go: fix backend to work when run in non-local environments (#18140)
-
Run
pyupgradeuntil convergance (#18128)
Documentation
-
docs: use an example black version that does not explode (#18270)
-
docs: fix typo (#18238)
-
Update the stated release target to match our desired reality. (#18234)
-
docs: add What's New section for 2.15.x release notes (#18226) (#18232)
-
Add warning about dependency inference +
extra_type_stubs. (#17076) -
docs: further updates to 2.16.x What's New (#18227)
-
Jacob Floyd/Huon Wilson updates to team page (#18221)
-
docs: add "What's New" section to 2.16 release notes (#18146)
-
Document the new get-pants.sh name. (#18137)
-
Add Pylint post (#18079)
-
Change to Pantsbuild's custom YouTube url (#18133)
-
Recommend checking the pantsup.sh script in. (#18120)
-
Don't update old release notes. (#18123)
-
Change
./pantstopantsin the docs (#18121)
2.16.0.dev6 (Jan 29, 2023)
New Features
-
go: add
environmentfield togo_binary(#18113) -
Add experimental backend for ruff with lint and fmt goals (#17945)
-
Add support for
fmtcue files. (#18106) -
Add new experimental backend for CUE with initial support for the
lintgoal. (#17943) -
Add yamllint as a lint tool for YAML sources (#17821)
-
lint: add pydocstyle python backend (#17596)
User API Changes
- Upgrade Pex to 2.1.121. (#18037)
Plugin API Changes
-
Make the python dep inference script extensible. (#17997)
-
Remove some dead code from
lockfile.py(#18041)
Bug fixes
-
Inject a path-safe target spec into
experimental_shell_commandetc processes (#18092) -
docker: Allow overriding FROM args when determining upstream image dependencies (#18009)
-
Make mypy cache per-repo (#18043)
-
Fix caching of PATH lookups in remote execution (#18026)
Documentation
-
docs: make tutorials to get started writing plugins visible on readme pages (#18083)
-
Document new pants launcher binary, aka scie-pants. (#18056)
-
Front matter for new tutorial pages. (#18074)
-
Cosmetic fix for current value information in help output for pass-through arguments. (#18051)
-
docs: add pydocstyle to the docs and help reference (#18033)
-
docs: add tutorial to get started writing plugins: No 3 (#18018)
2.16.0.dev5 (Jan 16, 2023)
New Features
-
New
env()BUILD file function. (#17652) -
Support REPL command history. (#17959)
-
Resolve Python dep inference ambiguity via locality. (#17931)
-
Add targets to re-wrap source files in different
SourcesFieldtypes. (#17877) -
Allow plugins to add custom schema/authority URL handler rules (#17898)
-
Support freezing command line args and env vars into pex binaries. (#17905)
-
Support catching
@ruleerrors (#17911)
User API Changes
-
Ugrade Pex to 2.1.120 (#17957)
-
Adds
workdirfield forexperimental_shell_commandand friends (#17928)
Bug fixes
-
Let pyright see dependencies in other source roots. (#18014)
-
go: gather and link transitive prebuilt object files for cgo mode (#17971)
-
add skip_pyright field to python test targets (#17960)
-
Allow
experimental_shell_command/experimental_run_in_sandboxto specifyoutput_s from anywhere under the buildroot (#17938) -
Do not load the BUILD file prelude (macros) in the bootstrap scheduler. (#17939)
Documentation
-
WSL disclaimer in Getting Started/Prerequisites (#18000)
-
Add Daniel Goldman and Darcy Shen to team page (#17921)
-
Clarify runtime vs. complete_platforms for serverless. (#18001)
-
docs: add tutorial to get started writing plugins: No 2 (#17890)
-
docs: generate a JSON schema file to be used in IDEs when editing pants.toml (#17915)
-
docs: fix markdown inline code typo in a docstring (#18002)
-
fix type in
checkhelp output (#17969) -
Document how to update the pants script. (#17976)
-
Add Kaiko to "who uses Pants" page. (#17949)
-
docs: provide a link to Google Cloud Function in the backend docstring (#17948)
-
docs: add info about beta stage support of protobuf for Scala and Java (#17935)
-
docs: add the first tutorial on writing plugins to readme docs directory (#17930)
-
docs: reformat the kotlin docs to have better line breaks on readme.com (#17929)
-
Update and reorganize resource hub (#17922)
-
Add Payhere to user list. (#17917)
-
Nudge more technical support toward GH Discussions (#17906)
-
go: update docs to remove caveats about implemented features (#17913)
2.16.0.dev4 (Dec 30, 2022)
New Features
-
Add [buf] config and config_discovery options (#17885)
-
New help topic:
backends. (#17600) -
Make pants work when the uid doesn't map to a user. (#17881)
-
Make JVM sources runnable (#17847)
-
Support
python_requirementas arun/experimental_run_in_sandboxtarget (#17864) -
Support
experimental_run_in_sandbox/./pants runforjvm_artifacttargets (#17827) -
go: support the
go testprofiling options (#17836) -
Add output_path field to python_distribution. (#17841)
User API Changes
-
Upgrade default mypy-protobuf version to 3.4 (#17887)
-
allow each resolve to be exported for multiple python interpreters (#17711)
-
More default Python module mappings. (#17879)
-
Make export cleanup a subset of
dist/export, not the whole thing (#17849) -
Unify the messages for lockfile validation errors. (#17842)
-
Unify validation of tool and user lockfile metadata. (#17834)
-
Detect Pants-generated lockfiles before attempting to validate. (#17833)
Plugin API Changes
-
Remove
immutable_input_digestsfrom shell code (#17886) -
Default
use_pantsdtoFalseinrun_pants(#17874) -
Remove the ToolCustomLockfile/ToolDefaultLockfile classes. (#17843)
Bug fixes
- scala: support scala v3 which has different compiler/library artifacts (#17855)
Performance
-
Bring back hardlinking big files (#17878)
-
Don't invalidate watched files if non-perms metadata changed (#17875)
Documentation
-
docs: mention name clashing between custom goals and options when writing plugins (#17899)
-
docs: add tutorial to get started writing plugins: No 1 (#17732)
-
Document batched
pytestexecution. (#17845) -
Tweak the docs about defaults. (#17829)
-
docs: extend python test goal with info on collecting tests with pytests (#17894)
2.16.0.dev3 (Dec 16, 2022)
New Features
-
Allow targets that implement
RunFieldSetto be executed in the sandbox for side-effects (#17716) -
python_requirementstarget generator can parse PEP 621 pyproject.toml files (#16932)
User API Changes
-
Bump default version of shfmt from 3.2.4 to 3.6.0 (#17777)
-
An enum of Python export formats. (#17800)
-
Add export-codegen goal to more backends (#17773)
-
Adds
execution_dependenciesforexperimental_shell_command(#17743)
Plugin API Changes
- Remove boilerplate for run and test plugins (#17774)
Bug fixes
-
go: detect when
go.sumneeds additional entries filled in (#17811) -
go: pass module sources through to linker if
${SRCDIR}is referenced (#17780) -
go: improve options passed to assembler invocations (#17796)
-
Explicitly use "python" ijson backend (#17787)
-
Do not clear the
pantsdlog while restarting (#17783) -
Restore support for :all: in
only_binary/no_binary. (#17779) -
go: remove notion of separate
__obj__directory (#17775) -
Visibility: empty selector should match no target. (#17763)
-
[Visibility]
**/..globs can match root level files (#17681) -
Visibility: fix rules path for generated targets. (#17760)
Documentation
-
Documentation for the new visibility rules (#17632)
-
Add Doctrine's eng blog post and example repo to resource hub. (#17810)
-
Add Astranis to user list. (#17812)
-
Add Doctrine to user list (#17793)
-
Doc: update
Getdocstring for multiple inputs. (#17730)
2.16.0.dev2 (Dec 08, 2022)
New Features
-
go: use target spec for coverage output directories plus support import path (#17734)
-
go: add
assembler_flagsfield for adding arbitrary extra assembler flags (#17731) -
Expose target field defaults in BUILD files. (#17649)
-
Add a new "preamble" plugin (#17682)
-
go: support code coverage over multiple packages during single test (#17701)
-
go: add
linker_flagsfield togo_modandgo_binarytarget types (#17697) -
go: add
compiler_flagsfield for adding arbitrary extra compiler flags (#17683)
User API Changes
-
Include transitive requirements missing for
python_distribution. (#17594) -
Extend default module mapping for Python 3rd-party dependency inference: pysocks and atlassian-python-api (#17654)
Bug fixes
-
Test DebugAdapter requests, and fix issues (#17678)
-
chdir in
rule_runner.run_interactive_process(#17722) -
More precise running workunit for processes executing remotely (#17719)
-
Don't strip the input of a
DictOptionfile config (#17705) -
Visibility rules: error if more than one declaration per BUILD file. (#17669)
-
Allow JVM source to depend on relocated_files target (#17005)
-
Fix bug in Go test result exit code interpretation. (#17661)
Performance
Documentation
-
Doc fixes and updates: (#17708)
-
docs: tidy up Writing plugins : rules-api directory files (#17710)
-
Update docker docs to clarify dependency handling. (#17655)
2.16.0.dev1 (Nov 27, 2022)
New Features
-
go: address sanitizer support (#17651)
-
go: add support for C/C++ memory sanitizer (#17644)
-
shell: add
experimental_test_shell_commandfor arbitrary shell-driven tests (#17640) -
support Go data race detector (#17510)
-
Add
Field.none_is_valid_valuebool class var option. (#17577)
User API Changes
Plugin API Changes
- Remove deprecated Platform.current. (#17646)
Bug fixes
-
Fix twine env vars propagation for
publishgoal. (#17650) -
Support
source=Nonefordocker_imagetargets. (#17578) -
Specify local environment for python source analysis goal (#17603)
-
go: allow use of
go_asm.hassembly header in assembly files (#17611) -
Visibility rule glob tweaks for
*and**(#17588)
Documentation
-
Fix broken docs links to manual build instructions (#17608)
-
Docs: improve docs on handling option values in cli (#17506)
2.16.0.dev0 (Nov 19, 2022)
New Features
-
Add
environment=toexperimental_shell_command. (#17575) -
Add debug goals to python (#17057)
-
Target visibility rules (#17401)
-
Emit a
__run.shinto InteractiveProcess sandboxes. (#17532) -
Support newer pip versions. (#17555)
-
New dependency rules Plugin API (#17550)
-
Export metadata about a packaged docker image (#17299)
-
Don't require hardcoded name in
python_distribution.provides(#17522) -
Add
per_platformobject (#17334) -
Process output capturing is symlink-aware (#17496)
-
go: introduce
GoBuildOptionsandcgo_enabledfield (#17475) -
Disambiguate Python module providers by level of ancestry. (#17489)
-
go: support ".syso" prebuilt object files (#17479)
-
Add Docker registries
use_local_aliasconfiguration option. (#17265) -
Proposal for supporting Jar shading rules (#17251)
-
A --resolve flag, to specify the resolves to export. (#17416)
-
Handle duplicate JAR entries in
deploy_jar(#17419)
User API Changes
-
Upgrade default version of golangci-lint to 1.50.1 (#17574)
-
Deprecate the old export semantics. (#17465)
-
Add
restartablefield topython_sources(#17400) -
Deprecate the
# Dependeescolumn name in the py-constraints summary. (#17399) -
Rename the dependees goal to dependents. (#17397)
-
Rename --changed-dependees to --changed-dependents (#17395)
Bug fixes
-
Allow for
run --debug-adapterto match breakpoints when source is running in a sandbox (#17566) -
Created an
NpxToolBaseas an inheritable Subsystem fornodejstools (#17567) -
Fix loading of
SymlinkNodesfrom theStore. (#17549) -
Do not try to create
""output directory inCreateArchive(#17538) -
Persist digests before emitting them in
fs_util(#17525) -
Fix memoization of
CoarsenedTarget.closure(#17516) -
Support parsing targets from additional paths not containing BUILD files. (#17451)
-
Ensure lockfile target exists before injecting a dependency to it. (#17365)
-
Ensure correct eq/hash semantics for PythonArtifact. (#17484)
-
Isolate config seed values from the DEFAULT section. (#17474)
-
Fix poorly understood stdout redirection issue. (#17471)
-
Fix propagation of the remote-execution-append-only-caches path (#17469)
-
Pyright should grab non-transitive dependencies and make them available in the sandbox (#17235)
-
Plumb symlink support through the Pants engine (#16844)
-
Flip the default for
pullondocker_imagetoFalse(#17459) -
Merge pytest addopts (#16614)
-
Fix dep inference from
shuint2_teststargets. (#17417) -
Fix
EnvironmentNameused intestruns (#17412) -
Add the m1 homebrew bin dir to the system binary search path. (#17411)
-
Restore debug hints for
testexecution (#17406)
Performance
-
Skip loading of local cache data when possible (#17495)
-
Symlink site-packages into
pylintvenvs when possible. (#17488) -
Filter coarsened targets to only those that are relevant in
pylintrunner rule (#17487)
Documentation
-
correct docs: direnv can't save ulimit (#17561)
-
Update team pages for SJ and Dan! (#17534)
-
Fix line breaks in a docs page. (#17527)
-
Clarify how
__defaults__apply to target generators. (#17493) -
Fix typo in docs: debug-adaptor should be debug-adapter (#17452)
-
Update
nuke_if_too_bigdocumentation (#17429) -
Fix version templating in
vcs_versiondocs (#17423)