mirror of
https://github.com/invoke-ai/InvokeAI
synced 2024-08-30 20:32:17 +00:00
0439b51a26
* partially working simple installer * works on linux * fix linux requirements files * read root environment variable in right place * fix cat invokeai.init in test workflows * fix classical cp error in test-invoke-pip.yml * respect --root argument now * untested bat installers added * windows install.bat now working fix logic to find frontend files * rename simple_install to "installer" 1. simple_install => 'installer' 2. source and binary install directories are removed * enable update scripts to update requirements - Also pin requirements to known working commits. - This may be a breaking change; exercise with caution - No functional testing performed yet! * update docs and installation requirements NOTE: This may be a breaking commit! Due to the way the installer works, I have to push to a public branch in order to do full end-to-end testing. - Updated installation docs, removing binary and source installers and substituting the "simple" unified installer. - Pin requirements for the "http:" downloads to known working commits. - Removed as much as possible the invoke-ai forks of others' repos. * fix directory path for installer * correct requirement/environment errors * exclude zip files in .gitignore * possible fix for dockerbuild * ready for torture testing - final Windows bat file tweaks - copy environments-and-requirements to the runtime directory so that the `update.sh` script can run. This is not ideal, since we lose control over the requirements. Better for the update script to pull the proper updated requirements script from the repository. * allow update.sh/update.bat to install arbitrary InvokeAI versions - Can pass the zip file path to any InvokeAI release, branch, commit or tag, and the installer will try to install it. - Updated documentation - Added Linux Python install hints. * use binary installer's :err_exit function * user diffusers 0.10.0 * added logic for CPPFLAGS on mac * improve windows install documentation - added information on a couple of gotchas I experienced during windows installation, including DLL loading errors experienced when Visual Studio C++ Redistributable was not present. * tagged to pull from 2.2.4-rc1 - also fix error of shell window closing immediately if suitable python not found Co-authored-by: mauwii <Mauwii@outlook.de>
147 lines
5.4 KiB
YAML
147 lines
5.4 KiB
YAML
name: Test invoke.py
|
|
on:
|
|
push:
|
|
branches:
|
|
- 'main'
|
|
- 'development'
|
|
pull_request:
|
|
branches:
|
|
- 'main'
|
|
- 'development'
|
|
|
|
jobs:
|
|
matrix:
|
|
strategy:
|
|
matrix:
|
|
stable-diffusion-model:
|
|
- 'stable-diffusion-1.5'
|
|
environment-yaml:
|
|
- environment-lin-amd.yml
|
|
- environment-lin-cuda.yml
|
|
- environment-mac.yml
|
|
- environment-win-cuda.yml
|
|
include:
|
|
- environment-yaml: environment-lin-amd.yml
|
|
os: ubuntu-22.04
|
|
curl-command: curl
|
|
github-env: $GITHUB_ENV
|
|
default-shell: bash -l {0}
|
|
- environment-yaml: environment-lin-cuda.yml
|
|
os: ubuntu-22.04
|
|
curl-command: curl
|
|
github-env: $GITHUB_ENV
|
|
default-shell: bash -l {0}
|
|
- environment-yaml: environment-mac.yml
|
|
os: macos-12
|
|
curl-command: curl
|
|
github-env: $GITHUB_ENV
|
|
default-shell: bash -l {0}
|
|
- environment-yaml: environment-win-cuda.yml
|
|
os: windows-2022
|
|
curl-command: curl.exe
|
|
github-env: $env:GITHUB_ENV
|
|
default-shell: pwsh
|
|
- stable-diffusion-model: stable-diffusion-1.5
|
|
stable-diffusion-model-url: https://huggingface.co/runwayml/stable-diffusion-v1-5/resolve/main/v1-5-pruned-emaonly.ckpt
|
|
stable-diffusion-model-dl-path: models/ldm/stable-diffusion-v1
|
|
stable-diffusion-model-dl-name: v1-5-pruned-emaonly.ckpt
|
|
name: ${{ matrix.environment-yaml }} on ${{ matrix.os }}
|
|
runs-on: ${{ matrix.os }}
|
|
env:
|
|
CONDA_ENV_NAME: invokeai
|
|
INVOKEAI_ROOT: '${{ github.workspace }}/invokeai'
|
|
defaults:
|
|
run:
|
|
shell: ${{ matrix.default-shell }}
|
|
steps:
|
|
- name: Checkout sources
|
|
id: checkout-sources
|
|
uses: actions/checkout@v3
|
|
|
|
- name: create models.yaml from example
|
|
run: |
|
|
mkdir -p ${{ env.INVOKEAI_ROOT }}/configs
|
|
cp configs/models.yaml.example ${{ env.INVOKEAI_ROOT }}/configs/models.yaml
|
|
|
|
- name: create environment.yml
|
|
run: cp "environments-and-requirements/${{ matrix.environment-yaml }}" environment.yml
|
|
|
|
- name: Use cached conda packages
|
|
id: use-cached-conda-packages
|
|
uses: actions/cache@v3
|
|
with:
|
|
path: ~/conda_pkgs_dir
|
|
key: conda-pkgs-${{ runner.os }}-${{ runner.arch }}-${{ hashFiles(matrix.environment-yaml) }}
|
|
|
|
- name: Activate Conda Env
|
|
id: activate-conda-env
|
|
uses: conda-incubator/setup-miniconda@v2
|
|
with:
|
|
activate-environment: ${{ env.CONDA_ENV_NAME }}
|
|
environment-file: environment.yml
|
|
miniconda-version: latest
|
|
|
|
- name: set test prompt to main branch validation
|
|
if: ${{ github.ref == 'refs/heads/main' }}
|
|
run: echo "TEST_PROMPTS=tests/preflight_prompts.txt" >> ${{ matrix.github-env }}
|
|
|
|
- name: set test prompt to development branch validation
|
|
if: ${{ github.ref == 'refs/heads/development' }}
|
|
run: echo "TEST_PROMPTS=tests/dev_prompts.txt" >> ${{ matrix.github-env }}
|
|
|
|
- name: set test prompt to Pull Request validation
|
|
if: ${{ github.ref != 'refs/heads/main' && github.ref != 'refs/heads/development' }}
|
|
run: echo "TEST_PROMPTS=tests/validate_pr_prompt.txt" >> ${{ matrix.github-env }}
|
|
|
|
- name: Use Cached Stable Diffusion Model
|
|
id: cache-sd-model
|
|
uses: actions/cache@v3
|
|
env:
|
|
cache-name: cache-${{ matrix.stable-diffusion-model }}
|
|
with:
|
|
path: ${{ env.INVOKEAI_ROOT }}/${{ matrix.stable-diffusion-model-dl-path }}
|
|
key: ${{ env.cache-name }}
|
|
|
|
- name: Download ${{ matrix.stable-diffusion-model }}
|
|
id: download-stable-diffusion-model
|
|
if: ${{ steps.cache-sd-model.outputs.cache-hit != 'true' }}
|
|
run: |
|
|
mkdir -p "${{ env.INVOKEAI_ROOT }}/${{ matrix.stable-diffusion-model-dl-path }}"
|
|
${{ matrix.curl-command }} -H "Authorization: Bearer ${{ secrets.HUGGINGFACE_TOKEN }}" -o "${{ env.INVOKEAI_ROOT }}/${{ matrix.stable-diffusion-model-dl-path }}/${{ matrix.stable-diffusion-model-dl-name }}" -L ${{ matrix.stable-diffusion-model-url }}
|
|
|
|
- name: run configure_invokeai.py
|
|
id: run-preload-models
|
|
run: |
|
|
python scripts/configure_invokeai.py --no-interactive --yes
|
|
|
|
- name: cat invokeai.init
|
|
id: cat-invokeai
|
|
run: cat ${{ env.INVOKEAI_ROOT }}/invokeai.init
|
|
|
|
- name: Run the tests
|
|
id: run-tests
|
|
if: matrix.os != 'windows-2022'
|
|
run: |
|
|
time python scripts/invoke.py \
|
|
--no-patchmatch \
|
|
--no-nsfw_checker \
|
|
--model ${{ matrix.stable-diffusion-model }} \
|
|
--from_file ${{ env.TEST_PROMPTS }} \
|
|
--root="${{ env.INVOKEAI_ROOT }}" \
|
|
--outdir="${{ env.INVOKEAI_ROOT }}/outputs"
|
|
|
|
- name: export conda env
|
|
id: export-conda-env
|
|
if: matrix.os != 'windows-2022'
|
|
run: |
|
|
mkdir -p outputs/img-samples
|
|
conda env export --name ${{ env.CONDA_ENV_NAME }} > ${{ env.INVOKEAI_ROOT }}/outputs/environment-${{ runner.os }}-${{ runner.arch }}.yml
|
|
|
|
- name: Archive results
|
|
if: matrix.os != 'windows-2022'
|
|
id: archive-results
|
|
uses: actions/upload-artifact@v3
|
|
with:
|
|
name: results_${{ matrix.requirements-file }}_${{ matrix.python-version }}
|
|
path: ${{ env.INVOKEAI_ROOT }}/outputs
|