Add GOOS=windows make release support.
Signed-off-by: Lantao Liu <lantaol@google.com>
This commit is contained in:
@@ -16,11 +16,12 @@
|
||||
|
||||
source $(dirname "${BASH_SOURCE[0]}")/../utils.sh
|
||||
|
||||
# DESTDIR is the dest path to install dependencies.
|
||||
# DESTDIR is the absolute dest path to install dependencies.
|
||||
DESTDIR=${DESTDIR:-"/"}
|
||||
# Convert to absolute path if it's relative.
|
||||
# Make sure that DESTDIR is an absolute path.
|
||||
if [[ ${DESTDIR} != /* ]]; then
|
||||
DESTDIR=${ROOT}/${DESTDIR}
|
||||
echo "DESTDIR is not an absolute path"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
# NOSUDO indicates not to use sudo during installation.
|
||||
|
||||
@@ -74,7 +74,7 @@ bash -c 'cat >"'"${CNI_CONFIG_DIR}"'"/0-containerd-nat.conf <<EOF
|
||||
"subnet": "'$subnet'",
|
||||
"routes": [
|
||||
{
|
||||
"gateway": "'$gateway'"
|
||||
"GW": "'$gateway'"
|
||||
}
|
||||
]
|
||||
},
|
||||
|
||||
@@ -22,7 +22,7 @@ source $(dirname "${BASH_SOURCE[0]}")/../utils.sh
|
||||
# WINCNI_BIN_DIR is the cni plugin directory
|
||||
WINCNI_BIN_DIR="${WINCNI_BIN_DIR:-"C:\\Program Files\\containerd\\cni\\bin"}"
|
||||
WINCNI_PKG=github.com/Microsoft/windows-container-networking
|
||||
WINCNI_VERSION=33bc4764ea3ad7c6ec58c5716370d329f5eb1266
|
||||
WINCNI_VERSION=aa10a0b31e9f72937063436454def1760b858ee2
|
||||
|
||||
# Create a temporary GOPATH for cni installation.
|
||||
GOPATH="$(mktemp -d /tmp/cri-install-cni.XXXX)"
|
||||
@@ -30,8 +30,10 @@ GOPATH="$(mktemp -d /tmp/cri-install-cni.XXXX)"
|
||||
# Install cni
|
||||
checkout_repo "${WINCNI_PKG}" "${WINCNI_VERSION}" "${WINCNI_PKG}"
|
||||
cd "${GOPATH}/src/${WINCNI_PKG}"
|
||||
go build "${WINCNI_PKG}/plugins/nat"
|
||||
install -D -m 755 "nat.exe" "${WINCNI_BIN_DIR}/nat.exe"
|
||||
make all
|
||||
install -D -m 755 "out/nat.exe" "${WINCNI_BIN_DIR}/nat.exe"
|
||||
install -D -m 755 "out/sdnbridge.exe" "${WINCNI_BIN_DIR}/sdnbridge.exe"
|
||||
install -D -m 755 "out/sdnoverlay.exe" "${WINCNI_BIN_DIR}/sdnoverlay.exe"
|
||||
|
||||
# Clean the tmp GOPATH dir.
|
||||
rm -rf "${GOPATH}"
|
||||
|
||||
@@ -30,7 +30,7 @@ from-vendor HCSSHIM "${HCSSHIM_PKG}"
|
||||
checkout_repo "${HCSSHIM_PKG}" "${HCSSHIM_VERSION}" "${HCSSHIM_REPO}"
|
||||
cd "${GOPATH}/src/${HCSSHIM_PKG}"
|
||||
go build "${HCSSHIM_PKG}/cmd/containerd-shim-runhcs-v1"
|
||||
install -D -m 755 containerd-shim-runhcs-v1 "${HCSSHIM_DIR}"/containerd-shim-runhcs-v1
|
||||
install -D -m 755 containerd-shim-runhcs-v1.exe "${HCSSHIM_DIR}"/containerd-shim-runhcs-v1.exe
|
||||
|
||||
# Clean the tmp GOPATH dir. Use sudo because runc build generates
|
||||
# some privileged files.
|
||||
|
||||
75
hack/release-windows.sh
Executable file
75
hack/release-windows.sh
Executable file
@@ -0,0 +1,75 @@
|
||||
#!/bin/bash
|
||||
|
||||
# Copyright The containerd Authors.
|
||||
#
|
||||
# Licensed under the Apache License, Version 2.0 (the "License");
|
||||
# you may not use this file except in compliance with the License.
|
||||
# You may obtain a copy of the License at
|
||||
#
|
||||
# http://www.apache.org/licenses/LICENSE-2.0
|
||||
#
|
||||
# Unless required by applicable law or agreed to in writing, software
|
||||
# distributed under the License is distributed on an "AS IS" BASIS,
|
||||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
# See the License for the specific language governing permissions and
|
||||
# limitations under the License.
|
||||
|
||||
set -o errexit
|
||||
set -o nounset
|
||||
set -o pipefail
|
||||
|
||||
source $(dirname "${BASH_SOURCE[0]}")/utils.sh
|
||||
cd ${ROOT}
|
||||
|
||||
umask 0022
|
||||
|
||||
# BUILD_DIR is the directory to generate release tar.
|
||||
# TARBALL is the name of the release tar.
|
||||
BUILD_DIR=${BUILD_DIR:-"_output"}
|
||||
# Convert to absolute path if it's relative.
|
||||
if [[ ${BUILD_DIR} != /* ]]; then
|
||||
BUILD_DIR=${ROOT}/${BUILD_DIR}
|
||||
fi
|
||||
TARBALL=${TARBALL:-"cri-containerd.tar.gz"}
|
||||
# INCLUDE_CNI indicates whether to install CNI. By default don't
|
||||
# include CNI in release tarball.
|
||||
INCLUDE_CNI=${INCLUDE_CNI:-false}
|
||||
# CUSTOM_CONTAINERD indicates whether to install customized containerd
|
||||
# for CI test.
|
||||
CUSTOM_CONTAINERD=${CUSTOM_CONTAINERD:-false}
|
||||
|
||||
destdir=${BUILD_DIR}/release-stage
|
||||
|
||||
if [[ -z "${VERSION}" ]]; then
|
||||
echo "VERSION is not set"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
# Remove release-stage directory to avoid including old files.
|
||||
rm -rf ${destdir}
|
||||
|
||||
# Install dependencies into release stage.
|
||||
# Install hcsshim
|
||||
HCSSHIM_DIR=${destdir} ./hack/install/windows/install-hcsshim.sh
|
||||
|
||||
if ${INCLUDE_CNI}; then
|
||||
# Install cni
|
||||
NOSUDO=true WINCNI_BIN_DIR=${destdir}/cni ./hack/install/windows/install-cni.sh
|
||||
fi
|
||||
|
||||
# Build containerd from source
|
||||
NOSUDO=true CONTAINERD_DIR=${destdir} ./hack/install/install-containerd.sh
|
||||
# Containerd makefile always installs into a "bin" directory.
|
||||
mv "${destdir}"/bin/* "${destdir}"
|
||||
rm -rf "${destdir}/bin"
|
||||
|
||||
if ${CUSTOM_CONTAINERD}; then
|
||||
make install -e BINDIR=${destdir}
|
||||
fi
|
||||
|
||||
# Create release tar
|
||||
tarball=${BUILD_DIR}/${TARBALL}
|
||||
tar -zcvf ${tarball} -C ${destdir} . --owner=0 --group=0
|
||||
checksum=$(sha256 ${tarball})
|
||||
echo "sha256sum: ${checksum} ${tarball}"
|
||||
echo ${checksum} > ${tarball}.sha256
|
||||
@@ -26,6 +26,10 @@ umask 0022
|
||||
# BUILD_DIR is the directory to generate release tar.
|
||||
# TARBALL is the name of the release tar.
|
||||
BUILD_DIR=${BUILD_DIR:-"_output"}
|
||||
# Convert to absolute path if it's relative.
|
||||
if [[ ${BUILD_DIR} != /* ]]; then
|
||||
BUILD_DIR=${ROOT}/${BUILD_DIR}
|
||||
fi
|
||||
TARBALL=${TARBALL:-"cri-containerd.tar.gz"}
|
||||
# INCLUDE_CNI indicates whether to install CNI. By default don't
|
||||
# include CNI in release tarball.
|
||||
|
||||
Reference in New Issue
Block a user