From 9836844f419f9b340aa61137ea1042012ffc9bd6 Mon Sep 17 00:00:00 2001 From: Hiroto Funakoshi Date: Tue, 7 May 2024 17:16:21 +0900 Subject: [PATCH] [vald-client-python]: Use vald-client-ci workflows for release and e2e (#284) * feat: introduce two version support feature Signed-off-by: hlts2 * fix: refactor and add debug job for build and test Signed-off-by: hlts2 * fix: deleted debug job for e2e and build proto Signed-off-by: hlts2 --------- Signed-off-by: hlts2 --- .github/workflows/e2e.yaml | 2 +- .github/workflows/release.yml | 2 +- .github/workflows/sync.yaml | 2 +- .gitignore | 1 + Makefile | 95 +++++++++++++++++++++++------------ PYTHON_VERSION | 1 + 6 files changed, 69 insertions(+), 34 deletions(-) create mode 100644 PYTHON_VERSION diff --git a/.github/workflows/e2e.yaml b/.github/workflows/e2e.yaml index 195ed555..ab0a3cd6 100644 --- a/.github/workflows/e2e.yaml +++ b/.github/workflows/e2e.yaml @@ -30,4 +30,4 @@ jobs: # - uses: vdaas/vald-client-ci/.github/actions/e2e@main - uses: vdaas/vald-client-ci/.github/actions/e2e@feat/add-common-workflows with: - client_type: node + client_type: python diff --git a/.github/workflows/release.yml b/.github/workflows/release.yml index 5f3f3e17..2bf95e2a 100644 --- a/.github/workflows/release.yml +++ b/.github/workflows/release.yml @@ -28,5 +28,5 @@ jobs: # uses: vdaas/vald-client-ci/.github/workflows/_release.yaml@main uses: vdaas/vald-client-ci/.github/workflows/_release.yaml@feat/add-common-workflows with: - client_type: node + client_type: python secrets: inherit diff --git a/.github/workflows/sync.yaml b/.github/workflows/sync.yaml index a1e45bf4..d13800b3 100644 --- a/.github/workflows/sync.yaml +++ b/.github/workflows/sync.yaml @@ -25,7 +25,7 @@ jobs: # uses: vdaas/vald-client-ci/.github/workflows/sync.yaml@main uses: vdaas/vald-client-ci/.github/workflows/sync.yaml@feat/add-common-workflows with: - client_type: node + client_type: python secrets: CI_USER: ${{ secrets.DISPATCH_USER }} CI_TOKEN: ${{ secrets.DISPATCH_TOKEN }} diff --git a/.gitignore b/.gitignore index f78ec3d3..7e2386db 100644 --- a/.gitignore +++ b/.gitignore @@ -1,5 +1,6 @@ /vald-origin /vald +wordvecs1000.json # Byte-compiled / optimized / DLL files __pycache__/ diff --git a/Makefile b/Makefile index 28e20695..16a875d5 100755 --- a/Makefile +++ b/Makefile @@ -26,6 +26,7 @@ PYTHON = python VALD_DIR = vald-origin VALD_SHA = VALD_SHA VALD_CLIENT_PYTHON_VERSION = VALD_CLIENT_PYTHON_VERSION +VALD_CHECKOUT_REF ?= main BINDIR ?= /usr/local/bin @@ -58,6 +59,9 @@ PB2PYS = $(PROTOS:$(PROTO_ROOT)/%.proto=$(PB2DIR_ROOT)/$(SHADOW_ROOT)/%_pb2.py) MAKELISTS = Makefile +PYTHON_VERSION := $(eval PYTHON_VERSION := $(shell cat PYTHON_VERSION))$(PYTHON_VERSION) +TEST_DATASET_PATH = wordvecs1000.json + red = /bin/echo -e "\x1b[31m\#\# $1\x1b[0m" green = /bin/echo -e "\x1b[32m\#\# $1\x1b[0m" yellow = /bin/echo -e "\x1b[33m\#\# $1\x1b[0m" @@ -109,10 +113,19 @@ $(SHADOW_PROTO_ROOT)/%.proto: $(PROTO_ROOT)/%.proto $(PB2DIR_ROOT): mkdir -p $@ -$(PB2PYS): proto/deps $(PB2DIR_ROOT) $(SHADOWS) +$(PB2PYS): proto/deps/install $(PB2DIR_ROOT) $(SHADOWS) $(VALD_DIR): - git clone --depth 1 https://$(VALDREPO) $(VALD_DIR) + git clone https://$(VALDREPO) $(VALD_DIR) + +## checkout vald repository +vald/checkout: $(VALD_DIR) + cd $(VALD_DIR) && git checkout $(VALD_CHECKOUT_REF) + +.PHONY: vald/origin/sha/print +## print origin VALD_SHA value +vald/origin/sha/print: $(VALD_DIR) + @cd $(VALD_DIR) && git rev-parse HEAD | tr -d '\n' .PHONY: vald/sha/print ## print VALD_SHA value @@ -121,44 +134,59 @@ vald/sha/print: .PHONY: vald/sha/update ## update VALD_SHA value -vald/sha/update: vald - (cd vald; git rev-parse HEAD | tr -d '\n' > ../$(VALD_SHA)) +vald/sha/update: $(VALD_DIR) + (cd $(VALD_DIR); git rev-parse HEAD | tr -d '\n' > ../$(VALD_SHA)) -.PHONY: vald/client/python/version/print +.PHONY: vald/client/version/print ## print VALD_CLIENT_PYTHON_VERSION value -vald/client/python/version/print: +vald/client/version/print: @cat $(VALD_CLIENT_PYTHON_VERSION) -.PHONY: vald/client/python/version/update +.PHONY: vald/client/version/update ## update VALD_CLIENT_PYTHON_VERSION value -vald/client/python/version/update: vald +vald/client/version/update: $(VALD_DIR) (vald_version=`cat $(VALD_DIR)/versions/VALD_VERSION | sed -e 's/^v//'`; \ - client_version=`cat $(VALD_CLIENT_PYTHON_VERSION)`; \ - major=$${client_version%%.*}; client_version="$${client_version#*.}"; \ - minor=$${client_version%%.*}; client_version="$${client_version#*.}"; \ - patch=$${client_version%%.*}; client_version="$${client_version#*.}"; \ - if [ "$${vald_version}" = "$${major}.$${minor}.$${patch}" ]; then \ - if [ "$${patch}" = "$${client_version}" ]; then \ - new_version="$${major}.$${minor}.$${patch}.post1"; \ - else \ - rev="$${client_version#post}"; \ - rev=$$((rev+1)); \ - new_version="$${major}.$${minor}.$${patch}.post$${rev}"; \ - fi; \ - else \ - new_version="$${vald_version}"; \ - fi; \ - echo "VALD_VERSION: $${vald_version}, NEW_CLIENT_VERSION: $${new_version}"; \ - echo "$${new_version}" > VALD_CLIENT_PYTHON_VERSION) + echo "VALD_VERSION: $${vald_version}"; \ + echo "$${vald_version}" > VALD_CLIENT_PYTHON_VERSION) sed -i -e "s/^version = .*\$$/version = `cat VALD_CLIENT_PYTHON_VERSION`/" setup.cfg -.PHONY: proto/deps +.PHONY: test +## Execute test +test: $(TEST_DATASET_PATH) + python src/test.py + +$(TEST_DATASET_PATH): + curl -L https://raw.githubusercontent.com/rinx/word2vecjson/master/data/wordvecs1000.json -o $(TEST_DATASET_PATH) + +.PHONY: ci/deps/install +## install deps for CI environment +ci/deps/install: proto/deps/install + sudo apt-get update -y && sudo apt-get install -y \ + python3-setuptools \ + libprotobuf-dev \ + libprotoc-dev \ + protobuf-compiler + pip3 install grpcio-tools + +.PHONY: ci/deps/update +## update deps for CI environment +ci/deps/update: + @echo "Nothing do be done" + +.PHONY: ci/package/prepare +## prepare package to publish +ci/package/prepare: + python3 setup.py sdist + python3 setup.py bdist_wheel + +.PHONY: ci/package/publish +## publich packages +ci/package/publish: + @echo "Nothing do be done" + +.PHONY: proto/deps/install ## install proto deps -proto/deps: buf/install - -.PHONY: buf/install -## install buf command. -buf/install: $(BINDIR)/buf +proto/deps/install: $(BINDIR)/buf $(BINDIR)/buf: @version=$$(curl -sSL $(BUF_VERSION_URL)); \ @@ -166,3 +194,8 @@ $(BINDIR)/buf: "https://github.com/bufbuild/buf/releases/download/$$version/buf-$(shell uname -s)-$(shell uname -m)" \ -o "${BINDIR}/buf" && \ chmod +x "${BINDIR}/buf" + +.PHONY: version/python +## Print Python version +version/python: + @echo $(PYTHON_VERSION) diff --git a/PYTHON_VERSION b/PYTHON_VERSION new file mode 100644 index 00000000..c8cfe395 --- /dev/null +++ b/PYTHON_VERSION @@ -0,0 +1 @@ +3.10