diff --git a/.github/workflows/build-test.yml b/.github/workflows/build-test.yml new file mode 100644 index 0000000..bb2fec5 --- /dev/null +++ b/.github/workflows/build-test.yml @@ -0,0 +1,31 @@ +# SPDX-License-Identifier: Apache-2.0 +# Copyright 2024 Intel Corporation + +name: Build and test workflow +on: + pull_request: + branches: + - master + push: + branches: + - master + +jobs: + build: + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@v4 + - uses: actions/setup-go@v5 + with: + go-version-file: 'go.mod' + - name: build + run: make build + test: + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@v4 + - uses: actions/setup-go@v5 + with: + go-version-file: 'go.mod' + - name: Unit tests + run: make test diff --git a/.github/workflows/code-scan.yml b/.github/workflows/code-scan.yml new file mode 100644 index 0000000..4ae9ae7 --- /dev/null +++ b/.github/workflows/code-scan.yml @@ -0,0 +1,43 @@ +# SPDX-License-Identifier: Apache-2.0 +# Copyright 2024 Intel Corporation + +name: Code scan workflow + +on: + pull_request: + branches: + - master + push: + branches: + - master + +jobs: + version-check: + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@v4 + - name: check version + run: make check-version + lint: + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@v4 + - uses: actions/setup-go@v5 + with: + go-version-file: 'go.mod' + - name: golang-lint + run: make lint + license: + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@v4 + - name: check license + run: make license + fossa-check: + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@v4 + - name: FOSSA scan + uses: fossa-contrib/fossa-action@v3 + with: + fossa-api-key: 6d304c09a3ec097ba4517724e4a4d17d diff --git a/.github/workflows/master.yml b/.github/workflows/master.yml deleted file mode 100644 index 5c88d4b..0000000 --- a/.github/workflows/master.yml +++ /dev/null @@ -1,75 +0,0 @@ -# SPDX-License-Identifier: Apache-2.0 -# Copyright 2024 Intel Corporation - -name: Master workflow -on: - push: - branches: - - master - pull_request: - -jobs: - build: - runs-on: ubuntu-latest - steps: - - uses: actions/checkout@v4 - - uses: actions/setup-go@v5 - with: - go-version-file: 'go.mod' - - name: Build - run: go build -o build/_output/onos-kpimon ./cmd/onos-kpimon - - lint: - runs-on: ubuntu-latest - steps: - - uses: actions/checkout@v4 - - uses: actions/setup-go@v5 - with: - go-version-file: 'go.mod' - - uses: golangci/golangci-lint-action@v6.0.1 - with: - version: latest - args: -v --config ./.golangci.yml --timeout 5m - - unit-tests: - runs-on: ubuntu-latest - steps: - - uses: actions/checkout@v4 - - uses: actions/setup-go@v5 - with: - go-version-file: 'go.mod' - - name: Unit tests - run: | - go test -race github.com/onosproject/onos-kpimon/pkg/... - go test -race github.com/onosproject/onos-kpimon/cmd/... - - docker-build: - runs-on: ubuntu-latest - steps: - - uses: actions/checkout@v4 - - uses: actions/setup-go@v5 - with: - go-version-file: 'go.mod' - - name: Build Docker image - run: | - git clone https://github.com/onosproject/build-tools.git build/build-tools - go mod vendor - docker build . -f build/onos-kpimon/Dockerfile -t onosproject/onos-kpimon:latest - rm -rf vendor - - license-check: - runs-on: ubuntu-latest - steps: - - uses: actions/checkout@v4 - - name: reuse lint - uses: fsfe/reuse-action@v3 - - fossa-check: - runs-on: ubuntu-latest - steps: - - uses: actions/checkout@v4 - - - name: FOSSA scan - uses: fossa-contrib/fossa-action@v3 - with: - fossa-api-key: 6d304c09a3ec097ba4517724e4a4d17d diff --git a/.github/workflows/push.yml b/.github/workflows/push.yml deleted file mode 100644 index 0bf38e9..0000000 --- a/.github/workflows/push.yml +++ /dev/null @@ -1,241 +0,0 @@ -# SPDX-License-Identifier: Apache-2.0 -# Copyright 2024 Intel Corporation -# Copyright 2024 Kyunghee University -name: GitHub release and Docker images - -on: - push: - branches: - - master - tags: - - v* - -jobs: - push-images: - runs-on: ubuntu-latest - if: github.repository_owner == 'onosproject' - env: - REGISTRY: docker.io - DOCKER_REPOSITORY: onosproject/ - steps: - - uses: actions/checkout@v4 - with: - fetch-depth: 0 - - - uses: actions/setup-go@v5 - with: - go-version-file: 'go.mod' - - - run: echo GIT_SHA_SHORT=$(git rev-parse --short HEAD) >> $GITHUB_ENV - - - uses: docker/login-action@v3.1.0 - with: - registry: ${{ env.REGISTRY }} - username: ${{ secrets.DOCKER_USERNAME }} - password: ${{ secrets.DOCKER_PASSWORD }} - - - name: Build and push Docker image with tag latest - env: - DOCKER_TAG: latest - DOCKER_USERNAME: ${{ secrets.DOCKER_USERNAME }} - DOCKER_PASSWORD: ${{ secrets.DOCKER_PASSWORD }} - run: | - git clone https://github.com/onosproject/build-tools.git build/build-tools - make images - docker push ${{ env.DOCKER_REPOSITORY }}onos-kpimon:${{ env.DOCKER_TAG }} - - - name: Build and push Docker image with tag version - if: steps.version-change.outputs.changed == 'true' - env: - DOCKER_TAG: v${{ needs.tag-github.outputs.version }} - DOCKER_USERNAME: ${{ secrets.DOCKER_USERNAME }} - DOCKER_PASSWORD: ${{ secrets.DOCKER_PASSWORD }} - run: | - git clone https://github.com/onosproject/build-tools.git build/build-tools - make images - docker push ${{ env.DOCKER_REPOSITORY }}onos-kpimon:${{ env.DOCKER_TAG }} - - - name: Get changes - id: version-file - run: | - if git diff --name-only ${{ github.event.before }} ${{ github.event.after }} | grep VERSION; then - echo "changed=true" >> $GITHUB_OUTPUT - version_before=$(git show ${{ github.event.before }}:VERSION) - echo "version_before=$version_before" >> $GITHUB_OUTPUT - else - echo "VERSION file was not changed" - fi - - - name: Validate change in version file - id: version-change - if: steps.version-file.outputs.changed == 'true' - run: | - version=$(cat VERSION) - version_before_full=${{ steps.version-file.outputs.version_before }} - version_before=${version_before_full::-4} - echo "version=$version" - echo "version_before=$version_before" - validate="^[0-9]+\.[0-9]+\.[0-9]+$" - if [[ $version =~ $validate ]]; then - echo "changed=true" >> $GITHUB_OUTPUT - echo "version=$version" >> $GITHUB_OUTPUT - else - echo "Version change not for release" - fi - if [[ $version_before =~ $validate ]]; then - IFS='.' read -r major minor patch <<< "$version" - IFS='.' read -r major_b minor_b patch_b <<< "$version_before" - if [[ "$major" -ne "$major_b" ]] || [[ "$minor" -ne "$minor_b" ]]; then - version_branch="$major_b.$minor_b" - echo "release_branch=true" >> $GITHUB_OUTPUT - echo "version_branch=$version_branch" >> $GITHUB_OUTPUT - fi - else - echo "Version change not for branch release" - fi - - - # CAUTION: Other actions depend on this name "tag-github" - tag-github: - runs-on: ubuntu-latest - if: github.repository_owner == 'onosproject' - outputs: - changed: ${{ steps.version-change.outputs.changed }} - version: ${{ steps.version-change.outputs.version }} - release_branch: ${{ steps.version-change.outputs.release_branch }} - version_branch: ${{ steps.version-change.outputs.version_branch }} - steps: - - uses: actions/checkout@v4 - with: - fetch-depth: 0 - - - name: Get changes - id: version-file - run: | - if git diff --name-only ${{ github.event.before }} ${{ github.event.after }} | grep VERSION; then - echo "changed=true" >> $GITHUB_OUTPUT - version_before=$(git show ${{ github.event.before }}:VERSION) - echo "version_before=$version_before" >> $GITHUB_OUTPUT - else - echo "VERSION file was not changed" - fi - - - name: Validate change in version file - id: version-change - if: steps.version-file.outputs.changed == 'true' - run: | - version=$(cat VERSION) - version_before_full=${{ steps.version-file.outputs.version_before }} - version_before=${version_before_full::-4} - echo "version=$version" - echo "version_before=$version_before" - validate="^[0-9]+\.[0-9]+\.[0-9]+$" - if [[ $version =~ $validate ]]; then - echo "changed=true" >> $GITHUB_OUTPUT - echo "version=$version" >> $GITHUB_OUTPUT - else - echo "Version change not for release" - fi - if [[ $version_before =~ $validate ]]; then - IFS='.' read -r major minor patch <<< "$version" - IFS='.' read -r major_b minor_b patch_b <<< "$version_before" - if [[ "$major" -ne "$major_b" ]] || [[ "$minor" -ne "$minor_b" ]]; then - version_branch="$major_b.$minor_b" - echo "release_branch=true" >> $GITHUB_OUTPUT - echo "version_branch=$version_branch" >> $GITHUB_OUTPUT - fi - else - echo "Version change not for branch release" - fi - - - name: Create release using REST API - if: steps.version-change.outputs.changed == 'true' - run: | - curl -L \ - -X POST \ - -H "Accept: application/vnd.github+json" \ - -H "Authorization: Bearer ${{ secrets.GH_ONOS_PAT }}" \ - -H "X-GitHub-Api-Version: 2022-11-28" \ - https://api.github.com/repos/${{ github.repository }}/releases \ - -d '{ - "tag_name": "v${{ steps.version-change.outputs.version }}", - "target_commitish": "${{ github.event.repository.default_branch }}", - "name": "v${{ steps.version-change.outputs.version }}", - "draft": false, - "prerelease": false, - "generate_release_notes": true - }' - - #release-image: - # runs-on: ubuntu-latest - # needs: tag-github - # if: needs.tag-github.outputs.changed == 'true' - # env: - # REGISTRY: docker.io - # DOCKER_REPOSITORY: onosproject/ - # steps: - # - uses: actions/checkout@v4 - # - # - uses: actions/setup-go@v5 - # with: - # go-version-file: 'go.mod' - # - # - uses: docker/login-action@v3.1.0 - # with: - # registry: ${{ env.REGISTRY }} - # username: ${{ secrets.DOCKER_USERNAME }} - # password: ${{ secrets.DOCKER_PASSWORD }} - # - # - name: Build and push release Docker image - # env: - # DOCKER_TAG: ${{ needs.tag-github.outputs.version }} - # run: | - # git clone https://github.com/onosproject/build-tools.git build/build-tools - # make images - # docker push ${{ env.DOCKER_REPOSITORY }}onos-kpimon:${{ env.DOCKER_TAG }} - - update-version: - runs-on: ubuntu-latest - needs: tag-github - if: needs.tag-github.outputs.changed == 'true' - steps: - - uses: actions/checkout@v4 - - - name: Increment version - run: | - version=${{ needs.tag-github.outputs.version }} - IFS='.' read -r major minor patch <<< "$version" - patch_update=$((patch+1)) - NEW_VERSION="$major.$minor.$patch_update-dev" - echo $NEW_VERSION > VERSION - echo "Updated version: $NEW_VERSION" - - - name: Create Pull Request - uses: peter-evans/create-pull-request@v6 - with: - token: ${{ secrets.GH_ONOS_PAT }} - commit-message: Update version - committer: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> - author: ${{ github.actor }} <${{ github.actor_id }}+${{ github.actor }}@users.noreply.github.com> - signoff: false - branch: version-update - delete-branch: true - title: Update version - body: | - Update VERSION file - add-paths: | - VERSION - -# branch-release: -# runs-on: ubuntu-latest -# needs: tag-github -# if: (needs.tag-github.outputs.changed == 'true') && (needs.tag-github.outputs.release_branch == 'true') -# env: -# GITHUB_TOKEN: ${{ secrets.GH_ONOS_PAT }} -# steps: -# - uses: actions/checkout@v4 -# -# - uses: peterjgrainger/action-create-branch@v3.0.0 -# with: -# branch: "rel-${{ needs.tag-github.outputs.version_branch }}" -# sha: '${{ github.event.pull_request.head.sha }}' \ No newline at end of file diff --git a/.github/workflows/release.yml b/.github/workflows/release.yml new file mode 100644 index 0000000..699ade9 --- /dev/null +++ b/.github/workflows/release.yml @@ -0,0 +1,133 @@ +# SPDX-License-Identifier: Apache-2.0 +# Copyright 2024 Intel Corporation +# Copyright 2024 Kyunghee University +name: Publish image and tag/release code + +on: + push: + branches: + - master + +jobs: + version-check: + if: (github.repository_owner == 'onosproject') + runs-on: ubuntu-latest + outputs: + valid_version: ${{ steps.version-check-step.outputs.valid_version }} + dev_version: ${{ steps.dev-version-check-step.outputs.dev_version }} + target_version: ${{ steps.get-target-version-step.outputs.target_version }} + steps: + - uses: actions/checkout@v4 + with: + fetch-depth: 0 + + - name: check version + id: version-check-step + run: | + make check-version; if [[ $? == 0 ]]; then echo "valid_version=true" >> $GITHUB_OUTPUT; else echo "valid_version=false" >> $GITHUB_OUTPUT; fi + cat $GITHUB_OUTPUT + + - name: check dev version + id: dev-version-check-step + run: | + f_dev=$(./build/bin/version_check.sh is_dev) + if [[ $f_dev == "true" ]]; then echo "dev_version=true" >> $GITHUB_OUTPUT; else echo "dev_version=false" >> $GITHUB_OUTPUT; fi + cat $GITHUB_OUTPUT + + - name: get target version + id: get-target-version-step + run: | + echo "target_version=$(cat VERSION)" >> $GITHUB_OUTPUT + cat $GITHUB_OUTPUT + + tag_versions: + runs-on: ubuntu-latest + needs: version-check + if: (github.repository_owner == 'onosproject') && (needs.version-check.outputs.valid_version == 'true') && (needs.version-check.outputs.dev_version == 'false') + steps: + - uses: actions/checkout@v4 + with: + fetch-depth: 0 + - name: create release using REST API + run: | + curl -L \ + -X POST \ + -H "Accept: application/vnd.github+json" \ + -H "Authorization: Bearer ${{ secrets.GH_ONOS_PAT }}" \ + -H "X-GitHub-Api-Version: 2022-11-28" \ + https://api.github.com/repos/${{ github.repository }}/releases \ + -d '{ + "tag_name": "v${{ needs.version-check.outputs.target_version }}", + "target_commitish": "${{ github.event.repository.default_branch }}", + "name": "v${{ needs.version-check.outputs.target_version }}", + "draft": false, + "prerelease": false, + "generate_release_notes": true + }' + + publish-images: + runs-on: ubuntu-latest + needs: version-check + if: (github.repository_owner == 'onosproject') && (needs.version-check.outputs.valid_version == 'true') + env: + REGISTRY: docker.io + DOCKER_REPOSITORY: onosproject/ + steps: + - uses: actions/checkout@v4 + with: + fetch-depth: 0 + - uses: actions/setup-go@v5 + with: + go-version-file: 'go.mod' + - uses: docker/login-action@v3.1.0 + with: + registry: ${{ env.REGISTRY }} + username: ${{ secrets.DOCKER_USERNAME }} + password: ${{ secrets.DOCKER_PASSWORD }} + DOCKER_USERNAME: ${{ secrets.DOCKER_USERNAME }} + DOCKER_PASSWORD: ${{ secrets.DOCKER_PASSWORD }} + - name: Build and push Docker image with tag latest + env: + DOCKER_TAG: latest + run: | + ONOS_KPIMON_VERSION=${{ env.DOCKER_TAG }} make docker-build + ONOS_KPIMON_VERSION=${{ env.DOCKER_TAG }} make docker-push + - name: Build and push Docker image with tag + if: needs.version-check.outputs.dev_version == 'false' + env: + DOCKER_TAG: v${{ needs.version-check.outputs.target_version }} + run: | + ONOS_KPIMON_VERSION=${{ env.DOCKER_TAG }} make docker-build + ONOS_KPIMON_VERSION=${{ env.DOCKER_TAG }} make docker-push + + bump-up-version: + runs-on: ubuntu-latest + needs: version-check + if: (github.repository_owner == 'onosproject') && (needs.version-check.outputs.valid_version == 'true') && (needs.version-check.outputs.dev_version == 'false') + steps: + - uses: actions/checkout@v4 + with: + fetch-depth: 0 + - name: increment version + run: | + IFS='.' read -r major minor patch <<< ${{ needs.version-check.outputs.target_version }} + patch_update=$((patch+1)) + NEW_VERSION="$major.$minor.$patch_update-dev" + echo $NEW_VERSION > VERSION + echo "Updated version: $NEW_VERSION" + + - name: Create Pull Request + uses: peter-evans/create-pull-request@v6 + with: + token: ${{ secrets.GH_ONOS_PAT }} + commit-message: Update version + committer: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> + author: ${{ github.actor }} <${{ github.actor_id }}+${{ github.actor }}@users.noreply.github.com> + signoff: true + branch: version-update + delete-branch: true + title: Update version + body: | + Update VERSION file + add-paths: | + VERSION \ No newline at end of file diff --git a/.gitignore b/.gitignore index 33f4154..b0178aa 100644 --- a/.gitignore +++ b/.gitignore @@ -22,4 +22,4 @@ vendor *report*.xml *coverage*.xml *-output.out - +venv diff --git a/Makefile b/Makefile index 3bd8d15..3ad5e24 100644 --- a/Makefile +++ b/Makefile @@ -1,77 +1,67 @@ -# SPDX-FileCopyrightText: 2019-present Open Networking Foundation -# # SPDX-License-Identifier: Apache-2.0 +# Copyright 2019 Open Networking Foundation +# Copyright 2024 Intel Corporation export CGO_ENABLED=1 export GO111MODULE=on .PHONY: build -ONOS_KPIMON_VERSION := latest +ONOS_KPIMON_VERSION ?= latest ONOS_PROTOC_VERSION := v0.6.6 BUF_VERSION := 0.27.1 +GOLANG_CI_VERSION := v1.52.2 + +all: build images + build: # @HELP build the Go binaries and run all validations (default) build: GOPRIVATE="github.com/onosproject/*" go build -o build/_output/onos-kpimon ./cmd/onos-kpimon -build-tools:=$(shell if [ ! -d "./build/build-tools" ]; then cd build && git clone https://github.com/onosproject/build-tools.git; fi) -include ./build/build-tools/make/onf-common.mk - test: # @HELP run the unit tests and source code validation -test: build deps linters license +test: build lint license go test -race github.com/onosproject/onos-kpimon/pkg/... go test -race github.com/onosproject/onos-kpimon/cmd/... -jenkins-test: # @HELP run the unit tests and source code validation producing a junit style report for Jenkins -jenkins-test: deps license linters - TEST_PACKAGES=github.com/onosproject/onos-kpimon/... ./build/build-tools/build/jenkins/make-unit - -buflint: #@HELP run the "buf check lint" command on the proto files in 'api' - docker run -it -v `pwd`:/go/src/github.com/onosproject/onos-kpimon \ - -w /go/src/github.com/onosproject/onos-kpimon/api \ - bufbuild/buf:${BUF_VERSION} check lint - -protos: # @HELP compile the protobuf files (using protoc-go Docker) -protos: - docker run -it -v `pwd`:/go/src/github.com/onosproject/onos-kpimon \ - -w /go/src/github.com/onosproject/onos-kpimon \ - --entrypoint build/bin/compile-protos.sh \ - onosproject/protoc-go:${ONOS_PROTOC_VERSION} - -helmit-kpm: integration-test-namespace # @HELP run MHO tests locally - helmit test -n test ./cmd/onos-kpimon-test --timeout 30m --no-teardown --suite kpm - -helmit-ha: integration-test-namespace # @HELP run MHO HA tests locally - helmit test -n test ./cmd/onos-kpimon-test --timeout 30m --no-teardown --suite ha - -integration-tests: helmit-kpm helmit-ha # @HELP run all MHO integration tests locally - -onos-kpimon-docker: # @HELP build onos-kpimon Docker image -onos-kpimon-docker: +docker-build-onos-kpimon: # @HELP build onos-kpimon Docker image @go mod vendor docker build . -f build/onos-kpimon/Dockerfile \ -t onosproject/onos-kpimon:${ONOS_KPIMON_VERSION} @rm -rf vendor -images: # @HELP build all Docker images -images: build onos-kpimon-docker - -kind: # @HELP build Docker images and add them to the currently configured kind cluster -kind: images - @if [ "`kind get clusters`" = '' ]; then echo "no kind cluster found" && exit 1; fi - kind load docker-image onosproject/onos-kpimon:${ONOS_KPIMON_VERSION} - -all: build images - -publish: # @HELP publish version on github and dockerhub - ./build/build-tools/publish-version ${VERSION} onosproject/onos-kpimon - -jenkins-publish: jenkins-tools # @HELP Jenkins calls this to publish artifacts - ./build/bin/push-images - ./build/build-tools/release-merge-commit - -clean:: # @HELP remove all the build artifacts - rm -rf ./build/_output ./vendor ./cmd/onos-kpimon/onos-kpimon ./cmd/onos/onos - go clean -testcache github.com/onosproject/onos-kpimon/... - +docker-build: # @HELP build all Docker images +docker-build: build docker-build-onos-kpimon + +docker-push-onos-kpimon: # @HELP push onos-kpimon Docker image + docker push onosproject/onos-kpimon:${ONOS_KPIMON_VERSION} + +docker-push: # @HELP push docker images +docker-push: docker-push-onos-kpimon + +lint: # @HELP examines Go source code and reports coding problems + golangci-lint --version | grep $(GOLANG_CI_VERSION) || curl -sSfL https://raw.githubusercontent.com/golangci/golangci-lint/master/install.sh | sh -s -- -b `go env GOPATH`/bin $(GOLANG_CI_VERSION) + golangci-lint run --timeout 15m + +license: # @HELP run license checks + rm -rf venv + python3 -m venv venv + . ./venv/bin/activate;\ + python3 -m pip install --upgrade pip;\ + python3 -m pip install reuse;\ + reuse lint + +check-version: # @HELP check version is duplicated + ./build/bin/version_check.sh all + +clean: # @HELP remove all the build artifacts + rm -rf ./build/_output ./vendor ./cmd/onos-kpimon/onos-kpimon ./cmd/onos/onos venv + go clean github.com/onosproject/onos-kpimon/... + +help: + @grep -E '^.*: *# *@HELP' $(MAKEFILE_LIST) \ + | sort \ + | awk ' \ + BEGIN {FS = ": *# *@HELP"}; \ + {printf "\033[36m%-30s\033[0m %s\n", $$1, $$2}; \ + ' \ No newline at end of file diff --git a/build/bin/compile-protos.sh b/build/bin/compile-protos.sh deleted file mode 100644 index 7cba8bf..0000000 --- a/build/bin/compile-protos.sh +++ /dev/null @@ -1,27 +0,0 @@ -#!/bin/sh - -# SPDX-FileCopyrightText: 2019-present Open Networking Foundation -# -# SPDX-License-Identifier: Apache-2.0 - -proto_imports=".:${GOPATH}/src/github.com/gogo/protobuf/protobuf:${GOPATH}/src/github.com/gogo/protobuf:${GOPATH}/src/github.com/envoyproxy/protoc-gen-validate:${GOPATH}/src":"${GOPATH}/src/github.com/onosproject/onos-kpimon/api" - -# samples below -# admin.proto cannot be generated with fast marshaler/unmarshaler because it uses gnmi.ModelData -#protoc -I=$proto_imports --doc_out=docs/api --doc_opt=markdown,admin.md --gogo_out=Mgoogle/protobuf/timestamp.proto=github.com/gogo/protobuf/types,Mgoogle/protobuf/duration.proto=github.com/gogo/protobuf/types,import_path=github.com/onosproject/onos-e2t/api/admin,plugins=grpc:. api/admin/v1/*.proto -#protoc -I=$proto_imports --doc_out=docs/api --doc_opt=markdown,diags.md --gogo_out=Mgoogle/protobuf/timestamp.proto=github.com/gogo/protobuf/types,Mconfig/admin/admin.proto=github.com/onosproject/onos-e2t/api/admin,import_path=github.com/onosproject/onos-e2t/api/diags,plugins=grpc:. api/diags/*.proto - -#protoc -I=$proto_imports --doc_out=docs/api --doc_opt=markdown,headers.md --gogo_out=Mgoogle/protobuf/timestamp.proto=github.com/gogo/protobuf/types,Mgoogle/protobuf/duration.proto=github.com/gogo/protobuf/types,import_path=github.com/onosproject/onos-e2t/api,plugins=grpc:. api/ricapi/e2/headers/v1beta1/headers.proto -#protoc -I=$proto_imports --doc_out=docs/api --doc_opt=markdown,ricapi.md --gogo_out=Mgoogle/protobuf/timestamp.proto=github.com/gogo/protobuf/types,Mgoogle/protobuf/duration.proto=github.com/gogo/protobuf/types,import_path=github.com/onosproject/onos-e2t/api,plugins=grpc:. api/ricapi/e2/v1beta1/ricapi_e2.proto -#protoc -I=$proto_imports --doc_out=docs/api --doc_opt=markdown,subscription.md --gogofaster_out=Mgoogle/protobuf/timestamp.proto=github.com/gogo/protobuf/types,Mgoogle/protobuf/any.proto=github.com/gogo/protobuf/types,Mgoogle/protobuf/duration.proto=github.com/gogo/protobuf/types,import_path=github.com/onosproject/onos-e2t/api/subscription/v1beta1,plugins=grpc:. api/subscription/v1beta1/subscription.proto - - -#protoc -I=$proto_imports --validate_out=lang=go:. --proto_path=api --gogo_out=Mgoogle/protobuf/timestamp.proto=github.com/gogo/protobuf/types,Mgoogle/protobuf/duration.proto=github.com/gogo/protobuf/types,import_path=github.com/onosproject/onos-e2t/api:. api/e2ap/v1beta1/e2ap_commondatatypes.proto -#protoc -I=$proto_imports --validate_out=lang=go:. --proto_path=api --gogo_out=Mgoogle/protobuf/timestamp.proto=github.com/gogo/protobuf/types,Mgoogle/protobuf/duration.proto=github.com/gogo/protobuf/types,import_path=github.com/onosproject/onos-e2t/api:. api/e2ap/v1beta1/e2ap_constants.proto -#protoc -I=$proto_imports --validate_out=lang=go:. --proto_path=api --gogo_out=Mgoogle/protobuf/timestamp.proto=github.com/gogo/protobuf/types,Mgoogle/protobuf/duration.proto=github.com/gogo/protobuf/types,import_path=github.com/onosproject/onos-e2t/api:. api/e2ap/v1beta1/e2ap_containers.proto -#protoc -I=$proto_imports --validate_out=lang=go:. --proto_path=api --gogo_out=Mgoogle/protobuf/timestamp.proto=github.com/gogo/protobuf/types,Mgoogle/protobuf/duration.proto=github.com/gogo/protobuf/types,import_path=github.com/onosproject/onos-e2t/api:. api/e2ap/v1beta1/e2ap_ies.proto -#protoc -I=$proto_imports --validate_out=lang=go:. --proto_path=api --gogo_out=Mgoogle/protobuf/timestamp.proto=github.com/gogo/protobuf/types,Mgoogle/protobuf/duration.proto=github.com/gogo/protobuf/types,import_path=github.com/onosproject/onos-e2t/api:. api/e2ap/v1beta1/e2ap_pdu_contents.proto -#protoc -I=$proto_imports --validate_out=lang=go:. --proto_path=api --gogo_out=Mgoogle/protobuf/timestamp.proto=github.com/gogo/protobuf/types,Mgoogle/protobuf/duration.proto=github.com/gogo/protobuf/types,import_path=github.com/onosproject/onos-e2t/api:. api/e2ap/v1beta1/e2ap_pdu_descriptions.proto - -cp -r github.com/onosproject/onos-kpimon/* . -rm -rf github.com diff --git a/build/bin/push-images b/build/bin/push-images deleted file mode 100755 index 3a5af27..0000000 --- a/build/bin/push-images +++ /dev/null @@ -1,11 +0,0 @@ -#!/bin/bash - -# SPDX-FileCopyrightText: 2019-present Open Networking Foundation -# -# SPDX-License-Identifier: Apache-2.0 - -set -e - -echo "$DOCKER_PASSWORD" | docker login -u "$DOCKER_USER" --password-stdin -make images -docker push onosproject/onos-kpimon:latest diff --git a/build/bin/version_check.sh b/build/bin/version_check.sh new file mode 100755 index 0000000..feabddb --- /dev/null +++ b/build/bin/version_check.sh @@ -0,0 +1,93 @@ +#!/bin/bash +# SPDX-License-Identifier: Apache-2.0 +# Copyright 2024 Intel Corporation + +set +x + +# input should be all, is_valid_format, is_dev, and is_unique +INPUT=$1 + +function is_valid_format() { + # check if version format is matched to SemVer + VER_REGEX='^(0|[1-9][0-9]*)\.(0|[1-9][0-9]*)\.(0|[1-9][0-9]*)$' + if [[ ! $(cat VERSION | tr -d '\n' | sed s/-dev//) =~ $VER_REGEX ]] + then + return 1 + fi + return 0 +} + +function is_dev_version() { + # check if version has '-dev' + # if there is, no need to check version + if [[ $(cat VERSION | tr -d '\n' | tail -c 4) =~ "-dev" ]] + then + return 0 + fi + return 1 +} + +function is_unique_version() { + # check if the version is already tagged in GitHub repository + for t in $(git tag | cat) + do + if [[ $t == $(echo v$(cat VERSION | tr -d '\n')) ]] + then + return 1 + fi + done + return 0 +} + +case $INPUT in + all) + is_valid_format + f_valid=$? + if [[ $f_valid == 1 ]] + then + echo "ERROR: Version $(cat VERSION) is not in SemVer format" + exit 2 + fi + + is_dev_version + f_dev=$? + if [[ $f_dev == 0 ]] + then + echo "This is dev version" + exit 0 + fi + + is_unique_version + f_unique=$? + if [[ $f_unique == 1 ]] + then + echo "ERROR: duplicated tag $(cat VERSION)" + exit 2 + fi + ;; + + is_valid_format) + is_valid_format + ;; + + is_dev) + is_dev_version + f_dev=$? + if [[ $f_dev == 0 ]] + then + echo "true" + exit 0 + fi + echo "false" + ;; + + is_unique) + is_unique_version + ;; + + *) + echo -n "unknown input" + exit 2 + ;; + +esac diff --git a/build/onos-kpimon/Dockerfile b/build/onos-kpimon/Dockerfile index c9ede52..c6365f5 100644 --- a/build/onos-kpimon/Dockerfile +++ b/build/onos-kpimon/Dockerfile @@ -14,7 +14,7 @@ COPY cmd/ /go/src/github.com/onosproject/onos-kpimon/cmd/ COPY pkg/ /go/src/github.com/onosproject/onos-kpimon/pkg/ COPY vendor/ /go/src/github.com/onosproject/onos-kpimon/vendor/ COPY api/ /go/src/github.com/onosproject/onos-kpimon/api -COPY build/build-tools /go/src/github.com/onosproject/onos-kpimon/build/build-tools +COPY build/ /go/src/github.com/onosproject/onos-kpimon/build/ RUN cd /go/src/github.com/onosproject/onos-kpimon && GOFLAGS=-mod=vendor make ${ONOS_MAKE_TARGET}