| # Copyright 2019-present Open Networking Foundation |
| # |
| # 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. |
| |
| SHELL = bash -e -o pipefail |
| VERSION ?= $(shell cat ./VERSION) |
| DIFF ?= $(git diff --shortstat 2> /dev/null | tail -n1) |
| GIT_STATUS ?= $(shell [ -z "$DIFF" ] && echo "Dirty" || echo "Clean") |
| |
| ## Docker related |
| DOCKER_TAG ?= ${VERSION} |
| DOCKER_REPOSITORY ?= "" |
| DOCKER_REGISTRY ?= "" |
| DOCKER_RUN_ARGS ?= "" |
| DOCKER_PORTS ?= -p 50070:50070 -p 50060:50060 -p 50071:50071 -p 50072:50072 -p 50073:50073 -p 50074:50074 |
| TYPE ?= minimal |
| |
| # tool containers |
| VOLTHA_TOOLS_VERSION ?= 2.2.0 |
| |
| GO = docker run --rm --user $$(id -u):$$(id -g) -v ${CURDIR}:/app $(shell test -t 0 && echo "-it") -v gocache:/.cache -v gocache-${VOLTHA_TOOLS_VERSION}:/go/pkg voltha/voltha-ci-tools:${VOLTHA_TOOLS_VERSION}-golang go |
| GO_SH = docker run --rm --user $$(id -u):$$(id -g) -v ${CURDIR}:/app $(shell test -t 0 && echo "-it") -v gocache:/.cache -v gocache-${VOLTHA_TOOLS_VERSION}:/go/pkg voltha/voltha-ci-tools:${VOLTHA_TOOLS_VERSION}-golang sh -c ' |
| BBSIM_BUILDER = docker run --rm --user $$(id -u):$$(id -g) -v ${CURDIR}:/app $(shell test -t 0 && echo "-it") -v gocache:/.cache -v gocache-${VOLTHA_TOOLS_VERSION}:/go/pkg bbsim-builder go |
| GO_JUNIT_REPORT = docker run --rm --user $$(id -u):$$(id -g) -v ${CURDIR}:/app -i voltha/voltha-ci-tools:${VOLTHA_TOOLS_VERSION}-go-junit-report go-junit-report |
| GOCOVER_COBERTURA = docker run --rm --user $$(id -u):$$(id -g) -v ${CURDIR}:/app -i voltha/voltha-ci-tools:${VOLTHA_TOOLS_VERSION}-gocover-cobertura gocover-cobertura |
| BBSIM_LINTER = docker run --rm --user $$(id -u):$$(id -g) -v ${CURDIR}:/app $(shell test -t 0 && echo "-it") -v gocache:/.cache -v gocache-${VOLTHA_TOOLS_VERSION}:/go/pkg bbsim-linter:${VOLTHA_TOOLS_VERSION}-golangci-lint golangci-lint |
| HADOLINT = docker run --rm --user $$(id -u):$$(id -g) -v ${CURDIR}:/app $(shell test -t 0 && echo "-it") voltha/voltha-ci-tools:${VOLTHA_TOOLS_VERSION}-hadolint hadolint |
| PROTOC = docker run --rm --user $$(id -u):$$(id -g) -v ${CURDIR}:/app $(shell test -t 0 && echo "-it") -v gocache-${VOLTHA_TOOLS_VERSION}:/go/pkg voltha/voltha-ci-tools:${VOLTHA_TOOLS_VERSION}-protoc protoc |
| |
| builder: |
| @docker build -t bbsim-builder:latest -f build/ci/builder.Dockerfile build/ci/ |
| |
| linter: |
| # since this repo depends on C libs (libpcap), they are first added into a local container |
| @[[ "$(docker images -q bbsim-linter:${VOLTHA_TOOLS_VERSION}-golangci-lint 2> /dev/null)" != "" ]] || \ |
| docker build --build-arg=VOLTHA_TOOLS_VERSION=${VOLTHA_TOOLS_VERSION} -t bbsim-linter:${VOLTHA_TOOLS_VERSION}-golangci-lint -f build/ci/linter.Dockerfile build/ci/ |
| |
| |
| # Public targets |
| all: help |
| |
| protos: api/bbsim/bbsim.pb.go api/bbsim/bbsim.pb.gw.go api/legacy/bbsim.pb.go api/legacy/bbsim.pb.gw.go # @HELP Build proto files |
| |
| .PHONY: build |
| build: protos build-bbsim build-bbsimctl build-bbr |
| |
| ## lint and unit tests |
| |
| lint-dockerfile: |
| @echo "Running Dockerfile lint check..." |
| @${HADOLINT} $$(find ./build -name "Dockerfile*") |
| @echo "Dockerfile lint check OK" |
| |
| lint-mod: |
| @echo "Running dependency check..." |
| @${GO} mod verify |
| @echo "Dependency check OK. Running vendor check..." |
| @git status > /dev/null |
| @git diff-index --quiet HEAD -- go.mod go.sum vendor || (echo "ERROR: Staged or modified files must be committed before running this test" && git status -- go.mod go.sum vendor && exit 1) |
| @[[ `git ls-files --exclude-standard --others go.mod go.sum vendor` == "" ]] || (echo "ERROR: Untracked files must be cleaned up before running this test" && git status -- go.mod go.sum vendor && exit 1) |
| ${GO} mod tidy |
| ${GO} mod vendor |
| @git status > /dev/null |
| @git diff-index --quiet HEAD -- go.mod go.sum vendor || (echo "ERROR: Modified files detected after running go mod tidy / go mod vendor" && git status -- go.mod go.sum vendor && git checkout -- go.mod go.sum vendor && exit 1) |
| @[[ `git ls-files --exclude-standard --others go.mod go.sum vendor` == "" ]] || (echo "ERROR: Untracked files detected after running go mod tidy / go mod vendor" && git status -- go.mod go.sum vendor && git checkout -- go.mod go.sum vendor && exit 1) |
| @echo "Vendor check OK." |
| |
| lint: lint-mod lint-dockerfile |
| |
| sca: linter |
| @rm -rf ./sca-report |
| @mkdir -p ./sca-report |
| @echo "Running static code analysis..." |
| @${BBSIM_LINTER} run --deadline=4m --out-format junit-xml ./... | tee ./sca-report/sca-report.xml |
| @echo "" |
| @echo "Static code analysis OK" |
| |
| test: test-unit test-bbr |
| |
| test-unit: clean local-omci-sim builder # @HELP Execute unit tests |
| @mkdir -p ./tests/results |
| @${BBSIM_BUILDER} test -mod=vendor -v -coverprofile ./tests/results/go-test-coverage.out -covermode count ./... 2>&1 | tee ./tests/results/go-test-results.out ;\ |
| RETURN=$$? ;\ |
| ${GO_JUNIT_REPORT} < ./tests/results/go-test-results.out > ./tests/results/go-test-results.xml ;\ |
| ${GOCOVER_COBERTURA} < ./tests/results/go-test-coverage.out > ./tests/results/go-test-coverage.xml ;\ |
| exit $$RETURN |
| |
| test-bbr: release-bbr docker-build # @HELP Validate that BBSim and BBR are working together |
| DOCKER_RUN_ARGS="-pon 2 -onu 2" make docker-run |
| sleep 5 |
| ./$(RELEASE_DIR)/$(RELEASE_BBR_NAME)-linux-amd64 -pon 2 -onu 2 |
| docker rm -f bbsim |
| |
| mod-update: # @HELP Download the dependencies to the vendor folder |
| ${GO} mod tidy |
| ${GO} mod vendor |
| |
| docker-build: local-omci-sim# @HELP Build the BBSim docker container (contains BBSimCtl too) |
| docker build \ |
| -t ${DOCKER_REGISTRY}${DOCKER_REPOSITORY}bbsim:${DOCKER_TAG} \ |
| -f build/package/Dockerfile . |
| |
| docker-push: # @HELP Push the docker container to a registry |
| docker push ${DOCKER_REGISTRY}${DOCKER_REPOSITORY}bbsim:${DOCKER_TAG} |
| |
| docker-kind-load: |
| @if [ "`kind get clusters | grep voltha-$(TYPE)`" = '' ]; then echo "no voltha-$(TYPE) cluster found" && exit 1; fi |
| kind load docker-image ${DOCKER_REGISTRY}${DOCKER_REPOSITORY}bbsim:${DOCKER_TAG} --name=voltha-$(TYPE) --nodes $(shell kubectl get nodes --template='{{range .items}}{{.metadata.name}},{{end}}' | sed 's/,$$//') |
| |
| docker-run: # @HELP Runs the container locally (available options: DOCKER_RUN_ARGS="-pon 2 -onu 2" make docker-run) |
| docker run -d ${DOCKER_PORTS} --privileged --rm --name bbsim ${DOCKER_REGISTRY}${DOCKER_REPOSITORY}bbsim:${DOCKER_TAG} /app/bbsim ${DOCKER_RUN_ARGS} |
| |
| docker-run-dev: # @HELP Runs the container locally (intended for development purposes, not in detached mode) |
| docker run ${DOCKER_PORTS} --privileged --rm --name bbsim ${DOCKER_REGISTRY}${DOCKER_REPOSITORY}bbsim:${DOCKER_TAG} /app/bbsim ${DOCKER_RUN_ARGS} |
| |
| .PHONY: docs docs-lint |
| docs: swagger # @HELP Generate docs and opens them in the browser |
| make -C docs html |
| @echo -e "\nBBSim documentation generated in file://${PWD}/docs/build/html/index.html" |
| |
| docs-lint: |
| make -C docs lint |
| |
| # Release related items |
| # Generates binaries in $RELEASE_DIR with name $RELEASE_NAME-$RELEASE_OS_ARCH |
| # Inspired by: https://github.com/kubernetes/minikube/releases |
| RELEASE_DIR ?= release |
| RELEASE_OS_ARCH ?= linux-amd64 linux-arm64 windows-amd64 darwin-amd64 |
| |
| RELEASE_BBR_NAME ?= bbr |
| RELEASE_BBSIM_NAME ?= bbsim |
| RELEASE_BBSIMCTL_NAME ?= bbsimctl |
| |
| release-bbr: builder |
| @echo "$(RELEASE_BBR_NAME)-linux-amd64" |
| @${BBSIM_BUILDER} build -mod vendor \ |
| -ldflags "-w -X main.buildTime=$(shell date +%Y/%m/%d-%H:%M:%S) \ |
| -X main.commitHash=$(shell git log --pretty=format:%H -n 1) \ |
| -X main.gitStatus=${GIT_STATUS} \ |
| -X main.version=${VERSION}" \ |
| -o "$(RELEASE_DIR)/$(RELEASE_BBR_NAME)-linux-amd64" ./cmd/bbr |
| |
| release-bbsim: builder |
| @echo "$(RELEASE_BBSIM_NAME)-linux-amd64" |
| @${BBSIM_BUILDER} build -mod vendor \ |
| -ldflags "-w -X main.buildTime=$(shell date +%Y/%m/%d-%H:%M:%S) \ |
| -X main.commitHash=$(shell git log --pretty=format:%H -n 1) \ |
| -X main.gitStatus=${GIT_STATUS} \ |
| -X main.version=${VERSION}" \ |
| -o "$(RELEASE_DIR)/$(RELEASE_BBSIM_NAME)-linux-amd64" ./cmd/bbsim |
| |
| release-bbsimctl: |
| @${GO_SH} set -eo pipefail; \ |
| for os_arch in ${RELEASE_OS_ARCH}; do \ |
| echo "$(RELEASE_BBSIMCTL_NAME)-$$os_arch"; \ |
| GOOS="$${os_arch%-*}" GOARCH="$${os_arch#*-}" go build -mod vendor \ |
| -ldflags "-w -X github.com/opencord/bbsim/internal/bbsimctl/config.BuildTime=$(shell date +%Y/%m/%d-%H:%M:%S) \ |
| -X github.com/opencord/bbsim/internal/bbsimctl/config.CommitHash=$(shell git log --pretty=format:%H -n 1) \ |
| -X github.com/opencord/bbsim/internal/bbsimctl/config.GitStatus=${GIT_STATUS} \ |
| -X github.com/opencord/bbsim/internal/bbsimctl/config.Version=${VERSION}" \ |
| -o "$(RELEASE_DIR)/$(RELEASE_BBSIMCTL_NAME)-$$os_arch" ./cmd/bbsimctl; \ |
| done' |
| |
| .PHONY: release release-bbr release-bbsim release-bbsimctl |
| release: release-bbr release-bbsim release-bbsimctl # @HELP Creates release ready bynaries for BBSimctl and BBR artifacts |
| swagger: docs/swagger/bbsim/bbsim.swagger.json docs/swagger/leagacy/bbsim.swagger.json # @HELP Generate swagger documentation for BBSim API |
| |
| help: # @HELP Print the command options |
| @echo |
| @echo "\033[0;31m BroadBand Simulator (BBSim) \033[0m" |
| @echo |
| @echo Emulates the control plane of an openolt compatible device |
| @echo Useful for development and scale testing |
| @echo |
| @grep -E '^.*: .* *# *@HELP' $(MAKEFILE_LIST) \ |
| | sort \ |
| | awk ' \ |
| BEGIN {FS = ": .* *# *@HELP"}; \ |
| {printf "\033[36m%-30s\033[0m %s\n", $$1, $$2}; \ |
| ' |
| |
| ## Local Development Helpers |
| local-omci-sim: |
| ifdef LOCAL_OMCI_SIM |
| mkdir -p vendor/github.com/opencord/omci-sim/ |
| cp -r ${LOCAL_OMCI_SIM}/* vendor/github.com/opencord/omci-sim/ |
| endif |
| |
| # Internals |
| |
| clean: |
| @rm -f bbsim |
| @rm -f bbsimctl |
| @rm -f bbr |
| @rm -rf tools/bin |
| @rm -rf release/* |
| |
| build-bbr: local-omci-sim |
| @go build -mod vendor \ |
| -ldflags "-w -X main.buildTime=$(shell date +%Y/%m/%d-%H:%M:%S) \ |
| -X main.commitHash=$(shell git log --pretty=format:%H -n 1) \ |
| -X main.gitStatus=${GIT_STATUS} \ |
| -X main.version=${VERSION}" \ |
| ./cmd/bbr |
| |
| build-bbsim: |
| @go build -mod vendor \ |
| -ldflags "-w -X main.buildTime=$(shell date +%Y/%m/%d-%H:%M:%S) \ |
| -X main.commitHash=$(shell git log --pretty=format:%H -n 1) \ |
| -X main.gitStatus=${GIT_STATUS} \ |
| -X main.version=${VERSION}" \ |
| ./cmd/bbsim |
| |
| build-bbsimctl: |
| @go build -mod vendor \ |
| -ldflags "-w -X github.com/opencord/bbsim/internal/bbsimctl/config.BuildTime=$(shell date +%Y/%m/%d-%H:%M:%S) \ |
| -X github.com/opencord/bbsim/internal/bbsimctl/config.CommitHash=$(shell git log --pretty=format:%H -n 1) \ |
| -X github.com/opencord/bbsim/internal/bbsimctl/config.GitStatus=${GIT_STATUS} \ |
| -X github.com/opencord/bbsim/internal/bbsimctl/config.Version=${VERSION}" \ |
| ./cmd/bbsimctl |
| |
| setup_tools: |
| @echo "Downloading dependencies..." |
| @${GO} mod download github.com/grpc-ecosystem/grpc-gateway github.com/opencord/voltha-protos/v2 |
| @echo "Dependencies downloaded OK" |
| |
| VOLTHA_PROTOS ?= $(shell ${GO} list -f '{{ .Dir }}' -m github.com/opencord/voltha-protos/v2) |
| GOOGLEAPI ?= $(shell ${GO} list -f '{{ .Dir }}' -m github.com/grpc-ecosystem/grpc-gateway) |
| |
| .PHONY: api/openolt/openolt.pb.go api/bbsim/bbsim.pb.go api/bbsim/bbsim.pb.gw.go api/legacy/bbsim.pb.go api/legacy/bbsim.pb.gw.go docs/swagger/bbsim/bbsim.swagger.json docs/swagger/leagacy/bbsim.swagger.json |
| api/openolt/openolt.pb.go: api/openolt/openolt.proto setup_tools |
| @echo $@ |
| @${PROTOC} -I. \ |
| -I${GOOGLEAPI}/third_party/googleapis \ |
| --go_out=plugins=grpc:./ \ |
| $< |
| |
| api/bbsim/bbsim.pb.go api/bbsim/bbsim.pb.gw.go: api/bbsim/bbsim.proto api/bbsim/bbsim.yaml setup_tools |
| @echo $@ |
| @${PROTOC} -I. \ |
| -I${GOOGLEAPI}/third_party/googleapis \ |
| -I${VOLTHA_PROTOS}/protos/ \ |
| --go_out=plugins=grpc:./ \ |
| --grpc-gateway_out=logtostderr=true,grpc_api_configuration=api/bbsim/bbsim.yaml,allow_delete_body=true:./ \ |
| $< |
| |
| api/legacy/bbsim.pb.go api/legacy/bbsim.pb.gw.go: api/legacy/bbsim.proto setup_tools |
| @echo $@ |
| @${PROTOC} -I. \ |
| -I${GOOGLEAPI}/third_party/googleapis/ \ |
| -I${GOOGLEAPI}/ \ |
| -I${VOLTHA_PROTOS}/protos/ \ |
| --go_out=plugins=grpc:./ \ |
| --grpc-gateway_out=logtostderr=true,allow_delete_body=true:./ \ |
| $< |
| |
| docs/swagger/bbsim/bbsim.swagger.json: api/bbsim/bbsim.yaml setup_tools |
| @echo $@ |
| @${PROTOC} -I ./api \ |
| -I${GOOGLEAPI}/ \ |
| -I${VOLTHA_PROTOS}/protos/ \ |
| --swagger_out=logtostderr=true,allow_delete_body=true,disable_default_errors=true,grpc_api_configuration=$<:docs/swagger/ \ |
| api/bbsim/bbsim.proto |
| |
| docs/swagger/leagacy/bbsim.swagger.json: api/legacy/bbsim.proto setup_tools |
| @echo $@ |
| @${PROTOC} -I ./api \ |
| -I${GOOGLEAPI}/ \ |
| -I${VOLTHA_PROTOS}/protos/ \ |
| --swagger_out=logtostderr=true,allow_delete_body=true,disable_default_errors=true:docs/swagger/ \ |
| $< |