![Livar Cunha](/assets/img/avatar_default.png)
* dotnet/release/2.0.0: (72 commits) Updating the signing project to reflect the new location of the resolver. Another update to MSBuild. To 15.3.0-preview-000385-01. Another update to msbuild. To 15.3.0-preview-000385-01. Update to SetupCrossgen 183 - Coherence 25615 Don't include .NET Core MS.NET.Build.Extensions tasks for .NET Framework and vice versa Update version of SDK and MS.NET.Build.Extensions, adapt to layout change Updating MSBuild to 15.3.0-preview-000384-01 Update MSBuild to 15.3.0-preview-000384-01 test pack command Changing NuGet version to Preview3-4154 Updating NuGet version to Preview3-4154 Add Microsoft.NET.Build.Extensions files to package for VS insertion reenable smoke test of F# templates empty commit Don't try to CrossGen .NET Framework support DLLs Update test platform to 15.3.0-preview-20170609-02. Turning off implicit restore when publishing the build project. Updating the vstest.console to use the same runtime that is shipping with the CLI. Update to template build 256 to fix Web Auth scenarios Add test for consuming .NET Standard 2.0 library from .NET Framework 4.6.1 project ...
196 lines
6.8 KiB
Bash
Executable file
196 lines
6.8 KiB
Bash
Executable file
#!/usr/bin/env bash
|
|
#
|
|
# Copyright (c) .NET Foundation and contributors. All rights reserved.
|
|
# Licensed under the MIT license. See LICENSE file in the project root for full license information.
|
|
#
|
|
|
|
set -e
|
|
|
|
machine_has() {
|
|
hash "$1" > /dev/null 2>&1
|
|
return $?
|
|
}
|
|
|
|
check_min_reqs() {
|
|
if ! machine_has "curl"; then
|
|
echo "run-build: Error: curl is required to download dotnet. Install curl to proceed." >&2
|
|
return 1
|
|
fi
|
|
return 0
|
|
}
|
|
|
|
# args:
|
|
# remote_path - $1
|
|
# [out_path] - $2 - stdout if not provided
|
|
download() {
|
|
eval $invocation
|
|
|
|
local remote_path=$1
|
|
local out_path=${2:-}
|
|
|
|
local failed=false
|
|
if [ -z "$out_path" ]; then
|
|
curl --retry 10 -sSL --create-dirs $remote_path || failed=true
|
|
else
|
|
curl --retry 10 -sSL --create-dirs -o $out_path $remote_path || failed=true
|
|
fi
|
|
|
|
if [ "$failed" = true ]; then
|
|
echo "run-build: Error: Download failed" >&2
|
|
return 1
|
|
fi
|
|
}
|
|
|
|
SOURCE="${BASH_SOURCE[0]}"
|
|
while [ -h "$SOURCE" ]; do # resolve $SOURCE until the file is no longer a symlink
|
|
DIR="$( cd -P "$( dirname "$SOURCE" )" && pwd )"
|
|
SOURCE="$(readlink "$SOURCE")"
|
|
[[ "$SOURCE" != /* ]] && SOURCE="$DIR/$SOURCE" # if $SOURCE was a relative symlink, we need to resolve it relative to the path where the symlink file was located
|
|
done
|
|
DIR="$( cd -P "$( dirname "$SOURCE" )" && pwd )"
|
|
REPOROOT="$DIR"
|
|
|
|
ARCHITECTURE="x64"
|
|
source "$REPOROOT/scripts/common/_prettyprint.sh"
|
|
|
|
BUILD=1
|
|
|
|
LINUX_PORTABLE_INSTALL_ARGS=
|
|
CUSTOM_BUILD_ARGS=
|
|
|
|
# Set nuget package cache under the repo
|
|
[ -z $NUGET_PACKAGES ] && export NUGET_PACKAGES="$REPOROOT/.nuget/packages"
|
|
|
|
args=( "$@" )
|
|
|
|
while [[ $# > 0 ]]; do
|
|
lowerI="$(echo $1 | awk '{print tolower($0)}')"
|
|
case $lowerI in
|
|
-c|--configuration)
|
|
export CONFIGURATION=$2
|
|
args=( "${args[@]/$1}" )
|
|
args=( "${args[@]/$2}" )
|
|
shift
|
|
;;
|
|
--nopackage)
|
|
export DOTNET_BUILD_SKIP_PACKAGING=1
|
|
args=( "${args[@]/$1}" )
|
|
;;
|
|
--skip-prereqs)
|
|
# Allow CI to disable prereqs check since the CI has the pre-reqs but not ldconfig it seems
|
|
export DOTNET_INSTALL_SKIP_PREREQS=1
|
|
args=( "${args[@]/$1}" )
|
|
;;
|
|
--nobuild)
|
|
BUILD=0
|
|
;;
|
|
--architecture)
|
|
ARCHITECTURE=$2
|
|
args=( "${args[@]/$1}" )
|
|
args=( "${args[@]/$2}" )
|
|
shift
|
|
;;
|
|
--runtime-id)
|
|
CUSTOM_BUILD_ARGS="/p:Rid=\"$2\""
|
|
args=( "${args[@]/$1}" )
|
|
args=( "${args[@]/$2}" )
|
|
shift
|
|
;;
|
|
# This is here just to eat away this parameter because CI still passes this in.
|
|
--targets)
|
|
args=( "${args[@]/$1}" )
|
|
args=( "${args[@]/$2}" )
|
|
shift
|
|
;;
|
|
--linux-portable)
|
|
LINUX_PORTABLE_INSTALL_ARGS="--runtime-id linux-x64"
|
|
CUSTOM_BUILD_ARGS="/p:Rid=\"linux-x64\" /p:OSName=\"linux\""
|
|
args=( "${args[@]/$1}" )
|
|
;;
|
|
--help)
|
|
echo "Usage: $0 [--configuration <CONFIGURATION>] [--targets <TARGETS...>] [--skip-prereqs] [--nopackage] [--docker <IMAGENAME>] [--help]"
|
|
echo ""
|
|
echo "Options:"
|
|
echo " --configuration <CONFIGURATION> Build the specified Configuration (Debug or Release, default: Debug)"
|
|
echo " --skip-prereqs Skip checks for pre-reqs in dotnet_install"
|
|
echo " --nopackage Skip packaging targets"
|
|
echo " --nobuild Skip building, showing the command that would be used to build"
|
|
echo " --docker <IMAGENAME> Build in Docker using the Dockerfile located in scripts/docker/IMAGENAME"
|
|
echo " --linux-portable Builds the Linux portable .NET Tools instead of a distro-specific version."
|
|
echo " --help Display this help message"
|
|
exit 0
|
|
;;
|
|
*)
|
|
break
|
|
;;
|
|
esac
|
|
|
|
shift
|
|
done
|
|
|
|
# $args array may have empty elements in it.
|
|
# The easiest way to remove them is to cast to string and back to array.
|
|
# This will actually break quoted arguments, arguments like
|
|
# -test "hello world" will be broken into three arguments instead of two, as it should.
|
|
temp="${args[@]}"
|
|
args=($temp)
|
|
|
|
# Create an install directory for the stage 0 CLI
|
|
[ -z "$DOTNET_INSTALL_DIR" ] && export DOTNET_INSTALL_DIR=$REPOROOT/.dotnet_stage0/$ARCHITECTURE
|
|
[ -d "$DOTNET_INSTALL_DIR" ] || mkdir -p $DOTNET_INSTALL_DIR
|
|
|
|
# We also need to pull down a project.json based CLI that is used by some tests
|
|
# so create another directory for that.
|
|
[ -z "$DOTNET_INSTALL_DIR_PJ" ] && export DOTNET_INSTALL_DIR_PJ=$REPOROOT/.dotnet_stage0PJ/$ARCHITECTURE
|
|
[ -d "$DOTNET_INSTALL_DIR_PJ" ] || mkdir -p $DOTNET_INSTALL_DIR_PJ
|
|
|
|
export DOTNET_SKIP_FIRST_TIME_EXPERIENCE=1
|
|
|
|
# Enable verbose VS Test Console logging
|
|
export VSTEST_BUILD_TRACE=1
|
|
export VSTEST_TRACE_BUILD=1
|
|
|
|
|
|
# Don't resolve shared frameworks from user or global locations
|
|
DOTNET_MULTILEVEL_LOOKUP=0
|
|
|
|
# Install a stage 0
|
|
(set -x ; "$REPOROOT/scripts/obtain/dotnet-install.sh" --channel "release/2.0.0" --install-dir "$DOTNET_INSTALL_DIR" --architecture "$ARCHITECTURE" $LINUX_PORTABLE_INSTALL_ARGS --version "2.0.0-preview2-006437")
|
|
|
|
EXIT_CODE=$?
|
|
if [ $EXIT_CODE != 0 ]; then
|
|
echo "run-build: Error: installing stage0 with exit code $EXIT_CODE." >&2
|
|
exit $EXIT_CODE
|
|
fi
|
|
|
|
# Install a project.json based CLI for use by tests
|
|
(set -x ; "$REPOROOT/scripts/obtain/dotnet-install.sh" --channel "master" --install-dir "$DOTNET_INSTALL_DIR_PJ" --architecture "$ARCHITECTURE" --version "1.0.0-preview2-1-003177")
|
|
EXIT_CODE=$?
|
|
if [ $EXIT_CODE != 0 ]; then
|
|
echo "run-build: Error: installing project-json based cli failed with exit code $EXIT_CODE." >&2
|
|
exit $EXIT_CODE
|
|
fi
|
|
|
|
# Put stage 0 on the PATH (for this shell only)
|
|
PATH="$DOTNET_INSTALL_DIR:$PATH"
|
|
|
|
# Increases the file descriptors limit for this bash. It prevents an issue we were hitting during restore
|
|
FILE_DESCRIPTOR_LIMIT=$( ulimit -n )
|
|
if [ $FILE_DESCRIPTOR_LIMIT -lt 1024 ]
|
|
then
|
|
echo "Increasing file description limit to 1024"
|
|
ulimit -n 1024
|
|
fi
|
|
|
|
# Disable first run since we want to control all package sources
|
|
export DOTNET_SKIP_FIRST_TIME_EXPERIENCE=1
|
|
|
|
echo "${args[@]}"
|
|
|
|
if [ $BUILD -eq 1 ]; then
|
|
dotnet msbuild build.proj /p:Architecture=$ARCHITECTURE $CUSTOM_BUILD_ARGS /p:GeneratePropsFile=true /t:WriteDynamicPropsToStaticPropsFiles
|
|
dotnet msbuild build.proj /m /v:normal /fl /flp:v=diag /p:Architecture=$ARCHITECTURE $CUSTOM_BUILD_ARGS "${args[@]}"
|
|
else
|
|
echo "Not building due to --nobuild"
|
|
echo "Command that would be run is: 'dotnet msbuild build.proj /m /p:Architecture=$ARCHITECTURE $CUSTOM_BUILD_ARGS ${args[@]}'"
|
|
fi
|