mirror of
https://github.com/invoke-ai/InvokeAI
synced 2024-08-30 20:32:17 +00:00
5afb63e41b
other changes which where required: - move configure_invokeai.py into ldm.invoke - update files which imported configure_invokeai to use new location: - ldm/invoke/CLI.py - scripts/load_models.py - scripts/preload_models.py - update test-invoke-pip.yml: - remove pr type "converted_to_draft" - remove reference to dev/diffusers - remove no more needed requirements from matrix - add pytorch to matrix - install via `pip3 install --use-pep517 .` - use the created executables - this should also fix configure_invoke not executed in windows To install use `pip install --use-pep517 -e .` where `-e` is optional
145 lines
4.8 KiB
YAML
145 lines
4.8 KiB
YAML
name: Test invoke.py pip
|
|
on:
|
|
push:
|
|
branches:
|
|
- 'main'
|
|
pull_request:
|
|
types:
|
|
- 'ready_for_review'
|
|
- 'opened'
|
|
- 'synchronize'
|
|
|
|
concurrency:
|
|
group: ${{ github.workflow }}-${{ github.head_ref || github.run_id }}
|
|
cancel-in-progress: true
|
|
|
|
jobs:
|
|
matrix:
|
|
if: github.event.pull_request.draft == false
|
|
strategy:
|
|
matrix:
|
|
stable-diffusion-model:
|
|
- stable-diffusion-1.5
|
|
python-version:
|
|
# - '3.9'
|
|
- '3.10'
|
|
pytorch:
|
|
- linux-cuda-11_7
|
|
- linux-rocm-5_2
|
|
# - linux-cpu
|
|
- macos-default
|
|
# - windows-cpu
|
|
- windows-cuda-11_7
|
|
include:
|
|
- pytorch: linux-cuda-11_7
|
|
os: ubuntu-22.04
|
|
github-env: $GITHUB_ENV
|
|
- pytorch: linux-rocm-5_2
|
|
os: ubuntu-22.04
|
|
extra-index-url: 'https://download.pytorch.org/whl/rocm5.2'
|
|
github-env: $GITHUB_ENV
|
|
# - pytorch: linux-cpu
|
|
# os: ubuntu-22.04
|
|
# extra-index-url: 'https://download.pytorch.org/whl/cpu'
|
|
- pytorch: macos
|
|
os: macOS-12
|
|
github-env: $GITHUB_ENV
|
|
# - pytorch: windows-cpu
|
|
# os: windows-2022
|
|
- pytorch: windows-cuda-11_7
|
|
os: windows-2022
|
|
extra-index-url: 'https://download.pytorch.org/whl/cu117'
|
|
github-env: $env:GITHUB_ENV
|
|
name: ${{ matrix.pytorch }} on ${{ matrix.python-version }}
|
|
runs-on: ${{ matrix.os }}
|
|
env:
|
|
INVOKE_MODEL_RECONFIGURE: '--yes'
|
|
INVOKEAI_ROOT: '${{ github.workspace }}/invokeai'
|
|
PYTHONUNBUFFERED: 1
|
|
HAVE_SECRETS: ${{ secrets.HUGGINGFACE_TOKEN != '' }}
|
|
steps:
|
|
- name: Checkout sources
|
|
id: checkout-sources
|
|
uses: actions/checkout@v3
|
|
|
|
- name: set INVOKEAI_ROOT Windows
|
|
if: matrix.os == 'windows-2022'
|
|
run: |
|
|
echo "INVOKEAI_ROOT=${{ github.workspace }}\invokeai" >> ${{ matrix.github-env }}
|
|
echo "INVOKEAI_OUTDIR=${{ github.workspace }}\invokeai\outputs" >> ${{ matrix.github-env }}
|
|
|
|
- name: set INVOKEAI_ROOT others
|
|
if: matrix.os != 'windows-2022'
|
|
run: |
|
|
echo "INVOKEAI_ROOT=${{ github.workspace }}/invokeai" >> ${{ matrix.github-env }}
|
|
echo "INVOKEAI_OUTDIR=${{ github.workspace }}/invokeai/outputs" >> ${{ matrix.github-env }}
|
|
|
|
- name: Use Cached diffusers-1.5
|
|
id: cache-sd-model
|
|
uses: actions/cache@v3
|
|
env:
|
|
cache-name: huggingface-${{ matrix.stable-diffusion-model }}
|
|
with:
|
|
path: |
|
|
${{ env.INVOKEAI_ROOT }}/models/runwayml
|
|
${{ env.INVOKEAI_ROOT }}/models/stabilityai
|
|
${{ env.INVOKEAI_ROOT }}/models/CompVis
|
|
key: ${{ env.cache-name }}
|
|
|
|
- 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: setup python
|
|
uses: actions/setup-python@v4
|
|
with:
|
|
python-version: ${{ matrix.python-version }}
|
|
|
|
- name: install invokeai
|
|
run: pip3 install --use-pep517 .
|
|
env:
|
|
PIP_EXTRA_INDEX_URL: ${{ matrix.extra-index-url }}
|
|
|
|
- name: run configure_invokeai
|
|
id: run-preload-models
|
|
env:
|
|
HUGGING_FACE_HUB_TOKEN: ${{ secrets.HUGGINGFACE_TOKEN }}
|
|
run: >
|
|
configure_invokeai
|
|
--yes
|
|
--default_only
|
|
--full-precision # can't use fp16 weights without a GPU
|
|
|
|
- name: Run the tests
|
|
id: run-tests
|
|
if: matrix.os != 'windows-2022'
|
|
env:
|
|
# Set offline mode to make sure configure preloaded successfully.
|
|
HF_HUB_OFFLINE: 1
|
|
HF_DATASETS_OFFLINE: 1
|
|
TRANSFORMERS_OFFLINE: 1
|
|
run: >
|
|
invoke
|
|
--no-patchmatch
|
|
--no-nsfw_checker
|
|
--model ${{ matrix.stable-diffusion-model }}
|
|
--from_file ${{ env.TEST_PROMPTS }}
|
|
--root="${{ env.INVOKEAI_ROOT }}"
|
|
--outdir="${{ env.INVOKEAI_OUTDIR }}"
|
|
|
|
- name: Archive results
|
|
id: archive-results
|
|
if: matrix.os != 'windows-2022'
|
|
uses: actions/upload-artifact@v3
|
|
with:
|
|
name: results_${{ matrix.pytorch }}_${{ matrix.python-version }}
|
|
path: ${{ env.INVOKEAI_ROOT }}/outputs
|