Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/jianlizh429/pants-demo
https://github.com/jianlizh429/pants-demo
Last synced: about 1 month ago
JSON representation
- Host: GitHub
- URL: https://github.com/jianlizh429/pants-demo
- Owner: JianliZh429
- License: apache-2.0
- Created: 2022-03-21T08:00:06.000Z (almost 3 years ago)
- Default Branch: main
- Last Pushed: 2022-03-21T08:00:07.000Z (almost 3 years ago)
- Last Synced: 2024-04-14T03:50:27.042Z (9 months ago)
- Language: Shell
- Size: 13.7 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# example-python
An example repository to demonstrate Python support in Pants.See [pantsbuild.org](https://www.pantsbuild.org/docs) for much more detailed documentation.
This is only one possible way of laying out your project with Pants. See
[pantsbuild.org/docs/source-roots#examples](https://www.pantsbuild.org/docs/source-roots#examples) for some other
example layouts.# Running Pants
You run Pants goals using the `./pants` wrapper script, which will bootstrap the
configured version of Pants if necessary.Use `./pants --version` to see the version of Pants configured for the repo (which you can also find
in `pants.toml`).# Goals
Pants commands are called _goals_. You can get a list of goals with
```
./pants help goals
```# Targets
Targets are a way of setting metadata for some part of your code, such as timeouts for tests and
entry points for binaries. Targets have types like `python_source`, `resources`, and
`pex_binary`. They are defined in `BUILD` files.Pants goals can be invoked on targets or directly on source files (which is often more intuitive and convenient).
In the latter case, Pants locates target metadata for the source files as needed.## File specifications
Invoking goals on files is straightforward, e.g.,
```
./pants test helloworld/util/lang_test.py
```You can use globs:
```
./pants lint helloworld/util/*.py
```But note that these will be expanded by your shell, so this is equivalent to having used
```
./pants lint helloworld/util/lang.py helloworld/util/lang_test.py helloworld/util/resources.py helloworld/util/resources_test.py
```If you want Pants itself to expand the globs (which is sometimes necessary), you must quote them in the shell:
```
./pants lint 'helloworld/util/*.py'
```You can run on all changed files:
```
./pants --changed-since=HEAD lint
```You can run on all changed files, and any of their "dependees":
```
./pants --changed-since=HEAD --changed-dependees=transitive test
```## Target specifications
Targets are referenced on the command line using their address, of the form `path/to/dir:name`, e.g.,
```
./pants lint helloworld/util:util
```You can glob over all targets in a directory with a single trailing `:`, or over all targets in a directory
and all its subdirectories with a double trailing `::`, e.g.,```
./pants lint helloworld::
```## Globbing semantics
When you glob over files or targets, Pants knows to ignore ones that aren't relevant to the requested goal.
For example, if you run the `test` goal over a set of files that includes non-test files, Pants will just ignore
those, rather than error. So you can safely do things like```
./pants test ::
```To run all tests.
# Example Goals
Try these out in this repo!
## List targets
```
./pants list :: # All targets.
./pants list 'helloworld/**/*.py' # Just targets containing Python code.
```## Run linters and formatters
```
./pants lint ::
./pants fmt helloworld/greet::
```## Run MyPy
```
./pants check ::
```## Run tests
```
./pants test :: # Run all tests in the repo.
./pants test helloworld/util:test # Run all the tests in this target.
./pants test helloworld/util/lang_test.py # Run just the tests in this file.
./pants test helloworld/util/lang_test.py -- -k test_language_translator # Run just this one test.
```## Create a PEX binary
```
./pants package helloworld/main.py
```## Run a binary
```
./pants run helloworld/main.py
```## Open a REPL
```
./pants repl helloworld/greet # The REPL will have all relevant code and dependencies on its sys.path.
./pants repl --shell=ipython helloworld/greet --no-pantsd # To use IPython, you must disable Pantsd for now.
```## Build a wheel / generate `setup.py`
This will build both a `.whl` bdist and a `.tar.gz` sdist.
```
./pants package helloworld/util:dist
```## Count lines of code
```
./pants count-loc '**/*'
```
## Create virtualenv for IDE integration```
./pants export ::
```