-
Notifications
You must be signed in to change notification settings - Fork 22
/
Copy pathMakefile
83 lines (64 loc) · 3.12 KB
/
Makefile
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
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
# Make targets for building the IBM example helloworld edge service
# This imports the variables from horizon/hzn.json. You can ignore these lines, but do not remove them
-include horizon/.hzn.json.tmp.mk
# Default ARCH to the architecture of this machines (as horizon/golang describes it)
export ARCH = amd64
# Configurable parameters passed to serviceTest.sh in "test" target
export MATCH:='says: Hello'
export TIME_OUT:=60
# Build the docker image for the current architecture
build:
docker build -t $(DOCKER_IMAGE_BASE)_$(ARCH):$(SERVICE_VERSION) -f ./Dockerfile.$(ARCH) .
# Build the docker image for 3 architectures
build-all-arches:
ARCH=amd64 $(MAKE) build
# Target for travis to test new PRs
test-all-arches:
ARCH=amd64 $(MAKE) test
# Run and verify the service
test: build
hzn dev service start -S
@echo 'Testing service...'
../../../tools/serviceTest.sh $(SERVICE_NAME) $(MATCH) $(TIME_OUT) && \
{ hzn dev service stop; \
echo "*** Service test succeeded! ***"; } || \
{ hzn dev service stop; \
echo "*** Service test failed! ***"; \
false ;}
# Publish the service to the Horizon Exchange for the current architecture
publish-service:
hzn exchange service publish -I -O -r "us.icr.io:iamapikey:$(APIKEY)" -f horizon/service.definition.json
# Target for travis to publish service and pattern after PR is merged
publish:
ARCH=amd64 $(MAKE) publish-service
ARCH=amd64 $(MAKE) publish-service-policy
$(MAKE) publish-deployment-policy
hzn exchange pattern publish -f horizon/pattern-all-arches.json
# Build, run and verify, if test succeeds then publish (for the current architecture)
build-test-publish: build test publish-service
# Build/test/publish the service to the Horizon Exchange for 3 architectures and publish a deployment pattern for those architectures
publish-all-arches:
ARCH=amd64 $(MAKE) build-test-publish
hzn exchange pattern publish -f horizon/pattern-all-arches.json
# target for script - overwrite and pull insitead of push docker image
publish-service-overwrite:
hzn exchange service publish -O -P -f horizon/service.definition.json
# Publish Service Policy target for exchange publish script
publish-service-policy:
hzn exchange service addpolicy -f horizon/service.policy.json $(HZN_ORG_ID)/$(SERVICE_NAME)_$(SERVICE_VERSION)_$(ARCH)
# Publish Deployment Policy target for exchange publish script
publish-deployment-policy:
hzn exchange deployment addpolicy -f horizon/deployment.policy.json $(HZN_ORG_ID)/policy-$(SERVICE_NAME)_$(SERVICE_VERSION)
# new target for icp exchange to run on startup to publish only
publish-only:
ARCH=amd64 $(MAKE) publish-service-overwrite
ARCH=amd64 $(MAKE) publish-service-policy
hzn exchange pattern publish -f horizon/pattern-all-arches.json
clean:
-docker rmi $(DOCKER_IMAGE_BASE)_$(ARCH):$(SERVICE_VERSION) 2> /dev/null || :
clean-all-archs:
ARCH=amd64 $(MAKE) clean
# This imports the variables from horizon/hzn.cfg. You can ignore these lines, but do not remove them.
horizon/.hzn.json.tmp.mk: horizon/hzn.json
@ hzn util configconv -f $< | sed 's/=/?=/' > $@
.PHONY: build build-all-arches test publish-service build-test-publish publish-all-arches clean clean-all-archs