Metadata-Version: 2.4
Name: packse
Version: 0.3.57
Author-email: "Astral Software Inc." <hey@astral.sh>
License-File: LICENSE-APACHE
License-File: LICENSE-MIT
Keywords: packaging,packse,requirements,testing,uv
Classifier: Development Status :: 4 - Beta
Classifier: Environment :: Console
Classifier: Intended Audience :: Developers
Classifier: License :: OSI Approved :: Apache Software License
Classifier: License :: OSI Approved :: MIT License
Classifier: Operating System :: OS Independent
Classifier: Programming Language :: Python
Classifier: Programming Language :: Python :: 3 :: Only
Classifier: Programming Language :: Python :: 3.12
Classifier: Topic :: Software Development :: Libraries
Classifier: Topic :: Software Development :: Quality Assurance
Classifier: Topic :: Software Development :: Testing
Requires-Python: >=3.12
Requires-Dist: chevron-blue>=0.2.1
Requires-Dist: hatchling>=1.20.0
Requires-Dist: msgspec>=0.18.4
Requires-Dist: packaging>=24.2
Requires-Dist: pyyaml>=6.0.1
Requires-Dist: uv>=0.8
Provides-Extra: index
Requires-Dist: fastapi>=0.116.1; extra == 'index'
Requires-Dist: starlette>=0.47.3; extra == 'index'
Requires-Dist: uvicorn>=0.35.0; extra == 'index'
Provides-Extra: serve
Requires-Dist: fastapi>=0.116.1; extra == 'serve'
Requires-Dist: starlette>=0.47.3; extra == 'serve'
Requires-Dist: uvicorn>=0.35.0; extra == 'serve'
Requires-Dist: watchfiles>=0.21.0; extra == 'serve'
Description-Content-Type: text/markdown

# packse

Python packaging scenarios.

## Installation

Install from PyPI:

```bash
uv pip install packse
```

Once installed, the `packse` command-line interface will be available.

## Usage

### Scenarios

A scenario is a JSON description of a dependency tree.

See [`scenarios/examples/`](./scenarios/examples/)

Each scenario file can contain one or more scenarios.

### Listing scenarios

A list of available scenarios can be printed with the `list` command:

```bash
packse list
```

By default, packse will search for scenarios in the current tree. You may also pass a file to read
from:

```bash
packse list scenarios/examples/example.json
```

Each scenario will be listed with its unique identifier e.g. `example-cd797223`. This is the name of the package
that can be installed to run the scenario once it is built and published.

Each `packse` command supports reading multiple scenario files. For example, with `list`:

```bash
packse list scenarios/examples/example.json scenarios/requires-does-not-exist.json
```

### Viewing scenarios

The dependency tree of a scenario can be previewed using the `view` command:

```
$ packse view scenarios/examples/example.json
example-89cac9f1
├── root
│   └── requires a
│       └── satisfied by a-1.0.0
├── a
│   └── a-1.0.0
│       └── requires b>1.0.0
│           ├── satisfied by b-2.0.0
│           └── satisfied by b-3.0.0
└── b
    ├── b-1.0.0
    ├── b-2.0.0
    │   └── requires c
    │       └── unsatisfied: no versions for package
    └── b-3.0.0
```

Note the `view` command will view all scenarios in a file by default. A single scenario can be viewed by providing
the `--name` option:

```
$ packse view scenarios/examples/example.json --name example
example

This is an example scenario, in which the user depends on a single package `a` which requires `b`

example-89cac9f1
├── root
│   └── requires a
│       └── satisfied by a-1.0.0
├── a
│   └── a-1.0.0
│       └── requires b>1.0.0
│           ├── satisfied by b-2.0.0
│           └── satisfied by b-3.0.0
└── b
    ├── b-1.0.0
    ├── b-2.0.0
    │   └── requires c
    │       └── unsatisfied: no versions for package
    └── b-3.0.0
```

Notice, when a specific scenario is specified, there is more information displayed.

### Building scenarios

A scenario can be used to generate packages and build distributions:

```bash
packse build scenario/example.toml
```

The `build/` directory will contain sources for all of the packages in the scenario.
The `dist/` directory will contain built distributions for all of the packages in the scenario.

When a scenario is built, it is given a unique identifier based on a hash of the scenario contents and the project
templates used to generate the packages. Each package and requirement in the scenario will be prefixed with the
identifier. The unique identifier can be excluded using the `--no-hash` argument, however, this will prevent
publishing multiple times to a registry that does not allow overwrites.

The `PACKSE_VERSION_SEED` environment variable can be used to override the seed used to generate the unique
identifier, allowing versions to differ based on information outside of packse.

### Running a package index

_Requires installation with the `serve` extra_

To start a local package index:

```bash
packse serve
```

Packages can be installed by passing the `--index-url` flag to the installer e.g. with `pip`:

```bash
pip install --index-url http://127.0.0.1:3141/simple-html example-a-e656679f
```

To also include build dependencies, use the `/vendor` subdirectory:

```bash
pip install --index-url http://127.0.0.1:3141/simple-html --find-links http://127.0.0.1:3141/vendor example-a-e656679f
```

Packse will watch for changes to the `scenarios` directory, and publish new versions on each change.

Note when developing, it is often useful to use the `--no-hash` flag to avoid having to determine the latest
hash for the scenario.

### Building a package index

_Requires installation with the `index` extra_

Packse can build a file tree that can be served statically, for example, through GitHub Pages, that serve both
the scenarios and the vendored build dependencies, using the `index` command:

```bash
packse index build
```

This creates three directories in `./index`:

 * `./index/files`: The distributions.
 * `./index/simple-html`: The simple HTML index (PEP 503).
 * `./index/vendor`: A flat index of build dependencies.

### Testing scenarios

Published scenarios can then be tested with your choice of package manager.

For example, with `pip`:

```bash
pip install -i https://astral-sh.github.io/packse/548262f/simple-html/ example-cd797223
```

### Exporting scenarios

Scenario information can be exported with the `packse inspect`. This creates a JSON representation of the scenarios
with additional generated information such as the root package name and the tree displayed during `packse view`.

### Writing new scenarios

Scenario files may contain one or more scenarios written in JSON. See the existing scenarios for examples and
the `Scenario` type for details on the supported schema.
