mirror of https://github.com/pypa/hatch.git
181 lines
5.6 KiB
Markdown
181 lines
5.6 KiB
Markdown
# Environments
|
|
|
|
-----
|
|
|
|
[Environments](config/environment/overview.md) are designed to allow for isolated workspaces for testing, building documentation, or anything else projects need.
|
|
|
|
Unless an environment is [chosen explicitly](#selection), Hatch will use the `default` environment.
|
|
|
|
## Creation
|
|
|
|
You can create environments by using the [`env create`](cli/reference.md#hatch-env-create) command. Let's enter the directory of the project we created in the [setup phase](intro.md#new-project):
|
|
|
|
```console
|
|
$ hatch env create
|
|
Creating environment: default
|
|
Installing project in development mode
|
|
Syncing dependencies
|
|
```
|
|
|
|
!!! tip
|
|
You never need to manually create environments as [spawning a shell](#entering-environments) or [running commands](#command-execution) within one will automatically trigger creation.
|
|
|
|
## Entering environments
|
|
|
|
You can spawn a [shell](config/hatch.md#shell) within an environment by using the [`shell`](cli/reference.md#hatch-shell) command.
|
|
|
|
```console
|
|
$ hatch shell
|
|
(hatch-demo) $
|
|
```
|
|
|
|
Now confirm the project has been installed:
|
|
|
|
```console
|
|
(hatch-demo) $ pip show hatch-demo
|
|
Name: hatch-demo
|
|
Version: 0.0.1
|
|
...
|
|
```
|
|
|
|
Finally, see where your environment's Python is [located](config/hatch.md#environments):
|
|
|
|
```console
|
|
(hatch-demo) $ python -c "import sys;print(sys.executable)"
|
|
...
|
|
```
|
|
|
|
You can type `exit` to leave the environment.
|
|
|
|
## Command execution
|
|
|
|
The [`run`](cli/reference.md#hatch-run) command allows you to execute commands in an environment as if you had already entered it. For example, running the following command will output the same path as before:
|
|
|
|
```
|
|
hatch run python -c "import sys;print(sys.executable)"
|
|
```
|
|
|
|
## Scripts
|
|
|
|
You can also run any [scripts](config/environment/overview.md#scripts) that have been defined.
|
|
|
|
You'll notice that in the `pyproject.toml` file there are already scripts defined in the `default` environment. Try running the `test` command, which invokes [pytest](https://github.com/pytest-dev/pytest) with some default arguments:
|
|
|
|
```
|
|
hatch run test
|
|
```
|
|
|
|
All additional arguments are passed through to that script, so for example if you wanted to see the version of `pytest` and which plugins are installed you could do:
|
|
|
|
```
|
|
hatch run test -VV
|
|
```
|
|
|
|
## Dependencies
|
|
|
|
Hatch ensures that environments are always compatible with the currently defined [project dependencies](config/metadata.md#dependencies) (if [installed](config/environment/overview.md#skip-install) and in [dev mode](config/environment/overview.md#dev-mode)) and [environment dependencies](config/environment/overview.md#dependencies).
|
|
|
|
To add `cowsay` as a dependency, open `pyproject.toml` and add it to the [`dependencies`](config/metadata.md#dependencies) array:
|
|
|
|
```toml tab="pyproject.toml"
|
|
[project]
|
|
...
|
|
dependencies = [
|
|
"cowsay"
|
|
]
|
|
```
|
|
|
|
This dependency will be installed the next time you [spawn a shell](#entering-environments) or [run a command](#command-execution). For example:
|
|
|
|
```console
|
|
$ hatch run cowsay -t "Hello, world!"
|
|
Syncing dependencies
|
|
_____________
|
|
| Hello, world! |
|
|
=============
|
|
\
|
|
\
|
|
^__^
|
|
(oo)\_______
|
|
(__)\ )\/\
|
|
||----w |
|
|
|| ||
|
|
```
|
|
|
|
!!! note
|
|
The `Syncing dependencies` status will display temporarily when Hatch updates environments in response to any dependency changes that you make.
|
|
|
|
## Selection
|
|
|
|
You can select which environment to enter or run commands in by using the `-e`/`--env` [root option](cli/reference.md#hatch) or by setting the `HATCH_ENV` environment variable.
|
|
|
|
The [`run`](cli/reference.md#hatch-run) command allows for more explicit selection by prepending `<ENV_NAME>:` to commands. For example, if you had the following configuration:
|
|
|
|
```toml config-example
|
|
[tool.hatch.envs.docs]
|
|
dependencies = [
|
|
"mkdocs"
|
|
]
|
|
[tool.hatch.envs.docs.scripts]
|
|
build = "mkdocs build --clean --strict"
|
|
serve = "mkdocs serve --dev-addr localhost:8000"
|
|
```
|
|
|
|
you could then serve your documentation by running:
|
|
|
|
```
|
|
hatch run docs:serve
|
|
```
|
|
|
|
!!! tip
|
|
If you've already [entered](#entering-environments) an environment, commands will target it by default.
|
|
|
|
## Matrix
|
|
|
|
Every environment can define its own set of [matrices](config/environment/advanced.md#matrix):
|
|
|
|
```toml config-example
|
|
[tool.hatch.envs.test]
|
|
dependencies = [
|
|
"pytest"
|
|
]
|
|
|
|
[[tool.hatch.envs.test.matrix]]
|
|
python = ["2.7", "3.8"]
|
|
version = ["42", "3.14"]
|
|
|
|
[[tool.hatch.envs.test.matrix]]
|
|
python = ["3.8", "3.9"]
|
|
version = ["9000"]
|
|
features = ["foo", "bar"]
|
|
```
|
|
|
|
Using the [`env show`](cli/reference.md#hatch-env-show) command would then display:
|
|
|
|
```console
|
|
$ hatch env show --ascii
|
|
Standalone
|
|
+---------+---------+
|
|
| Name | Type |
|
|
+=========+=========+
|
|
| default | virtual |
|
|
+---------+---------+
|
|
Matrices
|
|
+------+---------+---------------------+--------------+
|
|
| Name | Type | Envs | Dependencies |
|
|
+======+=========+=====================+==============+
|
|
| test | virtual | test.py2.7-42 | pytest |
|
|
| | | test.py2.7-3.14 | |
|
|
| | | test.py3.8-42 | |
|
|
| | | test.py3.8-3.14 | |
|
|
| | | test.py3.8-9000-foo | |
|
|
| | | test.py3.8-9000-bar | |
|
|
| | | test.py3.9-9000-foo | |
|
|
| | | test.py3.9-9000-bar | |
|
|
+------+---------+---------------------+--------------+
|
|
```
|
|
|
|
## Removal
|
|
|
|
You can remove a single environment or environment matrix by using the [`env remove`](cli/reference.md#hatch-env-remove) command or all of a project's environments by using the [`env prune`](cli/reference.md#hatch-env-prune) command.
|