ci: improve install script

This commit is contained in:
DaniPopes 2023-02-25 15:12:29 +01:00
parent ec0cf0e8ef
commit e0a46a338d
No known key found for this signature in database
GPG Key ID: 0F09640DDB7AC692
1 changed files with 55 additions and 40 deletions

View File

@ -1,52 +1,67 @@
#!/usr/bin/env bash #!/usr/bin/env bash
# Installs Solc and Geth binaries # Installs Solc and Geth binaries
# Note: intended for use only with CI (x86_64 Ubuntu, MacOS or Windows)
set -e set -e
GETH_BUILD=${GETH_BUILD:-"1.11.2-73b01f40"} GETH_BUILD=${GETH_BUILD:-"1.11.2-73b01f40"}
SOLC_VERSION=${SOLC_VERSION:-"0.8.19"} SOLC_VERSION=${SOLC_VERSION:-"0.8.19"}
DIR="$HOME/bin" BIN_DIR=${BIN_DIR:-"$HOME/bin"}
mkdir -p "$DIR" BIN_DIR=$(realpath "$BIN_DIR")
cd "$DIR"
export PATH="$DIR:$PATH"
if [ "$GITHUB_PATH" ]; then
echo "$DIR" >> "$GITHUB_PATH"
echo "$HOME/.cargo/bin" >> "$GITHUB_PATH"
fi
echo "Installing Geth"
PLATFORM="$(uname -s | awk '{print tolower($0)}')" PLATFORM="$(uname -s | awk '{print tolower($0)}')"
case "$PLATFORM" in if [ "$PLATFORM" != "linux" ] && [ "$PLATFORM" != "darwin" ]; then
linux|darwin) EXT=".exe"
GETH_ARCHIVE_NAME="geth-$PLATFORM-amd64-$GETH_BUILD"
curl "https://gethstore.blob.core.windows.net/builds/$GETH_ARCHIVE_NAME.tar.gz" | tar -xzvf -
mv -f "$GETH_ARCHIVE_NAME/geth" ./
rm -rf "$GETH_ARCHIVE_NAME"
chmod +x geth
;;
*)
GETH_ARCHIVE_NAME="geth-windows-amd64-$GETH_BUILD"
zip="$GETH_ARCHIVE_NAME.zip"
curl -o "$zip" "https://gethstore.blob.core.windows.net/builds/$zip"
unzip "$zip"
mv -f "$GETH_ARCHIVE_NAME/geth.exe" ./
rm -rf "$GETH_ARCHIVE_NAME" "$zip"
;;
esac
geth version
echo "Installing Solc"
cargo install --locked svm-rs
# install only if it doesn't exist already
if command -v solc; then
if [ -z "$(solc --version | grep "$SOLC_VERSION" || true)" ]; then
svm install "$SOLC_VERSION"
fi
svm use "$SOLC_VERSION"
fi fi
solc --version main() {
mkdir -p "$BIN_DIR"
cd "$BIN_DIR"
export PATH="$BIN_DIR:$PATH"
if [ "$GITHUB_PATH" ]; then
echo "$BIN_DIR" >> "$GITHUB_PATH"
fi
which geth install_geth &
which solc install_solc &
wait
echo "Installed Geth:"
geth version
echo ""
echo "Installed Solc:"
solc --version
}
install_geth() {
case "$PLATFORM" in
linux|darwin)
GETH_ARCHIVE_NAME="geth-$PLATFORM-amd64-$GETH_BUILD"
curl "https://gethstore.blob.core.windows.net/builds/$GETH_ARCHIVE_NAME.tar.gz" | tar -xzvf -
mv -f "$GETH_ARCHIVE_NAME/geth" ./
rm -rf "$GETH_ARCHIVE_NAME"
chmod +x geth
;;
*)
GETH_ARCHIVE_NAME="geth-windows-amd64-$GETH_BUILD"
zip="$GETH_ARCHIVE_NAME.zip"
curl -o "$zip" "https://gethstore.blob.core.windows.net/builds/$zip"
unzip "$zip"
mv -f "$GETH_ARCHIVE_NAME/geth.exe" ./
rm -rf "$GETH_ARCHIVE_NAME" "$zip"
;;
esac
}
install_solc() {
case "$PLATFORM" in
linux) SOLC_NAME="solc-static-linux";;
darwin) SOLC_NAME="solc-macos";;
*) SOLC_NAME="solc-windows.exe";;
esac
wget -q "https://github.com/ethereum/solidity/releases/download/v$SOLC_VERSION/$SOLC_NAME"
mv -f "$SOLC_NAME" "solc$EXT"
chmod +x "solc$EXT"
}
main