Converting an existing project to use dg
dg and Dagster Components are under active development. You may encounter feature gaps, and the APIs may change. To report issues or give feedback, please join the #dg-components channel in the Dagster Community Slack.
Suppose we have an existing Dagster project. Our project defines a Python
package with a a single Dagster asset. The asset is exposed in a top-level
Definitions object in my_existing_project/definitions.py. We'll consider
both a case where we have been using uv with pyproject.toml and pip with setup.py.
- uv
- pip
tree
.
├── my_existing_project
│   ├── __init__.py
│   ├── assets.py
│   ├── definitions.py
│   └── py.typed
├── pyproject.toml
└── uv.lock
2 directories, 6 files
tree
.
├── my_existing_project
│   ├── __init__.py
│   ├── assets.py
│   ├── definitions.py
│   └── py.typed
└── setup.py
2 directories, 5 files
dg needs to be able to resolve a Python environment for your project. This
environment must include an installation of your project package. By default,
a project's environment will resolve to whatever virtual environment is
currently activated in the shell, or system Python if no virtual environment is
activated.
Before proceeding, we'll make sure we have an activated and up-to-date virtual
environment in the project root. Having the virtual environment located in the
project root is recommended (particularly when using uv) but not required.
- uv
- pip
If you don't have a virtual environment yet, run:
uv sync
Then activate it:
source .venv/bin/activate
If you don't have a virtual environment yet, run:
python -m venv .venv
Now activate it:
source .venv/bin/activate
And install the project package as an editable install:
pip install --editable .
Install dependencies
Install the dg command line tool
- uv
- pip
We'll install dg globally as a uv tool:
uv tool install dagster-dg
This installs dg into a hidden, isolated Python environment separate from your project virtual environment. The
dg executable is always available in the user's $PATH, regardless of any virtual environment activation in the
shell. This is the recommended way to work with dg if you are using uv.
Let's install dg into your project virtual environment. This is the recommended way to work with dg if you are
using pip.
pip install dagster-dg
Update project structure
Add dg configuration
The dg command recognizes Dagster projects through the presence of TOML
configuration. This may be either a pyproject.toml file with a tool.dg section or a dg.toml file. Let's add this configuration:
- uv
- pip
Since our project already has a pyproject.toml file, we can just add
the requisite tool.dg section to the file:
...
[tool.dg]
directory_type = "project"
[tool.dg.project]
root_module = "my_existing_project"
code_location_target_module = "my_existing_project.definitions"
Since our sample project has a setup.py and no pyproject.toml,
we'll create a dg.toml file:
directory_type = "project"
[project]
root_module = "my_existing_project"
code_location_target_module = "my_existing_project.definitions"
There are three settings:
- directory_type = "project": This is how- dgidentifies your package as a Dagster project. This is required.
- project.root_module = "my_existing_project": This points to the root module of your project. This is also required.
- project.code_location_target_module = "my_existing_project.definitions": This tells- dgwhere to find the top-level- Definitionsobject in your project. This actually defaults to- [root_module].definitions, so it is not strictly necessary for us to set it here, but we are including this setting in order to be explicit--existing projects might have the top-level- Definitionsobject defined in a different module, in which case this setting is required.
Now that these settings are in place, you can interact with your project using dg. If we run dg list defs we can see the sole existing asset in our project:
dg list defs
┏━━━━━━━━━┳━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━┓
┃ Section ┃ Definitions                                         ┃
┡━━━━━━━━━╇━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━┩
│ Assets  │ ┏━━━━━━━━━━┳━━━━━━━━━┳━━━━━━┳━━━━━━━┳━━━━━━━━━━━━━┓ │
│         │ ┃ Key      ┃ Group   ┃ Deps ┃ Kinds ┃ Description ┃ │
│         │ ┡━━━━━━━━━━╇━━━━━━━━━╇━━━━━━╇━━━━━━━╇━━━━━━━━━━━━━┩ │
│         │ │ my_asset │ default │      │       │             │ │
│         │ └──────────┴─────────┴──────┴───────┴─────────────┘ │
└─────────┴─────────────────────────────────────────────────────┘