Commit 35082ab6 authored by mchrusci's avatar mchrusci Committed by Robert Kimball

[ONNX CI] CI Speedup (#1674)

* CI speedup and simplification

* Rebuild cached master when branch build fails

* Fixed sed command

* Fixed cahced nGraph path

* Exit function if cmake or make fails

* Fixed build path

* Fail building in case cached ngraph is not built

* Ensure cached nGraph is on master before pulling
parent f6e4323f
...@@ -88,7 +88,7 @@ def PrepareEnvironment(configurationMaps) { ...@@ -88,7 +88,7 @@ def PrepareEnvironment(configurationMaps) {
UTILS.PropagateStatus("Run_docker_containers", configMap["dockerContainerName"]) UTILS.PropagateStatus("Run_docker_containers", configMap["dockerContainerName"])
sh """ sh """
docker cp ${CI_ROOT}/utils/docker.sh ${configMap["dockerContainerName"]}:/home docker cp ${CI_ROOT}/utils/docker.sh ${configMap["dockerContainerName"]}:/home
docker exec ${configMap["dockerContainerName"]} bash -c "/root/${CI_ROOT}/prepare_environment.sh --ngraph-branch=$ghprbSourceBranch" docker exec ${configMap["dockerContainerName"]} bash -c "/root/${CI_ROOT}/prepare_environment.sh"
""" """
} }
UTILS.CreateStage("Prepare_environment", prepareEnvironmentMethod, configurationMaps) UTILS.CreateStage("Prepare_environment", prepareEnvironmentMethod, configurationMaps)
......
...@@ -16,37 +16,56 @@ ...@@ -16,37 +16,56 @@
# otherwise. Any license under such intellectual property rights must be express # otherwise. Any license under such intellectual property rights must be express
# and approved by Intel in writing. # and approved by Intel in writing.
set -x
set -e
PATTERN='[-a-zA-Z0-9_]*=' NGRAPH_CACHE_DIR="/home"
for i in "$@"
do
case $i in
--help*)
printf "Following parameters are available:
--help displays this message
--ngraph-branch ngraph branch name to build
"
exit 0
;;
--ngraph-branch=*)
NGRAPH_BRANCH=`echo $i | sed "s/${PATTERN}//"`
;;
esac
done
set -x function check_cached_ngraph() {
# if no ngraph in /home - clone
if [ ! -e "${NGRAPH_CACHE_DIR}/ngraph" ]; then
cd /home/
git clone --single-branch https://github.com/NervanaSystems/ngraph -b master
fi
}
function build_ngraph() { function build_ngraph() {
# directory containing ngraph repo # directory containing ngraph repo
local ngraph_directory="$1" local ngraph_directory="$1"
local func_parameters="$2"
cd "${ngraph_directory}/ngraph"
for parameter in $func_parameters
do
case $parameter in
REBUILD)
rm -rf "${ngraph_directory}/ngraph/build"
rm -rf "${ngraph_directory}/ngraph_dist"
;;
UPDATE)
git checkout master
git pull origin master
;;
USE_CACHED)
check_cached_ngraph
if [[ -n $(ls /home/ngraph/build 2> /dev/null) ]]; then
cp -Rf "${NGRAPH_CACHE_DIR}/ngraph/build" "${ngraph_directory}/ngraph/" || return 1
else
return 1
fi
for f in $(find ${ngraph_directory}/ngraph/build/ -name 'CMakeCache.txt');
do
sed -i "s\\${NGRAPH_CACHE_DIR}\\${ngraph_directory}\\g" $f
done
;;
esac
done
cd "${ngraph_directory}/ngraph" cd "${ngraph_directory}/ngraph"
mkdir -p ./build mkdir -p ./build
cd ./build cd ./build
cmake ../ -DNGRAPH_USE_PREBUILT_LLVM=TRUE -DNGRAPH_ONNX_IMPORT_ENABLE=TRUE -DCMAKE_INSTALL_PREFIX="${ngraph_directory}/ngraph_dist" cmake ../ -DNGRAPH_TOOLS_ENABLE=FALSE -DNGRAPH_UNIT_TEST_ENABLE=FALSE -DNGRAPH_USE_PREBUILT_LLVM=TRUE -DNGRAPH_ONNX_IMPORT_ENABLE=TRUE -DCMAKE_INSTALL_PREFIX="${ngraph_directory}/ngraph_dist" || return 1
rm "${ngraph_directory}"/ngraph/python/dist/ngraph*.whl rm -f "${ngraph_directory}"/ngraph/python/dist/ngraph*.whl
make -j $(lscpu --parse=CORE | grep -v '#' | sort | uniq | wc -l) make -j $(lscpu --parse=CORE | grep -v '#' | sort | uniq | wc -l) || return 1
make install make install || return 1
cd "${ngraph_directory}/ngraph/python" cd "${ngraph_directory}/ngraph/python"
if [ ! -d ./pybind11 ]; then if [ ! -d ./pybind11 ]; then
git clone --recursive -b allow-nonconstructible-holders https://github.com/jagerman/pybind11.git git clone --recursive -b allow-nonconstructible-holders https://github.com/jagerman/pybind11.git
...@@ -54,30 +73,15 @@ function build_ngraph() { ...@@ -54,30 +73,15 @@ function build_ngraph() {
export PYBIND_HEADERS_PATH="${ngraph_directory}/ngraph/python/pybind11" export PYBIND_HEADERS_PATH="${ngraph_directory}/ngraph/python/pybind11"
export NGRAPH_CPP_BUILD_PATH="${ngraph_directory}/ngraph_dist" export NGRAPH_CPP_BUILD_PATH="${ngraph_directory}/ngraph_dist"
python3 setup.py bdist_wheel python3 setup.py bdist_wheel
return 0
} }
# Clone and build nGraph master # Copy stored nGraph master and use it to build PR branch
cd /home if ! build_ngraph "/root" "USE_CACHED"; then
if [ -e ./ngraph ]; then build_ngraph "${NGRAPH_CACHE_DIR}" "UPDATE REBUILD"
cd ./ngraph build_ngraph "/root" "REBUILD USE_CACHED"
if [[ $(git pull) != *"Already up-to-date"* ]]; then
build_ngraph "/home"
fi
else
git clone https://github.com/NervanaSystems/ngraph.git -b master
build_ngraph "/home"
fi fi
cp -R /home/ngraph/build /root/ngraph/
cp -R /home/ngraph_dist /root/
# Change directory to ngraph cloned initially by CI, which is already on relevant branch
cd /root/ngraph
for f in $(find build/ -name 'CMakeCache.txt');
do
sed -i 's/home/root/g' $f
done
build_ngraph "/root"
# Copy Onnx models # Copy Onnx models
if [ -d /home/onnx_models/.onnx ]; then if [ -d /home/onnx_models/.onnx ]; then
rsync -avhz /home/onnx_models/.onnx /root/ngraph-onnx/ rsync -avhz /home/onnx_models/.onnx /root/ngraph-onnx/
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment