Skip to content

feat: Add ONNX

feat: Add ONNX #226

name: Build and Push Preset Models
on:
pull_request:
branches:
- main
paths:
- 'presets/tfs/**'
- 'presets/llama-2/**'
- 'presets/llama-2-chat/**'
push:
branches:
- main
paths:
- 'presets/tfs/**'
- 'presets/llama-2/**'
- 'presets/llama-2-chat/**'
workflow_dispatch:
inputs:
image_tag_name:
description: 'Image Tag'
required: true
permissions:
id-token: write
contents: read
env:
VERSION: 0.0.1
jobs:
setup:
runs-on: [self-hosted, 'username:runner-0']
outputs:
image_tag: ${{ steps.set_tag.outputs.image_tag }}
FALCON_MODIFIED: ${{ steps.check_modified_paths.outputs.FALCON_MODIFIED }}
LLAMA2_MODIFIED: ${{ steps.check_modified_paths.outputs.LLAMA2_MODIFIED }}
LLAMA2_CHAT_MODIFIED: ${{ steps.check_modified_paths.outputs.LLAMA2_CHAT_MODIFIED }}
steps:
- name: Checkout
uses: actions/checkout@v4
with:
submodules: true
fetch-depth: 0
- name: Check Available Disk Space
run: df -h
- name: Get Modified files
run: |
git checkout --detach
git fetch origin main:main
current_branch=$(git rev-parse --abbrev-ref HEAD)
if [ "$current_branch" == "main" ] || [ "$current_branch" == "master" ]; then
files=$(git diff --name-only HEAD^ HEAD)
else
files=$(git diff --name-only origin/main...HEAD)
fi
echo "Modified files: $files"
FILES_MODIFIED=""
while IFS= read -r file; do
trimmed_file=$(echo "$file" | tr -d '[:space:]')
echo "Trimmed file: $trimmed_file"
FILES_MODIFIED="${FILES_MODIFIED}${trimmed_file};"
done <<< "$files"
echo "FILES_MODIFIED=${FILES_MODIFIED}" >> $GITHUB_ENV
- name: Check Modified Paths
id: check_modified_paths
run: |
FALCON_MODIFIED=false
LLAMA2_MODIFIED=false
LLAMA2_CHAT_MODIFIED=false
IFS=';' read -ra ADDR <<< "$FILES_MODIFIED"
for file in "${ADDR[@]}"; do
echo "Checking file: $file"
if [[ "$file" == presets/tfs/* ]] && [[ "$FALCON_MODIFIED" == false ]]; then
echo "File matches falcon path: $file"
FALCON_MODIFIED=true
elif [[ "$file" == presets/llama-2/* ]] && [[ "$LLAMA2_MODIFIED" == false ]]; then
echo "File matches llama-2 path: $file"
LLAMA2_MODIFIED=true
elif [[ "$file" == presets/llama-2-chat/* ]] && [[ "$LLAMA2_CHAT_MODIFIED" == false ]]; then
echo "File matches llama-2-chat path: $file"
LLAMA2_CHAT_MODIFIED=true
else
echo "File does not match any paths: $file"
fi
done
echo "FALCON_MODIFIED=$FALCON_MODIFIED" >> $GITHUB_OUTPUT
echo "LLAMA2_MODIFIED=$LLAMA2_MODIFIED" >> $GITHUB_OUTPUT
echo "LLAMA2_CHAT_MODIFIED=$LLAMA2_CHAT_MODIFIED" >> $GITHUB_OUTPUT
- name: Models to Build
run: |
echo "FALCON_MODIFIED for this job: ${{ steps.check_modified_paths.outputs.FALCON_MODIFIED }}"
echo "LLAMA2_MODIFIED for this job: ${{ steps.check_modified_paths.outputs.LLAMA2_MODIFIED }}"
echo "LLAMA2_CHAT_MODIFIED for this job: ${{ steps.check_modified_paths.outputs.LLAMA2_CHAT_MODIFIED }}"
- name: Set Image Tag
id: set_tag
run: |
if [[ "${{ github.event_name }}" == "workflow_dispatch" && -n "${{ github.event.inputs.image_tag_name }}" ]]; then
echo "Using workflow dispatch to set image tag"
echo "image_tag=${{ github.event.inputs.image_tag_name }}" >> $GITHUB_OUTPUT
else
echo "Setting image tag based on version set"
echo "image_tag=${{ env.VERSION }}" >> $GITHUB_OUTPUT
fi
- name: Print Image Tag
run: |
echo "image_tag for this job: ${{ steps.set_tag.outputs.image_tag }}"
- name: Save registry and tag as an artifact for other workflows
run: |
sudo mkdir -p /tmp/artifacts
sudo chmod 777 /tmp/artifacts
echo ${{ steps.set_tag.outputs.image_tag }} | sudo tee /tmp/artifacts/tag.txt
sudo chmod 666 /tmp/artifacts/tag.txt
# ls -l /tmp/artifacts # Check the permissions of the directory contents
cat /tmp/artifacts/tag.txt
- name: Upload image tag as artifact
uses: actions/upload-artifact@v3
with:
name: artifacts
path: /tmp/artifacts
- name: Install Azure CLI latest
run: |
if ! which az > /dev/null; then
echo "Azure CLI not found. Installing..."
curl -sL https://aka.ms/InstallAzureCLIDeb | sudo bash
else
echo "Azure CLI already installed."
fi
matrix_prep:
needs: setup
runs-on: self-hosted
outputs:
matrix: ${{ steps.set_matrix.outputs.matrix }}
matrix_empty: ${{ steps.set_matrix.outputs.matrix_empty }}
steps:
- name: Checkout
uses: actions/checkout@v4
with:
submodules: true
fetch-depth: 0
- name: "Set matrix"
id: set_matrix
run: |
matrix=$(jq --arg FALCON_MODIFIED "${{ needs.setup.outputs.FALCON_MODIFIED }}" --arg LLAMA2_MODIFIED "${{ needs.setup.outputs.LLAMA2_MODIFIED }}" --arg LLAMA2_CHAT_MODIFIED "${{ needs.setup.outputs.LLAMA2_CHAT_MODIFIED }}" 'map(
. | select((.shouldBuildFalcon == $FALCON_MODIFIED) or (.shouldBuildLlama2 == $LLAMA2_MODIFIED) or (.shouldBuildLlama2Chat == $LLAMA2_CHAT_MODIFIED))
)' .github/matrix-configs.json)
# Check if matrix is empty and set an output variable
if [[ $matrix == "[]" ]]; then
echo "matrix_empty=true" >> $GITHUB_OUTPUT
else
echo "matrix_empty=false" >> $GITHUB_OUTPUT
fi
echo "matrix={\"include\":$(echo $matrix)}" >> $GITHUB_OUTPUT
build-models:
needs: [setup, matrix_prep]
runs-on: self-hosted
if: ${{needs.matrix_prep.outputs.matrix_empty == 'false'}}
strategy:
fail-fast: false
matrix: ${{fromJson(needs.matrix_prep.outputs.matrix)}}
steps:
- name: Checkout
uses: actions/checkout@v4
with:
submodules: true
fetch-depth: 0
# - name: 'Az CLI login'
# uses: azure/login@v1.4.6
# with:
# client-id: ${{ secrets.AZURE_CLIENT_ID }}
# tenant-id: ${{ secrets.AZURE_TENANT_ID }}
# allow-no-subscriptions: true
# - name: 'Set subscription'
# run: az account set --subscription ${{secrets.AZURE_SUBSCRIPTION_ID}}
- name: 'Get ACR Name'
id: acr_name
run: |
if [[ "${{ github.event_name }}" == "workflow_dispatch" && -n "${{ github.event.inputs.image_tag_name }}" ]]; then
ACR_NAME="aimodelsregistry"
ACR_CLIENT_ID=${{ secrets.AZURE_AMR_CLIENT_ID }}
ACR_CLIENT_SECRET=${{ secrets.AZURE_AMR_CLIENT_SECRET }}
else
ACR_NAME="aimodelsregistrytest"
ACR_CLIENT_ID=${{ secrets.AZURE_AMRT_CLIENT_ID }}
ACR_CLIENT_SECRET=${{ secrets.AZURE_AMRT_CLIENT_SECRET }}
fi
echo "ACR_NAME=$ACR_NAME" >> $GITHUB_OUTPUT
echo "ACR_CLIENT_ID=$ACR_CLIENT_ID" >> $GITHUB_OUTPUT
echo "ACR_CLIENT_SECRET=$ACR_CLIENT_SECRET" >> $GITHUB_OUTPUT
- name: Docker login
uses: docker/login-action@v3
with:
registry: ${{ steps.acr_name.outputs.ACR_NAME }}.azurecr.io
username: ${{ secrets.ACR_AMRT_USERNAME }}
password: ${{ secrets.ACR_AMRT_PASSWORD }}
# run: |
# # Echo the current working directory
# echo "Current Working Directory:"
# pwd
# if [[ "${{ steps.acr_name.outputs.ACR_NAME }}" == "aimodelsregistry" ]]; then
# echo ${{ secrets.ACR_AMR_PASSWORD }} | sudo docker login ${{ steps.acr_name.outputs.ACR_NAME }}.azurecr.io --username ${{ secrets.ACR_AMR_USERNAME }} --password-stdin
# else
# echo ${{ secrets.ACR_AMRT_PASSWORD }} | sudo docker login ${{ steps.acr_name.outputs.ACR_NAME }}.azurecr.io --username ${{ secrets.ACR_AMRT_USERNAME }} --password-stdin
# fi
- name: Build model (with retries)
run: |
retries=3
while [ $retries -gt 0 ]; do
BUILD_ARGS="${{ matrix.model.build_args }}"
echo "Docker BUILD_ARGS: $BUILD_ARGS"
sudo docker build $BUILD_ARGS \
-t ${{ steps.acr_name.outputs.ACR_NAME }}.azurecr.io/${{ matrix.model.name }}:${{ needs.setup.outputs.image_tag }} \
-f /home/kaito/${{ matrix.model.dockerfile }} \
. && break
retries=$((retries-1))
sleep 15
done
if [ $retries -eq 0 ]; then
echo "Docker build failed after 3 retries."
exit 1
fi
- name: Push model to ACR (with retries)
run: |
retries=3
while [ $retries -gt 0 ]; do
# Push the Docker image to ACR
sudo docker push ${{ steps.acr_name.outputs.ACR_NAME }}.azurecr.io/${{ matrix.model.name }}:${{ needs.setup.outputs.image_tag }}
# Check if the push was successful
if [ $? -eq 0 ]; then
echo "Docker push successful!"
break
else
echo "Docker push failed. Retrying..."
retries=$((retries-1))
sleep 15
fi
done
if [ $retries -eq 0 ]; then
echo "Docker push failed after 3 retries."
exit 1
fi