-
Notifications
You must be signed in to change notification settings - Fork 27
/
Copy pathMakefile
223 lines (189 loc) · 7.98 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
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
TOP_DIR = ../..
DEPLOY_RUNTIME=/kb/runtime
TARGET ?= /kb/deployment
include $(TOP_DIR)/tools/Makefile.common
SERVICE_SPEC = Transform.spec
SERVICE_NAME = Transform
SERVICE_DIR_NAME = transform
SERVICE_DIR = $(TARGET)/services/$(SERVICE_NAME)
SERVICE_PORT = 7778
DIR = $(shell pwd)
TPAGE = $(DEPLOY_RUNTIME)/bin/tpage
TPAGE_ARGS = --define kb_top=$(TARGET) --define kb_runtime=$(DEPLOY_RUNTIME) --define kb_service_name=$(SERVICE_NAME) \
--define kb_service_port=$(SERVICE_PORT)
ANT = ant
# to wrap scripts and deploy them to $(TARGET)/bin using tools in
# the dev_container. right now, these vars are defined in
# Makefile.common, so it's redundant here.
TOOLS_DIR = $(TOP_DIR)/tools
SRC_PERL = $(wildcard plugins/scripts/*/*.pl)
#WRAP_RSCRIPT_TOOL = wrap_rscript
#WRAP_RSCRIPT_SCRIPT = bash $(TOOLS_DIR)/$(WRAP_RSCRIPT_TOOL).sh
#SRC_R = $(wildcard scripts/*.R)
SRC_PYTHON = $(wildcard plugins/scripts/*/*.py)
# You can change these if you are putting your tests somewhere
# else or if you are not using the standard .t suffix
CLIENT_TESTS = $(wildcard t/client-tests/*.t)
SCRIPT_TESTS = $(wildcard t/script-tests/*.t)
SERVER_TESTS = $(wildcard t/server-tests/*.t)
# This is a very client centric view of release engineering.
# We assume our primary product for the community is the client
# libraries and command line interfaces on which specific
# science applications can be built.
#
# A service is composed of a client and a server, each of which
# should be independently deployable. Clients are composed of
# an application programming interface and a command line
# interface. In our make targets, the deploy-service deploys
# the server, the deploy-client deploys the application
# programming interface libraries, and the deploy-scripts deploys
# the command line interface (usually scripts written in a
# scripting language but java executables also qualify), and the
# deploy target would be equivelant to deploying a service (client
# libs, scripts, and server).
#
# Because the deployment of the server side code depends on the
# specific software module being deployed, the strategy needs
# to be one that leaves this decision to the module developer.
# This is done by having the deploy target depend on the
# deploy-service target. The module developer who chooses for
# good reason not to deploy the server with the client simply
# manages this dependancy accordingly. One option is to have
# a deploy-service target that does nothing, the other is to
# remove the dependancy from the deploy target.
#
# A smiliar naming convention is used for tests.
default: build-libs
# Test Section
test: test-java test-client test-scripts
echo "running java, client, and script tests"
test-java:
$(ANT) test
# test-all is deprecated.
# test-all: test-client test-scripts test-service
#
# What does it mean to test a client. This is a test of a client
# library. If it is a client-server module, then it should be
# run against a running server. You can say that this also tests
# the server, and I agree. You can add a test-service dependancy
# to the test-client target if it makes sense to you. This test
# example assumes there is already a tested running server.
test-client:
# run each test
for t in $(CLIENT_TESTS) ; do \
if [ -f $$t ] ; then \
$(DEPLOY_RUNTIME)/bin/perl $$t ; \
if [ $$? -ne 0 ] ; then \
exit 1 ; \
fi \
fi \
done
# What does it mean to test a script? A script test should test
# the command line scripts. If the script is a client in a client-
# server architecture, then there should be tests against a
# running server. You can add a test-service dependancy to the
# test-client target. You could also add a deploy-service and
# start-server dependancy to the test-scripts target if it makes
# sense to you. Future versions of the make files for services
# will move in this direction.
test-scripts: test-py-scripts
# run each test
for t in $(SCRIPT_TESTS) ; do \
if [ -f $$t ] ; then \
$(DEPLOY_RUNTIME)/bin/perl $$t ; \
if [ $$? -ne 0 ] ; then \
exit 1 ; \
fi \
fi \
done
setup-py-test-env:
if [ $$KB_TOP = '/kb/dev_container' ] ; then \
for P in `ls ..` ; do \
if [ $$P != $(SERVICE_DIR_NAME) ] ; then \
for F in `ls ../$$P/lib/biokbase/` ; do \
if [ -d ../$$P/lib/biokbase/$$F ] ; then \
ln -sf -t lib/biokbase/ $(KB_TOP)/modules/$$P/lib/biokbase/$$F ; \
fi \
done \
fi \
done \
fi
test-py-scripts: setup-py-test-env
t/py/setup_test_env.py
PYTHONPATH=$(DIR)/lib/ KB_KEEP_TEST_VENV=1 nosetests -v t/py
# What does it mean to test a server. A server test should not
# rely on the client libraries or scripts in so far as you should
# not have a test-service target that depends on the test-client
# or test-scripts targets. Otherwise, a circular dependency
# graph could result.
test-server:
# run each test
for t in $(SERVER_TESTS) ; do \
if [ -f $$t ] ; then \
$(DEPLOY_RUNTIME)/bin/perl $$t ; \
if [ $$? -ne 0 ] ; then \
exit 1 ; \
fi \
fi \
done
include $(TOP_DIR)/tools/Makefile.common.rules
# here are the standard KBase deployment targets (deploy,deploy-client, deploy-scripts, & deploy-service)
deploy: deploy-libs deploy-scripts deploy-service deploy-bins deploy-jars
deploy-bins:
rsync --exclude '*.bak*' -arv bin/. $(TARGET)/bin/.
bash deps/pylib.sh
bash deps/pllib.sh
deploy-jars:
cp lib/jars/kbase/transform/* $(TARGET)/lib/jars/kbase/transform/
# Deploy client artifacts, including the application programming interface
# libraries, command line scripts, and associated reference documentation.
deploy-client: deploy-libs deploy-scripts deploy-docs
# Deploy command line scripts. The scripts are "wrapped" so users do not
# need to modify their environment to run KBase scripts.
deploy-scripts:
find plugins/scripts -name '*.py' -exec cp {} $(TARGET)/pybin/ \;
find plugins/scripts -name '*.pl' -exec cp {} $(TARGET)/plbin/ \;
# Deploy documentation of the application programming interface.
# (Waiting for resolution on documentation of command line scripts).
deploy-docs: build-docs
if [ ! -d $(SERVICE_DIR)/webroot ] ; then mkdir -p $(SERVICE_DIR)/webroot ; fi
cp docs/*html $(SERVICE_DIR)/webroot/.
build-docs: build-libs
if [ ! -d docs ] ; then mkdir -p docs ; fi
pod2html -t "Transform" lib/Bio/KBase/Transform/Client.pm > docs/Transform.html
# Deploy service start and stop scripts.
deploy-service: deploy-cfg
if [ ! -d $(SERVICE_DIR) ] ; then mkdir -p $(SERVICE_DIR) ; fi
tpage $(TPAGE_ARGS) service/start_service.tt > $(SERVICE_DIR)/start_service; \
chmod +x $(SERVICE_DIR)/start_service; \
tpage $(TPAGE_ARGS) service/stop_service.tt > $(SERVICE_DIR)/stop_service; \
chmod +x $(SERVICE_DIR)/stop_service; \
tpage $(TPAGE_ARGS) service/process.tt > $(SERVICE_DIR)/process.$(SERVICE_NAME); \
chmod +x $(SERVICE_DIR)/process.$(SERVICE_NAME);
mkdir -p $(SERVICE_DIR)/awf
cat deploy.cfg service.cfg > $(SERVICE_DIR)/service.cfg;
mkdir -p $(SERVICE_DIR)/plugins/configs;
cp plugins/configs/*.json $(SERVICE_DIR)/plugins/configs/;
# the above service.cfg is not correct at the moment
# Use this if you want to unlink the generation of the docs from
# the generation of the libs. Not recommended, but could be a
# reason for it that I'm not seeing.
# The compile-docs should depend on build-libs so that we are ensured
# of having a set of documentation that is based on the latest
# type spec.
# Build libs should be dependent on the type specification and the
# type compiler. Building the libs in this way means that you don't
# need to put automatically generated code in a source code version
# control repository (ie cvs, git). It also ensures that you always
# have the most up-to-date libs and documentation if your compile
# docs depends on the compiled libs.
build-libs:
mkdir -p scripts; compile_typespec \
--pyimpl biokbase.$(SERVICE_NAME).Impl \
--pyserver biokbase.$(SERVICE_NAME).Server \
--client Bio::KBase::$(SERVICE_NAME)::Client \
--py biokbase/$(SERVICE_NAME)/Client \
--js javascript/$(SERVICE_NAME)/Client \
$(SERVICE_SPEC) lib
$(ANT) compile
# --scripts scripts \ # script is not working