aboutsummaryrefslogtreecommitdiffstats
path: root/src/k8splugin/Makefile
blob: 51b1f1a9a33d4cc9353228a86c4713698cffe3a7 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
# SPDX-license-identifier: Apache-2.0
##############################################################################
# Copyright (c) 2018 Intel Corporation
# All rights reserved. This program and the accompanying materials
# are made available under the terms of the Apache License, Version 2.0
# which accompanies this distribution, and is available at
# http://www.apache.org/licenses/LICENSE-2.0
##############################################################################

GOPATH := $(shell realpath "$(PWD)/../../")

export GOPATH ...
export GO111MODULE=on

.PHONY: plugins


all: clean plugins
	CGO_ENABLED=1 GOOS=linux GOARCH=amd64
	@go build -tags netgo -o ./k8plugin ./cmd/main.go

# The following is done this way as each patch on CI runs build and each merge runs deploy. So for build we don't need to build binary and hence
# no need to create a static binary with additional flags. However, for generating binary, additional build flags are necessary. This if used with
# mock plugin errors out for unit tests. So the seperation avoids the error.

build: clean plugins test cover
deploy: build

.PHONY: test
test: unit integration

.PHONY: unit
unit:
	@go test -v -tags 'unit' ./...

.PHONY: integration
integration: clean
	@go build -buildmode=plugin -o ./mock_files/mock_plugins/mockplugin.so ./mock_files/mock_plugins/mockplugin.go
	@go build -buildmode=plugin -o ./mock_files/mock_plugins/mocknetworkplugin.so ./mock_files/mock_plugins/mocknetworkplugin.go
	@go test -v -tags 'integration' ./...

format:
	@go fmt ./...

plugins:
	@find plugins -maxdepth 1 -type d -not -path plugins -exec sh -c "ls {}/plugin.go | xargs go build -buildmode=plugin -tags netgo -o $(basename {}).so" \;

clean:
	@find . -name "*so" -delete
	@rm -f k8plugin

.PHONY: cover
cover:
	@go test -tags 'unit' ./... -coverprofile=coverage.out
	@go tool cover -html=coverage.out -o coverage.html