mirror of
https://github.com/invoke-ai/InvokeAI
synced 2024-08-30 20:32:17 +00:00
ff68ae7710
Add debugger config for UI
313 lines
10 KiB
Markdown
313 lines
10 KiB
Markdown
# Local Development
|
|
|
|
If you are looking to contribute you will need to have a local development
|
|
environment. See the
|
|
[Developer Install](../installation/020_INSTALL_MANUAL.md#developer-install) for
|
|
full details.
|
|
|
|
Broadly this involves cloning the repository, installing the pre-reqs, and
|
|
InvokeAI (in editable form). Assuming this is working, choose your area of
|
|
focus.
|
|
|
|
## Documentation
|
|
|
|
We use [mkdocs](https://www.mkdocs.org) for our documentation with the
|
|
[material theme](https://squidfunk.github.io/mkdocs-material/). Documentation is
|
|
written in markdown files under the `./docs` folder and then built into a static
|
|
website for hosting with GitHub Pages at
|
|
[invoke-ai.github.io/InvokeAI](https://invoke-ai.github.io/InvokeAI).
|
|
|
|
To contribute to the documentation you'll need to install the dependencies. Note
|
|
the use of `"`.
|
|
|
|
```zsh
|
|
pip install ".[docs]"
|
|
```
|
|
|
|
Now, to run the documentation locally with hot-reloading for changes made.
|
|
|
|
```zsh
|
|
mkdocs serve
|
|
```
|
|
|
|
You'll then be prompted to connect to `http://127.0.0.1:8080` in order to
|
|
access.
|
|
|
|
## Backend
|
|
|
|
The backend is contained within the `./invokeai/backend` and `./invokeai/app` directories.
|
|
To get started please install the development dependencies.
|
|
|
|
From the root of the repository run the following command. Note the use of `"`.
|
|
|
|
```zsh
|
|
pip install ".[dev,test]"
|
|
```
|
|
|
|
These are optional groups of packages which are defined within the `pyproject.toml`
|
|
and will be required for testing the changes you make to the code.
|
|
|
|
### Running Tests
|
|
|
|
We use [pytest](https://docs.pytest.org/en/7.2.x/) for our test suite. Tests can
|
|
be found under the `./tests` folder and can be run with a single `pytest`
|
|
command. Optionally, to review test coverage you can append `--cov`.
|
|
|
|
```zsh
|
|
pytest --cov
|
|
```
|
|
|
|
Test outcomes and coverage will be reported in the terminal. In addition a more
|
|
detailed report is created in both XML and HTML format in the `./coverage`
|
|
folder. The HTML one in particular can help identify missing statements
|
|
requiring tests to ensure coverage. This can be run by opening
|
|
`./coverage/html/index.html`.
|
|
|
|
For example.
|
|
|
|
```zsh
|
|
pytest --cov; open ./coverage/html/index.html
|
|
```
|
|
|
|
??? info "HTML coverage report output"
|
|
|
|
![html-overview](../assets/contributing/html-overview.png)
|
|
|
|
![html-detail](../assets/contributing/html-detail.png)
|
|
|
|
### Reloading Changes
|
|
|
|
Experimenting with changes to the Python source code is a drag if you have to re-start the server —
|
|
and re-load those multi-gigabyte models —
|
|
after every change.
|
|
|
|
For a faster development workflow, add the `--dev_reload` flag when starting the server.
|
|
The server will watch for changes to all the Python files in the `invokeai` directory and apply those changes to the
|
|
running server on the fly.
|
|
|
|
This will allow you to avoid restarting the server (and reloading models) in most cases, but there are some caveats; see
|
|
the [jurigged documentation](https://github.com/breuleux/jurigged#caveats) for details.
|
|
|
|
|
|
## Front End
|
|
|
|
<!--#TODO: get input from blessedcoolant here, for the moment inserted the frontend README via snippets extension.-->
|
|
|
|
--8<-- "invokeai/frontend/web/README.md"
|
|
|
|
## Developing InvokeAI in VSCode
|
|
|
|
VSCode offers some nice tools:
|
|
|
|
- python debugger
|
|
- automatic `venv` activation
|
|
- remote dev (e.g. run InvokeAI on a beefy linux desktop while you type in
|
|
comfort on your macbook)
|
|
|
|
### Setup
|
|
|
|
You'll need the
|
|
[Python](https://marketplace.visualstudio.com/items?itemName=ms-python.python)
|
|
and
|
|
[Pylance](https://marketplace.visualstudio.com/items?itemName=ms-python.vscode-pylance)
|
|
extensions installed first.
|
|
|
|
It's also really handy to install the `Jupyter` extensions:
|
|
|
|
- [Jupyter](https://marketplace.visualstudio.com/items?itemName=ms-toolsai.jupyter)
|
|
- [Jupyter Cell Tags](https://marketplace.visualstudio.com/items?itemName=ms-toolsai.vscode-jupyter-cell-tags)
|
|
- [Jupyter Notebook Renderers](https://marketplace.visualstudio.com/items?itemName=ms-toolsai.jupyter-renderers)
|
|
- [Jupyter Slide Show](https://marketplace.visualstudio.com/items?itemName=ms-toolsai.vscode-jupyter-slideshow)
|
|
|
|
#### InvokeAI workspace
|
|
|
|
Creating a VSCode workspace for working on InvokeAI is highly recommended. It
|
|
can hold InvokeAI-specific settings and configs.
|
|
|
|
To make a workspace:
|
|
|
|
- Open the InvokeAI repo dir in VSCode
|
|
- `File` > `Save Workspace As` > save it _outside_ the repo
|
|
|
|
#### Default python interpreter (i.e. automatic virtual environment activation)
|
|
|
|
- Use command palette to run command
|
|
`Preferences: Open Workspace Settings (JSON)`
|
|
- Add `python.defaultInterpreterPath` to `settings`, pointing to your `venv`'s
|
|
python
|
|
|
|
Should look something like this:
|
|
|
|
```jsonc
|
|
{
|
|
// I like to have all InvokeAI-related folders in my workspace
|
|
"folders": [
|
|
{
|
|
// repo root
|
|
"path": "InvokeAI"
|
|
},
|
|
{
|
|
// InvokeAI root dir, where `invokeai.yaml` lives
|
|
"path": "/path/to/invokeai_root"
|
|
}
|
|
],
|
|
"settings": {
|
|
// Where your InvokeAI `venv`'s python executable lives
|
|
"python.defaultInterpreterPath": "/path/to/invokeai_root/.venv/bin/python"
|
|
}
|
|
}
|
|
```
|
|
|
|
Now when you open the VSCode integrated terminal, or do anything that needs to
|
|
run python, it will automatically be in your InvokeAI virtual environment.
|
|
|
|
Bonus: When you create a Jupyter notebook, when you run it, you'll be prompted
|
|
for the python interpreter to run in. This will default to your `venv` python,
|
|
and so you'll have access to the same python environment as the InvokeAI app.
|
|
|
|
This is _super_ handy.
|
|
|
|
#### Enabling Type-Checking with Pylance
|
|
|
|
We use python's typing system in InvokeAI. PR reviews will include checking that types are present and correct. We don't enforce types with `mypy` at this time, but that is on the horizon.
|
|
|
|
Using a code analysis tool to automatically type check your code (and types) is very important when writing with types. These tools provide immediate feedback in your editor when types are incorrect, and following their suggestions lead to fewer runtime bugs.
|
|
|
|
Pylance, installed at the beginning of this guide, is the de-facto python LSP (language server protocol). It provides type checking in the editor (among many other features). Once installed, you do need to enable type checking manually:
|
|
|
|
- Open a python file
|
|
- Look along the status bar in VSCode for `{ } Python`
|
|
- Click the `{ }`
|
|
- Turn type checking on - basic is fine
|
|
|
|
You'll now see red squiggly lines where type issues are detected. Hover your cursor over the indicated symbols to see what's wrong.
|
|
|
|
In 99% of cases when the type checker says there is a problem, there really is a problem, and you should take some time to understand and resolve what it is pointing out.
|
|
|
|
#### Debugging configs with `launch.json`
|
|
|
|
Debugging configs are managed in a `launch.json` file. Like most VSCode configs,
|
|
these can be scoped to a workspace or folder.
|
|
|
|
Follow the [official guide](https://code.visualstudio.com/docs/python/debugging)
|
|
to set up your `launch.json` and try it out.
|
|
|
|
Now we can create the InvokeAI debugging configs:
|
|
|
|
```jsonc
|
|
{
|
|
// Use IntelliSense to learn about possible attributes.
|
|
// Hover to view descriptions of existing attributes.
|
|
// For more information, visit: https://go.microsoft.com/fwlink/?linkid=830387
|
|
"version": "0.2.0",
|
|
"configurations": [
|
|
{
|
|
// Run the InvokeAI backend & serve the pre-built UI
|
|
"name": "InvokeAI Web",
|
|
"type": "python",
|
|
"request": "launch",
|
|
"program": "scripts/invokeai-web.py",
|
|
"args": [
|
|
// Your InvokeAI root dir (where `invokeai.yaml` lives)
|
|
"--root",
|
|
"/path/to/invokeai_root",
|
|
// Access the app from anywhere on your local network
|
|
"--host",
|
|
"0.0.0.0"
|
|
],
|
|
"justMyCode": true
|
|
},
|
|
{
|
|
// Run the nodes-based CLI
|
|
"name": "InvokeAI CLI",
|
|
"type": "python",
|
|
"request": "launch",
|
|
"program": "scripts/invokeai-cli.py",
|
|
"justMyCode": true
|
|
},
|
|
{
|
|
"type": "chrome",
|
|
"request": "launch",
|
|
"name": "InvokeAI UI",
|
|
// You have to run the UI with `yarn dev` for this to work
|
|
"url": "http://localhost:5173",
|
|
"webRoot": "${workspaceFolder}/invokeai/frontend/web"
|
|
},
|
|
{
|
|
// Run tests
|
|
"name": "InvokeAI Test",
|
|
"type": "python",
|
|
"request": "launch",
|
|
"module": "pytest",
|
|
"args": ["--capture=no"],
|
|
"justMyCode": true
|
|
},
|
|
{
|
|
// Run a single test
|
|
"name": "InvokeAI Single Test",
|
|
"type": "python",
|
|
"request": "launch",
|
|
"module": "pytest",
|
|
"args": [
|
|
// Change this to point to the specific test you are working on
|
|
"tests/nodes/test_invoker.py"
|
|
],
|
|
"justMyCode": true
|
|
},
|
|
{
|
|
// This is the default, useful to just run a single file
|
|
"name": "Python: File",
|
|
"type": "python",
|
|
"request": "launch",
|
|
"program": "${file}",
|
|
"justMyCode": true
|
|
}
|
|
]
|
|
}
|
|
```
|
|
|
|
You'll see these configs in the debugging configs drop down. Running them will
|
|
start InvokeAI with attached debugger, in the correct environment, and work just
|
|
like the normal app, though the UI debugger requires you to run the UI in dev
|
|
mode. See the [frontend guide](contribution_guides/contributingToFrontend.md) for setting that up.
|
|
|
|
Enjoy debugging InvokeAI with ease (not that we have any bugs of course).
|
|
|
|
#### Remote dev
|
|
|
|
This is very easy to set up and provides the same very smooth experience as
|
|
local development. Environments and debugging, as set up above, just work,
|
|
though you'd need to recreate the workspace and debugging configs on the remote.
|
|
|
|
Consult the
|
|
[official guide](https://code.visualstudio.com/docs/remote/remote-overview) to
|
|
get it set up.
|
|
|
|
Suggest using VSCode's included settings sync so that your remote dev host has
|
|
all the same app settings and extensions automagically.
|
|
|
|
##### One remote dev gotcha
|
|
|
|
I've found the automatic port forwarding to be very flakey. You can disable it
|
|
in `Preferences: Open Remote Settings (ssh: hostname)`. Search for
|
|
`remote.autoForwardPorts` and untick the box.
|
|
|
|
To forward ports very reliably, use SSH on the remote dev client (e.g. your
|
|
macbook). Here's how to forward both backend API port (`9090`) and the frontend
|
|
live dev server port (`5173`):
|
|
|
|
```bash
|
|
ssh \
|
|
-L 9090:localhost:9090 \
|
|
-L 5173:localhost:5173 \
|
|
user@remote-dev-host
|
|
```
|
|
|
|
The forwarding stops when you close the terminal window, so suggest to do this
|
|
_outside_ the VSCode integrated terminal in case you need to restart VSCode for
|
|
an extension update or something
|
|
|
|
Now, on your remote dev client, you can open `localhost:9090` and access the UI,
|
|
now served from the remote dev host, just the same as if it was running on the
|
|
client.
|