139 lines
5 KiB
Bash
Executable file
139 lines
5 KiB
Bash
Executable file
#!/usr/bin/env bash
|
|
|
|
set -e
|
|
|
|
[ -z "$CONFIGURATION" ] && CONFIGURATION=Debug
|
|
|
|
# TODO: Replace this with a dotnet generation
|
|
TFM=dnxcore50
|
|
|
|
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="$( cd -P "$DIR/.." && pwd )"
|
|
|
|
START_PATH=$PATH
|
|
|
|
echo "Bootstrapping dotnet.exe using DNX"
|
|
|
|
if [ -z "$RID" ]; then
|
|
UNAME=$(uname)
|
|
if [ "$UNAME" == "Darwin" ]; then
|
|
RID=osx.10.10-x64
|
|
elif [ "$UNAME" == "Linux" ]; then
|
|
# Detect Distro?
|
|
RID=ubuntu.14.04-x64
|
|
else
|
|
echo "Unknown OS: $UNAME" 1>&2
|
|
exit 1
|
|
fi
|
|
fi
|
|
|
|
OUTPUT_ROOT=$REPOROOT/artifacts/$RID
|
|
DNX_DIR=$OUTPUT_ROOT/dnx
|
|
STAGE0_DIR=$OUTPUT_ROOT/stage0
|
|
STAGE1_DIR=$OUTPUT_ROOT/stage1
|
|
STAGE2_DIR=$OUTPUT_ROOT/stage2
|
|
|
|
if [ "$DOTNET_CI_SKIP_STAGE0_INSTALL" != "1" ]; then
|
|
echo "Installing stage0"
|
|
# Use a sub-shell to ensure the DNVM gets cleaned up
|
|
rm -Rf $STAGE0_DIR
|
|
mkdir -p $STAGE0_DIR
|
|
$DIR/install-stage0.sh $STAGE0_DIR $DIR/dnvm2.sh
|
|
else
|
|
echo "Skipping stage0 because DOTNET_CI_SKIP_STAGE0_INSTALL"
|
|
fi
|
|
|
|
export PATH=$STAGE0_DIR/bin:$PATH
|
|
|
|
echo "Installing and use-ing the latest CoreCLR x64 DNX ..."
|
|
mkdir -p $DNX_DIR
|
|
|
|
export DNX_HOME=$DNX_DIR
|
|
export DNX_USER_HOME=$DNX_DIR
|
|
export DNX_GLOBAL_HOME=$DNX_DIR
|
|
|
|
if ! type dnvm > /dev/null 2>&1; then
|
|
curl -o $DNX_DIR/dnvm.sh https://raw.githubusercontent.com/aspnet/Home/dev/dnvm.sh
|
|
source $DNX_DIR/dnvm.sh
|
|
fi
|
|
|
|
dnvm install latest -u -r coreclr
|
|
|
|
# Make sure we got a DNX
|
|
if ! type dnx > /dev/null 2>&1; then
|
|
echo "DNX is required to bootstrap stage1" 1>&2
|
|
exit 1
|
|
fi
|
|
|
|
DNX_ROOT=$(dirname $(which dnx))
|
|
|
|
echo "Running 'dnu restore' to restore packages"
|
|
|
|
dnu restore "$REPOROOT" --runtime osx.10.10-x64 --runtime ubuntu.14.04-x64 --runtime osx.10.11-x64
|
|
|
|
# Clean up stage1
|
|
[ -d "$STAGE1_DIR" ] && rm -Rf "$STAGE1_DIR"
|
|
|
|
echo "Building basic dotnet tools using Stage 0"
|
|
dotnet publish --framework "$TFM" --runtime $RID --output "$STAGE1_DIR" --configuration "$CONFIGURATION" "$REPOROOT/src/Microsoft.DotNet.Cli"
|
|
dotnet publish --framework "$TFM" --runtime $RID --output "$STAGE1_DIR" --configuration "$CONFIGURATION" "$REPOROOT/src/Microsoft.DotNet.Tools.Compiler"
|
|
dotnet publish --framework "$TFM" --runtime $RID --output "$STAGE1_DIR" --configuration "$CONFIGURATION" "$REPOROOT/src/Microsoft.DotNet.Tools.Compiler.Csc"
|
|
dotnet publish --framework "$TFM" --runtime $RID --output "$STAGE1_DIR" --configuration "$CONFIGURATION" "$REPOROOT/src/Microsoft.DotNet.Tools.Publish"
|
|
dotnet publish --framework "$TFM" --runtime $RID --output "$STAGE1_DIR" --configuration "$CONFIGURATION" "$REPOROOT/src/Microsoft.DotNet.Tools.Resgen"
|
|
|
|
# Add stage1 to the path and use it to build stage2
|
|
export PATH=$STAGE1_DIR:$START_PATH
|
|
|
|
# Make corerun explicitly executable
|
|
chmod a+x $STAGE1_DIR/corerun
|
|
|
|
# Clean up stage2
|
|
[ -d "$STAGE2_DIR" ] && rm -Rf "$STAGE2_DIR"
|
|
|
|
echo "Building stage2 dotnet using stage1 ..."
|
|
dotnet publish --framework "$TFM" --runtime $RID --output "$STAGE2_DIR" --configuration "$CONFIGURATION" "$REPOROOT/src/Microsoft.DotNet.Cli"
|
|
dotnet publish --framework "$TFM" --runtime $RID --output "$STAGE2_DIR" --configuration "$CONFIGURATION" "$REPOROOT/src/Microsoft.DotNet.Tools.Compiler"
|
|
dotnet publish --framework "$TFM" --runtime $RID --output "$STAGE2_DIR" --configuration "$CONFIGURATION" "$REPOROOT/src/Microsoft.DotNet.Tools.Compiler.Csc"
|
|
dotnet publish --framework "$TFM" --runtime $RID --output "$STAGE2_DIR" --configuration "$CONFIGURATION" "$REPOROOT/src/Microsoft.DotNet.Tools.Publish"
|
|
dotnet publish --framework "$TFM" --runtime $RID --output "$STAGE2_DIR" --configuration "$CONFIGURATION" "$REPOROOT/src/Microsoft.DotNet.Tools.Resgen"
|
|
|
|
# Make Stage 2 Folder Accessible
|
|
chmod -R a+r $REPOROOT
|
|
|
|
# Copy DNX in to stage2
|
|
cp -R $DNX_ROOT $STAGE2_DIR/dnx
|
|
|
|
# Clean up some things we don't need
|
|
rm -Rf $STAGE2_DIR/dnx/lib/Microsoft.Dnx.DesignTimeHost
|
|
rm -Rf $STAGE2_DIR/dnx/lib/Microsoft.Dnx.Project
|
|
rm $STAGE2_DIR/dnx/dnu
|
|
|
|
# Copy and CHMOD the dotnet-restore script
|
|
cp $DIR/dotnet-restore.sh $STAGE2_DIR/dotnet-restore
|
|
chmod a+x $STAGE2_DIR/dotnet-restore
|
|
|
|
# Smoke-test the output
|
|
export PATH=$STAGE2_DIR:$START_PATH
|
|
|
|
rm "$REPOROOT/test/TestApp/project.lock.json"
|
|
dotnet restore "$REPOROOT/test/TestApp" --runtime "$RID"
|
|
dotnet publish "$REPOROOT/test/TestApp" --framework "$TFM" --runtime "$RID" --output "$REPOROOT/artifacts/$RID/smoketest"
|
|
|
|
OUTPUT=$($REPOROOT/artifacts/$RID/smoketest/TestApp)
|
|
[ "$OUTPUT" == "This is a test app" ] || (echo "Smoke test failed!" && exit 1)
|
|
|
|
# Check that a compiler error is reported
|
|
set +e
|
|
dotnet compile "$REPOROOT/test/compile/failing/SimpleCompilerError" --framework "$TFM" 2>/dev/null >/dev/null
|
|
rc=$?
|
|
if [ $rc == 0 ]; then
|
|
echo "Compiler failure test failed! The compiler did not fail to compile!"
|
|
exit 1
|
|
fi
|
|
set -e
|