name: LLM Nightly Tests # Controls when the action will run. on: schedule: - cron: '00 13 * * *' # GMT time, 13:00 GMT == 21:00 China pull_request: branches: [ main ] paths: - '.github/workflows/llm-nightly-test.yml' # Allows you to run this workflow manually from the Actions tab workflow_dispatch: # A workflow run is made up of one or more jobs that can run sequentially or in parallel jobs: llm-nightly-convert-test: runs-on: [ self-hosted, Gondolin, ubuntu-20.04-lts ] strategy: fail-fast: false matrix: python-version: ["3.9"] env: ORIGIN_DIR: ./llm/models LLAMA_ORIGIN_PATH: ./llm/models/llama-7b-hf GPTNEOX_ORIGIN_PATH: ./llm/models/gptneox-7b-redpajama-bf16 BLOOM_ORIGIN_PATH: ./llm/models/bloomz-7b1 INT4_CKPT_DIR: ./llm/ggml-actions/nightly LLAMA_INT4_CKPT_PATH: ./llm/ggml-actions/nightly/bigdl_llm_llama_q4_0.bin GPTNEOX_INT4_CKPT_PATH: ./llm/ggml-actions/nightly/bigdl_llm_gptneox_q4_0.bin BLOOM_INT4_CKPT_PATH: ./llm/ggml-actions/nightly/bigdl_llm_bloom_q4_0.bin steps: - uses: actions/checkout@v2 - name: Set up Python ${{ matrix.python-version }} uses: actions/setup-python@v2 with: python-version: ${{ matrix.python-version }} - name: Install dependencies run: | python -m pip install --upgrade pip python -m pip install --upgrade setuptools==58.0.4 python -m pip install --upgrade wheel - name: Download original models run: | llm_ftp_user=${RUNNER_REPOSITORY_URL:35} llm_ftp_user=$(echo $llm_ftp_user | tr '[:upper:]' '[:lower:]') llm_ftp_url=${FTP_URI:0:6}${llm_ftp_user}${FTP_URI:9}:8821 if [ ! -d $LLAMA_ORIGIN_PATH ]; then echo "Directory $LLAMA_ORIGIN_PATH not found. Downloading from FTP server..." wget -r -nH --no-verbose --cut-dirs=1 $llm_ftp_url/llm/llama-7b-hf -P $ORIGIN_DIR fi if [ ! -d $GPTNEOX_ORIGIN_PATH ]; then echo "Directory $GPTNEOX_ORIGIN_PATH not found. Downloading from FTP server..." wget -r -nH --no-verbose --cut-dirs=1 $llm_ftp_url/llm/gptneox-7b-redpajama-bf16 -P $ORIGIN_DIR fi if [ ! -d $BLOOM_ORIGIN_PATH ]; then echo "Directory $BLOOM_ORIGIN_PATH not found. Downloading from FTP server..." wget -r -nH --no-verbose --cut-dirs=1 $llm_ftp_url/llm/bloomz-7b1 -P $ORIGIN_DIR fi - name: Run LLM convert test shell: bash run: | $CONDA_HOME/bin/conda env remove -y -n bigdl-init-llm || true $CONDA_HOME/bin/conda create -n bigdl-init-llm -y python==3.9 setuptools==58.0.4 -c ${GONDOLIN_CONDA_CHANNEL} --override-channels source $CONDA_HOME/bin/activate bigdl-init-llm $CONDA_HOME/bin/conda info pip install requests bash python/llm/dev/release_default_linux.sh default false whl_name=$(ls python/llm/dist) pip install -i https://pypi.python.org/simple "python/llm/dist/${whl_name}[all]" pip install pytest bash python/llm/test/run-llm-convert-tests.sh source $CONDA_HOME/bin/deactivate $CONDA_HOME/bin/conda remove -n bigdl-init-llm --all env: ANALYTICS_ZOO_ROOT: ${{ github.workspace }} - name: Upload ckpt to ftp run: | apt-get install tnftp llm_ftp_user=${RUNNER_REPOSITORY_URL:35} llm_ftp_user=$(echo $llm_ftp_user | tr '[:upper:]' '[:lower:]') llm_ftp_url=${FTP_URI:0:6}${llm_ftp_user}${FTP_URI:9}:8821 tnftp -u ${llm_ftp_url}/${INT4_CKPT_DIR:1}/bigdl_llm_llama_7b_q4_0.bin $LLAMA_INT4_CKPT_PATH tnftp -u ${llm_ftp_url}/${INT4_CKPT_DIR:1}/bigdl_llm_redpajama_7b_q4_0.bin $GPTNEOX_INT4_CKPT_PATH tnftp -u ${llm_ftp_url}/${INT4_CKPT_DIR:1}/bigdl_llm_bloom_7b_q4_0.bin $BLOOM_INT4_CKPT_PATH