Skip to content

Commit

Permalink
Merge branch 'main' into dependabot/cargo/src/rust/engine/http-body-1…
Browse files Browse the repository at this point in the history
….0.1
  • Loading branch information
cburroughs authored Jan 9, 2025
2 parents 429f415 + f152256 commit 629c711
Show file tree
Hide file tree
Showing 388 changed files with 15,328 additions and 8,171 deletions.
15 changes: 15 additions & 0 deletions .devcontainer/Dockerfile
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
FROM mcr.microsoft.com/devcontainers/rust:1

RUN apt-get update && export DEBIAN_FRONTEND=noninteractive \
# Install prerequisites.
&& apt-get install --no-install-recommends -y build-essential clang libffi-dev libfuse-dev libssl-dev protobuf-compiler python3-dev \
# Install `hyperfine` and `dbg` for debugging and benchmarking.
# See: https://www.pantsbuild.org/stable/docs/contributions/development/debugging-and-benchmarking
&& apt-get install --no-install-recommends -y gdb python3-dbg \
&& curl -Lo /tmp/hyperfine.deb https://github.com/sharkdp/hyperfine/releases/download/v1.19.0/hyperfine_1.19.0_amd64.deb \
&& sudo dpkg -i /tmp/hyperfine.deb \
# Cleanup.
&& rm -rf /tmp/* \
&& apt-get autoremove -y \
&& apt-get clean all \
&& rm -rf /var/lib/apt/lists/*
39 changes: 39 additions & 0 deletions .devcontainer/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,39 @@
# Dev Container for developing Pants

This project provides a *Development Container* (or [Dev Container](https://containers.dev/) for short) with a full-featured development environment containing all the tools, libraries, and runtimes needed to work with the [Pants](https://github.com/pantsbuild/pants) codebase. Here are some advantages of using dev containers:

- **Faster setup**: Dev containers can be pre-built with all the necessary tools, libraries and runtimes, making setting up a new development environment faster. This is especially useful for new team members joining a project who can quickly get started without spending time setting up their development environment.
- **Portability**: Dev containers provide portability between different platforms and clouds, allowing developers to write once and run anywhere. This ensures that developers can use the same development environment across different machines and platforms without compatibility issues.
- **Consistency**: Dev containers provide a consistent development environment for all developers working on a project. This ensures that everyone is using the same tools, libraries and runtimes, reducing the chances of compatibility issues and making it easier to collaborate and reproduce bugs.
- **Isolation**: Dev containers run in isolation from the host system, which improves security and reduces the chances of conflicts with other software installed on the host system.
- **Reproducibility**: Dev containers can be version-controlled, making it easy to reproduce the development environment at any point in time. It also allows developers to roll back to an earlier environment version if necessary.

## Features

- [Rust](https://www.rust-lang.org/) engine and common Rust utilities
- [Python](https://www.python.org/) 3.11
- [Docker-in-Docker](https://github.com/devcontainers/features/tree/main/src/docker-in-docker) (DinD)
- [Shell History](https://github.com/stuartleeks/dev-container-features/tree/main/src/shell-history)
- [Local Git hooks](https://www.pantsbuild.org/stable/docs/contributions/development/setting-up-pants#step-3-set-up-a-pre-push-git-hook)
- Useful VS Code extensions like `Python`, `Pylance`, `Black Formatter`, `rust-analyser`, `Even Better TOML`, etc.
- Volumes for Pants [cache directories](https://www.pantsbuild.org/stable/docs/using-pants/using-pants-in-ci#directories-to-cache)
- `hyperfine`, `py-sy`, `memray` and `dbg` for [debugging and benchmarking](https://www.pantsbuild.org/stable/docs/contributions/development/debugging-and-benchmarking)

## Getting started

You need three (3) things to get started with development containers:

- [VS Code](https://code.visualstudio.com/)
- [Docker](https://www.docker.com/)
- [Dev Containers](https://marketplace.visualstudio.com/items?itemName=ms-vscode-remote.remote-containers) extension for VS Code

More on getting started can be found [here](https://code.visualstudio.com/docs/devcontainers/containers#_getting-started).

## Using the Dev Container

1. After forking and cloning `pantsbuild/pants`, start VS Code and run the `Dev Containers: Open Folder in Container...` command from the *Command Palette...* (`F1`) and select the Pants project folder.
2. The VS Code window (instance) will reload and start building the dev container. A progress notification provides status updates.
3. After the build completes, VS Code will automatically connect to the container. You can now work with the repository source code in this independent environment.
4. Pants sets up its development virtualenv at `~/.cache/pants/pants_dev_deps/<venv_fingerprint>.venv/`. Point VS Code to the `bin/python` file in this folder by running the `Python: Select Interpreter` command from the *Command Palette...* (`F1`), and then `Enter interpreter path...`. You may need to restart your *terminal*. See [Configure your IDE (optional)](https://www.pantsbuild.org/docs/contributor-setup#configure-your-ide-optional).

More on starting a dev container can be found [here](https://code.visualstudio.com/docs/devcontainers/containers#_picking-your-quick-start).
76 changes: 76 additions & 0 deletions .devcontainer/devcontainer.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,76 @@
{
"name": "Pants Dev Container",
"build": {
"context": ".",
"dockerfile": "./Dockerfile"
},
"features": {
"ghcr.io/devcontainers/features/docker-in-docker:2": {},
"ghcr.io/devcontainers/features/python:1": {
"version": "3.11.10"
},
"ghcr.io/stuartleeks/dev-container-features/shell-history:0": {}
},
"customizations": {
"vscode": {
"extensions": [
// VS Code extensions installed by the Python feature.
// See: https://github.com/devcontainers/features/tree/main/src/python#vs-code-extensions
// "ms-python.python",
// "ms-python.vscode-pylance",
// "ms-python.autopep8",
// Others useful extensions for Python and Rust.
"ms-python.black-formatter",
"ms-python.flake8",
"ms-python.mypy-type-checker",
"rust-lang.rust-analyzer",
"vadimcn.vscode-lldb",
"tamasfe.even-better-toml",
"unifiedjs.vscode-mdx"
],
"settings": {
"[python]": {
"editor.defaultFormatter": "ms-python.black-formatter",
"editor.formatOnSave": true
},
"[rust]": {
"editor.defaultFormatter": "rust-lang.rust-analyzer",
"editor.formatOnSave": true
},
"python.analysis.extraPaths": ["src/python"],
"black-formatter.args": ["--config=pyproject.toml"],
"flake8.args": ["--config=build-support/flake8/.flake8"],
"flake8.path": ["dist/export/python/virtualenvs/flake8/3.11.10/bin/flake8"],
"mypy-type-checker.args": ["--config-file=pyproject.toml"],
"mypy-type-checker.path": ["dist/export/python/virtualenvs/mypy/3.11.10/bin/mypy"],
"rust-analyzer.linkedProjects": ["src/rust/engine/Cargo.toml"]
}
}
},
"remoteUser": "vscode",
"mounts": [
// DinD feature mounts `/tmp` to `tmpfs` by default, limiting the `/tmp` folder size
// to the amount of RAM that is available, which results in `Out of space Exception`
// when Pants runs. Temporary fix until issue #471 is resolved.
// See: https://github.com/devcontainers/features/issues/471
{
"target": "/tmp",
"type": "volume"
},
// Mount cache directories used by the Pants launcher binary
// and some underlying tools.
// See: https://www.pantsbuild.org/stable/docs/using-pants/using-pants-in-ci#directories-to-cache
{
"source": "pants-named_caches",
"target": "/home/vscode/.cache/pants/named_caches",
"type": "volume"
},
{
"source": "pants-lmdb_store",
"target": "/home/vscode/.cache/pants/lmdb_store",
"type": "volume"
}
],
"postCreateCommand": ".devcontainer/postCreateCommand.sh",
"postStartCommand": ".devcontainer/postStartCommand.sh"
}
19 changes: 19 additions & 0 deletions .devcontainer/postCreateCommand.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
#!/usr/bin/env bash

set -ex

# Since this repository runs VS Code as the non-root "vscode" user,
# we need to be sure the user can access the folder.
# See: https://code.visualstudio.com/remote/advancedcontainers/improve-performance#_use-a-targeted-named-volume
sudo chown -R vscode:vscode /home/vscode/.cache

# Install local git hooks.
# See: https://www.pantsbuild.org/stable/docs/contributions/development/setting-up-pants#step-3-set-up-a-pre-push-git-hook
build-support/bin/setup.sh

# Install `py-sy` and `memray` for CPU and Memory profiling.
# See: https://www.pantsbuild.org/stable/docs/contributions/development/debugging-and-benchmarking
pip install py-spy memray

# Bootstrap Pants.
./pants --version
13 changes: 13 additions & 0 deletions .devcontainer/postStartCommand.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
#!/usr/bin/env bash

set -ex

# Export resolves used by VS Code extensions.
resolves=(flake8 mypy)
for r in ${resolves[@]}; do
sha256sum_file=dist/$r-lockfile.sha256
if [[ ! $(sha256sum -c $sha256sum_file) ]]; then
./pants export --resolve=$r
sha256sum 3rdparty/python/$r.lock > $sha256sum_file
fi
done
4 changes: 2 additions & 2 deletions .github/runs-on.yml
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
images:
ubuntu22-full-arm64-python3.7-python3.8-python3.9:
ubuntu22-full-arm64-python3.7-3.13:
platform: "linux"
arch: "arm64"
owner: "408085265505"
ami: "ami-072f12824058aa801"
ami: "ami-0718bef309678bb83"
18 changes: 14 additions & 4 deletions .github/workflows/cache_comparison.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -11,12 +11,22 @@ jobs:
uses: actions/checkout@v4
with:
fetch-depth: 10
- name: Set up Python 3.9
- name: Set up Python 3.7, 3.8, 3.9, 3.10, 3.12, 3.13, 3.11
uses: actions/setup-python@v5
with:
python-version: '3.9'
- name: Expose Pythons
uses: pantsbuild/actions/expose-pythons@v9
python-version: '3.7
3.8
3.9
3.10
3.12
3.13
3.11'
- env:
BASE_REF: ${{ github.event.inputs.base_ref }}
BUILD_COMMIT: ${{ github.event.inputs.build_commit }}
Expand Down
21 changes: 1 addition & 20 deletions .github/workflows/clear_self_hosted_persistent_caches.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@ jobs:
- self-hosted
- runs-on
- runner=4cpu-linux-arm64
- image=ubuntu22-full-arm64-python3.7-python3.8-python3.9
- image=ubuntu22-full-arm64-python3.7-3.13
- run-id=${{ github.run_id }}
steps:
- name: df before
Expand All @@ -26,25 +26,6 @@ jobs:
run: du -sh ~/.pex || true; rm -rf ~/.pex || true
- name: df after
run: df -h
clean_macos11_arm64:
runs-on:
- self-hosted
- macOS-11-ARM64
steps:
- name: df before
run: df -h
- name: Deleting ~/Library/Caches
run: du -sh ~/Library/Caches || true; rm -rf ~/Library/Caches || true
- name: Deleting ~/.cache
run: du -sh ~/.cache || true; rm -rf ~/.cache || true
- name: Deleting ~/.nce
run: du -sh ~/.nce || true; rm -rf ~/.nce || true
- name: Deleting ~/.rustup
run: du -sh ~/.rustup || true; rm -rf ~/.rustup || true
- name: Deleting ~/.pex
run: du -sh ~/.pex || true; rm -rf ~/.pex || true
- name: df after
run: df -h
name: Clear persistent caches on long-lived self-hosted runners
'on':
workflow_dispatch: {}
Loading

0 comments on commit 629c711

Please sign in to comment.