From 8c05f4eaf13d73cb1228992e7f19704c70417c9c Mon Sep 17 00:00:00 2001 From: Eduardo Apolinario <653394+eapolinario@users.noreply.github.com> Date: Tue, 26 Sep 2023 15:39:27 -0700 Subject: [PATCH] [Monorepo] Update manifest using the monorepo components (#4082) * Use latest tag in script/release.sh Signed-off-by: Eduardo Apolinario * Use a more idiomatic way of consuming grep results in call to kustomize in script/release.sh Signed-off-by: Eduardo Apolinario * Rearrange how config docs are created Signed-off-by: Eduardo Apolinario * Add compile_flytepropeller make target Signed-off-by: Eduardo Apolinario * Move the binaries instead of copying them --------- Signed-off-by: Eduardo Apolinario Co-authored-by: Eduardo Apolinario --- datacatalog/Makefile | 2 +- flyteadmin/Makefile | 6 +++-- flytepropeller/Makefile | 7 ++++- script/generate_config_docs.sh | 22 ++++++--------- script/release.sh | 49 +++++++++++++++++----------------- 5 files changed, 44 insertions(+), 42 deletions(-) diff --git a/datacatalog/Makefile b/datacatalog/Makefile index 9ce7f7fd6a..82c59ee34e 100644 --- a/datacatalog/Makefile +++ b/datacatalog/Makefile @@ -10,7 +10,7 @@ update_boilerplate: .PHONY: compile compile: mkdir -p ./bin - go build -o datacatalog ./cmd/main.go && mv ./datacatalog ./bin + go build -o bin/datacatalog ./cmd/main.go .PHONY: linux_compile linux_compile: export CGO_ENABLED ?= 0 diff --git a/flyteadmin/Makefile b/flyteadmin/Makefile index 8d00995378..59a870e098 100644 --- a/flyteadmin/Makefile +++ b/flyteadmin/Makefile @@ -37,7 +37,8 @@ k8s_integration_execute: .PHONY: compile compile: - go build -o flyteadmin -ldflags=$(LD_FLAGS) ./cmd/ && mv ./flyteadmin ${GOPATH}/bin + mkdir -p ./bin + go build -o bin/flyteadmin -ldflags=$(LD_FLAGS) ./cmd/ .PHONY: compile_debug compile_debug: @@ -46,7 +47,8 @@ compile_debug: .PHONY: compile_scheduler compile_scheduler: - go build -o flytescheduler -ldflags=$(LD_FLAGS) ./cmd/scheduler/ && mv ./flytescheduler ${GOPATH}/bin + mkdir -p ./bin + go build -o bin/flytescheduler -ldflags=$(LD_FLAGS) ./cmd/scheduler/ .PHONY: compile_scheduler_debug compile_scheduler_debug: diff --git a/flytepropeller/Makefile b/flytepropeller/Makefile index be00efaaf6..d45862369c 100644 --- a/flytepropeller/Makefile +++ b/flytepropeller/Makefile @@ -21,7 +21,12 @@ compile: mkdir -p ./bin go build -o bin/flytepropeller ./cmd/controller/main.go go build -o bin/flytepropeller-manager ./cmd/manager/main.go - go build -o bin/kubectl-flyte ./cmd/kubectl-flyte/main.go && cp bin/kubectl-flyte ${GOPATH}/bin + go build -o bin/kubectl-flyte ./cmd/kubectl-flyte/main.go + +.PHONY: compile_flytepropeller +compile_flytepropeller: + mkdir -p ./bin + go build -o bin/flytepropeller ./cmd/controller/main.go cross_compile: @glide install diff --git a/script/generate_config_docs.sh b/script/generate_config_docs.sh index 6ae295df47..1170979b2f 100755 --- a/script/generate_config_docs.sh +++ b/script/generate_config_docs.sh @@ -8,20 +8,14 @@ ROOT_DIR=${CUR_DIR}/.. OUTPUT_DIR="${ROOT_DIR}"/rsts/deployment/configuration/generated GOBIN=${GOPATH:-~/go}/bin -# The version should same as https://github.com/flyteorg/flyte/blob/6b92b72f508d0603fa44153a4e30cf81be76adfd/script/release.sh#L5-L8 -FLYTEADMIN_TAG=$(curl --silent "https://api.github.com/repos/flyteorg/flyteadmin/releases/latest" | jq -r .tag_name) -FLYTEPROPELLER_TAG=$(curl --silent "https://api.github.com/repos/flyteorg/flytepropeller/releases/latest" | jq -r .tag_name) -DATACATALOG_TAG=$(curl --silent "https://api.github.com/repos/flyteorg/datacatalog/releases/latest" | jq -r .tag_name) - -pushd "$(mktemp -d)" -curl https://github.com/flyteorg/flyteadmin/releases/download/${FLYTEADMIN_TAG}/flyteadmin_${FLYTEADMIN_TAG}_linux_x86_64.tar.gz --output flyteadmin.tar.gz -s -L && tar -xvf flyteadmin.tar.gz -mv flyteadmin $GOBIN/flyteadmin -mv flytescheduler $GOBIN/scheduler -curl https://github.com/flyteorg/flytepropeller/releases/download/${FLYTEPROPELLER_TAG}/flytepropeller_${FLYTEPROPELLER_TAG}_linux_x86_64.tar.gz --output flytepropeller.tar.gz -s -L && tar -xvf flytepropeller.tar.gz -mv flytepropeller $GOBIN/flytepropeller -curl https://github.com/flyteorg/datacatalog/releases/download/${DATACATALOG_TAG}/datacatalog_${DATACATALOG_TAG}_linux_x86_64.tar.gz --output datacatalog.tar.gz -s -L && tar -xvf datacatalog.tar.gz -mv datacatalog $GOBIN/datacatalog -popd +make -C datacatalog compile +mv datacatalog/bin/datacatalog ${GOBIN}/datacatalog +make -C flyteadmin compile +mv flyteadmin/bin/flyteadmin ${GOBIN}/flyteadmin +make -C flyteadmin compile_scheduler +mv flyteadmin/bin/flytescheduler ${GOBIN}/scheduler +make -C flytepropeller compile_flytepropeller +mv flytepropeller/bin/flytepropeller ${GOBIN}/flytepropeller output_config () { CONFIG_NAME=$1 diff --git a/script/release.sh b/script/release.sh index 6b36fdb6dd..1c903c5bbb 100755 --- a/script/release.sh +++ b/script/release.sh @@ -2,41 +2,42 @@ set -ex -FLYTEADMIN_TAG=$(curl --silent "https://api.github.com/repos/flyteorg/flyteadmin/releases/latest" | jq -r .tag_name) -DATACATALOG_TAG=$(curl --silent "https://api.github.com/repos/flyteorg/datacatalog/releases/latest" | jq -r .tag_name) +# Get latest release tag (minus the component prefix) +# TODO(monorepo): This only works if we have at least one component tag per release. +# In other words, if we have two consecutive releases the latest tag in the second release is going to point to an invalid +# tag (because there will not be images tagged with the previous release tag). +LATEST_TAG=$(git tag | sed 's#[^/]*/##' | sort | tail -n 1) + FLYTECONSOLE_TAG=$(curl --silent "https://api.github.com/repos/flyteorg/flyteconsole/releases/latest" | jq -r .tag_name) -FLYTEPROPELLER_TAG=$(curl --silent "https://api.github.com/repos/flyteorg/flytepropeller/releases/latest" | jq -r .tag_name) -FLYTECOPILOT_TAG=$(curl --silent "https://api.github.com/repos/flyteorg/flytecopilot/releases/latest" | jq -r .tag_name) -FLYTESTDLIB_TAG=$(curl --silent "https://api.github.com/repos/flyteorg/flytestdlib/releases/latest" | jq -r .tag_name) # bump latest release of flyte component in kustomize -grep -rlZ "newTag:[^P]*# FLYTEADMIN_TAG" ./kustomize/overlays | xargs -0 sed -i "s/newTag:[^P]*# FLYTEADMIN_TAG/newTag: ${FLYTEADMIN_TAG} # FLYTEADMIN_TAG/g" -grep -rlZ "newTag:[^P]*# DATACATALOG_TAG" ./kustomize/overlays | xargs -0 sed -i "s/newTag:[^P]*# DATACATALOG_TAG/newTag: ${DATACATALOG_TAG} # DATACATALOG_TAG/g" -grep -rlZ "newTag:[^P]*# FLYTECONSOLE_TAG" ./kustomize/overlays | xargs -0 sed -i "s/newTag:[^P]*# FLYTECONSOLE_TAG/newTag: ${FLYTECONSOLE_TAG} # FLYTECONSOLE_TAG/g" -grep -rlZ "newTag:[^P]*# FLYTEPROPELLER_TAG" ./kustomize/overlays | xargs -0 sed -i "s/newTag:[^P]*# FLYTEPROPELLER_TAG/newTag: ${FLYTEPROPELLER_TAG} # FLYTEPROPELLER_TAG/g" +grep -rlZ "newTag:[^P]*# FLYTEADMIN_TAG" ./kustomize/overlays | xargs -I {} sed -i "s/newTag:[^P]*# FLYTEADMIN_TAG/newTag: ${LATEST_TAG} # FLYTEADMIN_TAG/g" {} +grep -rlZ "newTag:[^P]*# DATACATALOG_TAG" ./kustomize/overlays | xargs -I {} sed -i "s/newTag:[^P]*# DATACATALOG_TAG/newTag: ${LATEST_TAG} # DATACATALOG_TAG/g" {} +grep -rlZ "newTag:[^P]*# FLYTECONSOLE_TAG" ./kustomize/overlays | xargs -I {} sed -i "s/newTag:[^P]*# FLYTECONSOLE_TAG/newTag: ${FLYTECONSOLE_TAG} # FLYTECONSOLE_TAG/g" {} +grep -rlZ "newTag:[^P]*# FLYTEPROPELLER_TAG" ./kustomize/overlays | xargs -I {} sed -i "s/newTag:[^P]*# FLYTEPROPELLER_TAG/newTag: ${LATEST_TAG} # FLYTEPROPELLER_TAG/g" {} # bump latest release of flyte component in helm -sed -i "s,tag:[^P]*# FLYTEADMIN_TAG,tag: ${FLYTEADMIN_TAG} # FLYTEADMIN_TAG," ./charts/flyte/values.yaml -sed -i "s,tag:[^P]*# FLYTEADMIN_TAG,tag: ${FLYTEADMIN_TAG} # FLYTEADMIN_TAG," ./charts/flyte-core/values.yaml +sed -i "s,tag:[^P]*# FLYTEADMIN_TAG,tag: ${LATEST_TAG} # FLYTEADMIN_TAG," ./charts/flyte/values.yaml +sed -i "s,tag:[^P]*# FLYTEADMIN_TAG,tag: ${LATEST_TAG} # FLYTEADMIN_TAG," ./charts/flyte-core/values.yaml -sed -i "s,tag:[^P]*# FLYTESCHEDULER_TAG,tag: ${FLYTEADMIN_TAG} # FLYTESCHEDULER_TAG," ./charts/flyte/values.yaml -sed -i "s,tag:[^P]*# FLYTESCHEDULER_TAG,tag: ${FLYTEADMIN_TAG} # FLYTESCHEDULER_TAG," ./charts/flyte-core/values.yaml +sed -i "s,tag:[^P]*# FLYTESCHEDULER_TAG,tag: ${LATEST_TAG} # FLYTESCHEDULER_TAG," ./charts/flyte/values.yaml +sed -i "s,tag:[^P]*# FLYTESCHEDULER_TAG,tag: ${LATEST_TAG} # FLYTESCHEDULER_TAG," ./charts/flyte-core/values.yaml -sed -i "s,tag:[^P]*# DATACATALOG_TAG,tag: ${DATACATALOG_TAG} # DATACATALOG_TAG," ./charts/flyte/values.yaml -sed -i "s,tag:[^P]*# DATACATALOG_TAG,tag: ${DATACATALOG_TAG} # DATACATALOG_TAG," ./charts/flyte-core/values.yaml +sed -i "s,tag:[^P]*# DATACATALOG_TAG,tag: ${LATEST_TAG} # DATACATALOG_TAG," ./charts/flyte/values.yaml +sed -i "s,tag:[^P]*# DATACATALOG_TAG,tag: ${LATEST_TAG} # DATACATALOG_TAG," ./charts/flyte-core/values.yaml sed -i "s,tag:[^P]*# FLYTECONSOLE_TAG,tag: ${FLYTECONSOLE_TAG} # FLYTECONSOLE_TAG," ./charts/flyte/values.yaml sed -i "s,tag:[^P]*# FLYTECONSOLE_TAG,tag: ${FLYTECONSOLE_TAG} # FLYTECONSOLE_TAG," ./charts/flyte-core/values.yaml -sed -i "s,tag:[^P]*# FLYTEPROPELLER_TAG,tag: ${FLYTEPROPELLER_TAG} # FLYTEPROPELLER_TAG," ./charts/flyte/values.yaml -sed -i "s,tag:[^P]*# FLYTEPROPELLER_TAG,tag: ${FLYTEPROPELLER_TAG} # FLYTEPROPELLER_TAG," ./charts/flyte-core/values.yaml +sed -i "s,tag:[^P]*# FLYTEPROPELLER_TAG,tag: ${LATEST_TAG} # FLYTEPROPELLER_TAG," ./charts/flyte/values.yaml +sed -i "s,tag:[^P]*# FLYTEPROPELLER_TAG,tag: ${LATEST_TAG} # FLYTEPROPELLER_TAG," ./charts/flyte-core/values.yaml -sed -i "s,image:[^P]*# FLYTECOPILOT_IMAGE,image: cr.flyte.org/flyteorg/flytecopilot:${FLYTECOPILOT_TAG} # FLYTECOPILOT_IMAGE," ./charts/flyte/values.yaml -sed -i "s,image:[^P]*# FLYTECOPILOT_IMAGE,image: cr.flyte.org/flyteorg/flytecopilot:${FLYTECOPILOT_TAG} # FLYTECOPILOT_IMAGE," ./charts/flyte-core/values.yaml -sed -i "s,tag:[^P]*# FLYTECOPILOT_TAG,tag: ${FLYTECOPILOT_TAG} # FLYTECOPILOT_TAG," ./charts/flyte-binary/values.yaml +sed -i "s,image:[^P]*# FLYTECOPILOT_IMAGE,image: cr.flyte.org/flyteorg/flytecopilot:${LATEST_TAG} # FLYTECOPILOT_IMAGE," ./charts/flyte/values.yaml +sed -i "s,image:[^P]*# FLYTECOPILOT_IMAGE,image: cr.flyte.org/flyteorg/flytecopilot:${LATEST_TAG} # FLYTECOPILOT_IMAGE," ./charts/flyte-core/values.yaml +sed -i "s,tag:[^P]*# FLYTECOPILOT_TAG,tag: ${LATEST_TAG} # FLYTECOPILOT_TAG," ./charts/flyte-binary/values.yaml -go get github.com/flyteorg/flyteadmin@${FLYTEADMIN_TAG} -go get github.com/flyteorg/flytepropeller@${FLYTEPROPELLER_TAG} -go get github.com/flyteorg/datacatalog@${DATACATALOG_TAG} -go get github.com/flyteorg/flytestdlib@${FLYTESTDLIB_TAG} +go get github.com/flyteorg/flyte/flyteadmin@${LATEST_TAG} +go get github.com/flyteorg/flyte/flytepropeller@${LATEST_TAG} +go get github.com/flyteorg/flyte/datacatalog@${LATEST_TAG} +go get github.com/flyteorg/flyte/flytestdlib@${LATEST_TAG} go mod tidy