PaddlePaddle CI Build Scripts - PaddlePaddle/Paddle GitHub Wiki

#!/bin/bash
#
# This build script is used for TeamCity CI, we need to 
# set the follwoing parameters in the project configuration:
#   PARAMETER            | EXAMPLE    |   COMMENTS
# CTEST_OUTPUT_ON_FAILURE   1         // whether output failure message
# CTEST_PARALLEL_LEVEL      5         // parallel level for running ctest
# PADDLE_VERSION            0.11.0    // the latest tag
# WITH_AVX                  ON        // wheter the instruction support AVX
# WITH_GOLANG               OFF       // don't build the Golang code
# WITH_GPU                  ON        // running on GPU
# WITH_UBUNTU_MIRROR        ON        // use unbuntu mirro to speed up dev Docker image building
# WITH_CACHE                ON        // whether using the cached third-party pacakge on host


set -xe
PR_ID=$(echo %teamcity.build.vcs.branch.Paddle_PaddlePaddle% | sed 's/[^0-9]*//g')
echo ${PR_ID}

CHANGED_FILES=$(cat %system.teamcity.build.changedFiles.file% | awk -F : '{print $1}')
if [ -z "$CHANGED_FILES" ]
then
  echo "empty changed files"
else
  echo "changed files: $CHANGED_FILES"
  COUNT=$(echo $CHANGED_FILES | awk -F . '{print $NF}'|grep -i -E 'md|rst|jpg|png' | wc -l)
  FILE_COUNT=$(echo $CHANGED_FILES | wc -l)
  if [ "$COUNT" -eq "$FILE_COUNT" ]
  then
    echo "all readme files or pictures, skip CI"
    exit 0
  fi
fi

apt_mirror='s#http://archive.ubuntu.com/ubuntu#mirror://mirrors.ubuntu.com/mirrors.txt#g'

export PADDLE_DEV_NAME=paddlepaddle/paddle:dev

nvidia-docker run -i --rm -v $PWD:/paddle ${PADDLE_DEV_NAME} rm -rf /paddle/build

if [[ "%WITH_CACHE%" == "ON" ]]; then
  # Use the cached thirdparty package if the MD5 is mathes.
  md5_content=$(cat \
                ${PWD}/cmake/external/*.cmake \
                |md5sum | awk '{print $1}')

  tp_cache_dir=/root/.cache/third_party
  tp_cache_file=$tp_cache_dir/%system.teamcity.projectName%_${md5_content}.tar.gz

  if [ ! -d ${tp_cache_dir} ];then
      mkdir -p ${tp_cache_dir}
  fi
  if [ -f ${tp_cache_file} ];then
      mkdir -p ${PWD}/build
      tar zxvf ${tp_cache_file}.tar.gz -C $PWD
  else
      # clear the older tar files if MD5 has chanaged.
      rm -rf $tp_cache_dir/*.tar.gz
  fi
fi

# Check the MD5 of the Dockerfile of dev Docker image,
# if there is no current Docker iamges, delete all the older 
# dev Docker images to free up disk space.

md5_dev_dockerfile=$(cat ${PWD}/Dockerfile | md5sum | awk '{print $1}')
export PADDLE_DEV_NAME=paddlepaddle/paddle-dev:${md5_dev_dockerfile}

dev_image_id=$(docker images paddlepaddle/paddle-dev:${md5_dev_dockerfile} -q)
if [[ ${dev_image_id} == "" ]]; then
    docker rmi $(docker images paddlepaddle/paddle-dev -q) || true
    if [[ "%WITH_UBUNTU_MIRROR%" == "ON" ]]; then
        docker build -t ${PADDLE_DEV_NAME} --build-arg UBUNTU_MIRROR=mirror://mirrors.ubuntu.com/mirrors.txt .
    else
        docker build -t ${PADDLE_DEV_NAME} .
    fi
fi

# make sure CPU only build with openblas passes.
nvidia-docker run -i --rm -v $PWD:/paddle -v /root/.cache:/root/.cache\
    -e "APT_MIRROR=${apt_mirror}"\
    -e "WITH_GPU=OFF"\
    -e "WITH_AVX=%WITH_AVX%"\
    -e "WITH_GOLANG=%WITH_GOLANG%"\
    -e "WITH_TESTING=OFF"\
    -e "WITH_COVERAGE=OFF" \
    -e "COVERALLS_UPLOAD=OFF" \
    -e "GIT_PR_ID=${PR_ID}" \
    -e "WITH_C_API=%WITH_C_API%" \
    -e "CMAKE_BUILD_TYPE=Debug" \
    -e "WITH_MKL=OFF" \
    -e "JSON_REPO_TOKEN=%JSON_REPO_TOKEN%" \
    -e "WITH_DEB=OFF" \
    -e "PADDLE_VERSION=%PADDLE_VERSION%" \
    -e "PADDLE_FRACTION_GPU_MEMORY_TO_USE=0.15" \
    -e "WITH_DISTRIBUTE=ON" \
    -e "RUN_TEST=OFF" ${PADDLE_DEV_NAME}

# run build with GPU and intel MKL and test.

nvidia-docker run -i --rm -v $PWD:/paddle -v /root/.cache:/root/.cache\
    -e "FLAGS_fraction_of_gpu_memory_to_use=0.15"\
    -e "CTEST_OUTPUT_ON_FAILURE=%CTEST_OUTPUT_ON_FAILURE%"\
    -e "CTEST_PARALLEL_LEVEL=%CTEST_PARALLEL_LEVEL%"\
    -e "APT_MIRROR=${apt_mirror}"\
    -e "WITH_GPU=ON"\
    -e "CUDA_ARCH_NAME=Auto"\
    -e "WITH_AVX=%WITH_AVX%"\
    -e "WITH_GOLANG=%WITH_GOLANG%"\
    -e "WITH_TESTING=ON"\
    -e "WITH_C_API=%WITH_C_API%" \
    -e "WITH_COVERAGE=ON" \
    -e "COVERALLS_UPLOAD=ON" \
    -e "GIT_PR_ID=${PR_ID}" \
    -e "JSON_REPO_TOKEN=%JSON_REPO_TOKEN%" \
    -e "WITH_DEB=OFF" \
    -e "PADDLE_VERSION=%PADDLE_VERSION%" \
    -e "PADDLE_FRACTION_GPU_MEMORY_TO_USE=0.15" \
    -e "CUDA_VISIBLE_DEVICES=0,1" \
    -e "WITH_DISTRIBUTE=ON" \
    -e "RUN_TEST=ON" ${PADDLE_DEV_NAME}

if [[ "%WITH_CACHE" == "ON" && ! -f $tp_cache_file ]]; then
    tar czvf $tp_cache_file ./build/third_party
fi
⚠️ **GitHub.com Fallback** ⚠️