@dman926/nx-python-pdm
v1.2.0
Published
[![LICENSE](https://img.shields.io/badge/license-MIT-green)](https://github.com/dman926/nx-python-pdm/blob/main/LICENSE) [![npm (scoped with tag)](https://img.shields.io/npm/v/%40dman926/nx-python-pdm/latest)](https://www.npmjs.com/package/@dman926/nx-pyt
Downloads
3
Readme
@dman926/nx-python-pdm
Use Python in NX workspaces with PDM
Installation
## Using pnpm
pnpm add -D @dman926/nx-python-pdm
## Or using npm
npm install -D @dman926/nx-python-pdm
## Or using yarn
yarn add -D @dman926/nx-python-pdm
Prerequisites
- An NX workspace
- PDM must be available to run from a terminal in the NX workspace.
Usage
Executors
- pdm - Run a command with PDM on the project
- command*: The command to run. 'pdm ' is prepended to this command.
- The default input is used for command as well. It is important to note that the remainder of the PDM command must still be wrapped in quotes.
- Ex:
nx run my-project:pdm --command="add -d wheel"
- Ex:
nx run my-project:pdm "add -d wheel"
- cwd: Override where the command runs. By default, the command runs in the project root. If provided, it should be relative to the workspace root or an absolute path.
- raw: Do not prepend
'pdm '
to the given command. - quiet: Suppress output to stdout. stderr will still be printed on process error.
- command*: The command to run. 'pdm ' is prepended to this command.
Generators
- python - Create an application or library with PDM
- name*: Name of the project.
- projectType*: Application or Library.
- application (default)
- library
- buildBackend: Override the PDM default build backend.
- pdm-backend
- setuptools
- flot
- hatchling
- e2eTestRunner: The tool to use for running E2E tests.
- cypress
- playwright
- robotframework
- linter: The tool to use for running lint checks.
- pylint
- flake8
- pycodestyle
- pylama
- mypy
- typeChecker: The tool to use for running type checks.
- mypy
- pyright
- pyre
- unitTestRunner: The tool to use for running unit tests.
- unittest (default)
- pytest
- directory: A directory where the project is placed.
- e2eDirectory: A directory where the E2E project is placed, Only used when separateE2eProject is used.
- separateE2eProject: Scaffold the E2E configuration in a separate project. Defaults to
true
. - e2eBundler: The bundler to use for running E2E tests. Only applies to cypress and playwright.
- tags: Add tags to the project (used for linting).
Targets
- build: Build the project with PDM and move the built files to
dist/{projectRoot}/
- serve: Run
src
with PDM. - test: Run unit tests with the selected unit test runner.
- lint: Run lint checks with the selected linter.
- typeCheck: Run type checks with the selected tool.
- e2e: Run end-to-end tests with the selected test runner.
- pdm: Allows running arbitrary PDM commands in the project through NX.
- See Executors for examples.