Welcome to mirror list, hosted at ThFree Co, Russian Federation.

github.com/dotnet/aspnetcore.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorNate McMaster <natemcmaster@users.noreply.github.com>2018-03-13 00:04:12 +0300
committerGitHub <noreply@github.com>2018-03-13 00:04:12 +0300
commit1c7f4142aad293587800797158aab6babb4256aa (patch)
treec90cb9c36e7125a51bd97db4cefc25bf3e53df8b /dockerbuild.sh
parent5599a963e46a07430a7be535ee77981d54627ab5 (diff)
Implement script to run build inside a local docker container (#950)
Diffstat (limited to 'dockerbuild.sh')
-rwxr-xr-xdockerbuild.sh110
1 files changed, 110 insertions, 0 deletions
diff --git a/dockerbuild.sh b/dockerbuild.sh
new file mode 100755
index 0000000000..00859a7b10
--- /dev/null
+++ b/dockerbuild.sh
@@ -0,0 +1,110 @@
+#!/usr/bin/env bash
+
+set -euo pipefail
+
+#
+# variables
+#
+
+RESET="\033[0m"
+RED="\033[0;31m"
+YELLOW="\033[0;33m"
+MAGENTA="\033[0;95m"
+DIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )"
+build_args=()
+docker_args=()
+
+#
+# Functions
+#
+__usage() {
+ echo "Usage: $(basename "${BASH_SOURCE[0]}") <image> [options] [[--] <Arguments>...]"
+ echo ""
+ echo "Arguments:"
+ echo " image The docker image to use."
+ echo " <Arguments>... Arguments passed to the command. Variable number of arguments allowed."
+ echo ""
+ echo "Options:"
+ echo " -v, --volume <VOLUME> An additional volume mount to add to the build container"
+ echo ""
+ echo "Description:"
+ echo " This will run build.sh inside the dockerfile as defined in build/docker/\$image.Dockerfile."
+
+ if [[ "${1:-}" != '--no-exit' ]]; then
+ exit 2
+ fi
+}
+
+
+__error() {
+ echo -e "${RED}error: $*${RESET}" 1>&2
+}
+
+__warn() {
+ echo -e "${YELLOW}warning: $*${RESET}"
+}
+
+__machine_has() {
+ hash "$1" > /dev/null 2>&1
+ return $?
+}
+
+#
+# main
+#
+
+image="${1:-}"
+shift || True
+
+while [[ $# -gt 0 ]]; do
+ case $1 in
+ -\?|-h|--help)
+ __usage --no-exit
+ exit 0
+ ;;
+ -v|--volume)
+ shift
+ volume_spec="${1:-}"
+ [ -z "$volume_spec" ] && __error "Missing value for parameter --volume" && __usage
+ docker_args[${#docker_args[*]}]="--volume"
+ docker_args[${#docker_args[*]}]="$volume_spec"
+ ;;
+ *)
+ build_args[${#build_args[*]}]="$1"
+ ;;
+ esac
+ shift
+done
+
+if [ -z "$image" ]; then
+ __usage --no-exit
+ __error 'Missing required argument: image'
+ exit 1
+fi
+
+if ! __machine_has docker; then
+ __error 'Missing required command: docker'
+ exit 1
+fi
+
+dockerfile="$DIR/build/docker/$image.Dockerfile"
+tagname="universe-build-$image"
+
+# Workaround for https://github.com/dotnet/cli/issues/8738 and https://github.com/Microsoft/msbuild/issues/3066
+# Run noop target because we need to generate the global.json file so we can install the matching
+# .NET Core SDK inside the Docker container.
+"$DIR/build.sh" /t:Noop
+cp "$DIR/global.json" "$(dirname "$dockerfile")"
+#endworkaround
+
+docker build "$(dirname "$dockerfile")" -f "$dockerfile" --tag $tagname
+
+docker run \
+ --rm -it \
+ -e CI \
+ -e DOTNET_CLI_TELEMETRY_OPTOUT \
+ -e Configuration \
+ -v "$DIR:/code/build" \
+ ${docker_args[@]+"${docker_args[@]}"} \
+ $tagname \
+ ${build_args[@]+"${build_args[@]}"}