forked from zendesk/maxwell
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathMakefile
128 lines (98 loc) · 5.5 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
all: compile
MAXWELL_VERSION ?=$(shell build/current_rev)
# If KAFKA_VERSION is provided, replace pom version with it
# (e.g. KAFKA_VERSION=0.8.2.2 make test)
LOCK_KAFKA_VERSION = $(shell [ -n "$(KAFKA_VERSION)" ] && echo "--lock-version org.apache.kafka/kafka-clients=$(KAFKA_VERSION)")
# Which additional version of kafka-clients will be fetched; should match the
# one declared in bin/maxwell bin/maxwell-bootstrap
ADDITIONAL_PACKAGED_KAFKA_08=0.8.2.2
ADDITIONAL_PACKAGED_KAFKA_010=0.10.0.1
ADDITIONAL_PACKAGED_KAFKA_01010=0.10.1.0
JAVAC=javac
JAVAC_FLAGS += -d target/classes
JAVAC_FLAGS += -sourcepath src/main/java:src/test/java:target/generated-sources/src/main/antlr4
JAVAC_FLAGS += -g -target 1.7 -source 1.7 -encoding UTF-8 -Xlint:-options -Xlint:unchecked
# files that just get copied to the root of the maxwell distro
DISTFILES=README.md docs/docs/quickstart.md docs/docs/config.md LICENSE src/main/resources/log4j2.xml config.properties.example kinesis-producer-library.properties.example
ANTLR_DEPS=$(shell build/maven_fetcher -f org.antlr/antlr4/4.5 -o target/dependency-antlr)
ANTLR=java -cp $(ANTLR_DEPS) org.antlr.v4.Tool
ANTLR_SRC=src/main/antlr4/com/zendesk/maxwell/schema/ddl/mysql.g4
ANTLR_IMPORTS=src/main/antlr4/imports
ANTLR_DIR=target/generated-sources/src/main/antlr4/com/zendesk/maxwell/schema/ddl
ANTLR_OUTPUT=$(ANTLR_DIR)/mysqlBaseListener.java $(ANTLR_DIR)/mysqlLexer.java $(ANTLR_DIR)/mysqlListener.java $(ANTLR_DIR)/mysqlParser.java
$(ANTLR_IMPORTS)/mysql_literal_tokens.g4: $(ANTLR_IMPORTS)/generate_tokens.rb
ruby $(ANTLR_IMPORTS)/generate_tokens.rb
$(ANTLR_OUTPUT): $(ANTLR_SRC) $(ANTLR_IMPORTS)/*.g4
${ANTLR} -package com.zendesk.maxwell.schema.ddl -lib $(ANTLR_IMPORTS) -o target/generated-sources $(ANTLR_SRC)
compile-antlr: $(ANTLR_OUTPUT)
JAVA_SOURCE = $(shell find src/main/java -name '*.java')
JAVA_DEPENDS = $(shell build/maven_fetcher -p -o target/dependency $(LOCK_KAFKA_VERSION))
target/.java: $(ANTLR_OUTPUT) $(JAVA_SOURCE)
@mkdir -p target/classes
@# Fetch jar so we can run it locally (bin/maxwell)
build/maven_fetcher -f org.apache.kafka/kafka-clients/$(ADDITIONAL_PACKAGED_KAFKA_08) --skip-dependencies -o target/dependency >/dev/null
build/maven_fetcher -f org.apache.kafka/kafka-clients/$(ADDITIONAL_PACKAGED_KAFKA_010) --skip-dependencies -o target/dependency >/dev/null
build/maven_fetcher -f org.apache.kafka/kafka-clients/$(ADDITIONAL_PACKAGED_KAFKA_01010) --skip-dependencies -o target/dependency >/dev/null
$(JAVAC) -classpath $(JAVA_DEPENDS) $(JAVAC_FLAGS) $?
@touch target/.java
copy-resources:
@cp -a src/main/resources/* target/classes
compile-java: target/.java
compile: compile-antlr compile-java copy-resources
JAVA_TEST_DEPENDS = $(shell build/maven_fetcher -p -o target/dependency-test -s test $(LOCK_KAFKA_VERSION))
JAVA_TEST_SOURCE=$(shell find src/test/java -name '*.java')
target/.java-test: $(JAVA_TEST_SOURCE)
@mkdir -p target/test-classes
cp -a src/test/resources/* target/test-classes
javac -d target/test-classes -sourcepath src/main/java:src/test/java:target/generated-sources -classpath target/classes:$(JAVA_TEST_DEPENDS) \
-g -target 1.7 -source 1.7 -encoding UTF-8 $?
@touch target/.java-test
compile-test: compile target/.java-test
TEST_CLASSES=$(shell build/get-test-classes)
define get_test_parameters
$(eval filter=$(shell echo $(1) | perl -ne '/#(.*)/; print "--filter=com.zendesk.maxwell.JUnitNameFilterFactory=$$1" if $$1')) \
$(eval class_pattern=$(shell echo $(1) | perl -ne '/test\.(\w+)/; print $$1 if $$1')) \
$(eval classes=$(if $(class_pattern),$(filter %$(class_pattern),$(TEST_CLASSES)),$(TEST_CLASSES))) \
$(filter) $(classes)
endef
test%: compile-test
java -classpath $(JAVA_TEST_DEPENDS):target/test-classes:target/classes org.junit.runner.JUnitCore $(call get_test_parameters,$@)
test: compile-test
java -classpath $(JAVA_TEST_DEPENDS):target/test-classes:target/classes org.junit.runner.JUnitCore $(TEST_CLASSES)
test-only: compile-test
java -classpath $(JAVA_TEST_DEPENDS):target/test-classes:target/classes org.junit.runner.JUnitCore ${ARGS}
clean:
rm -f target/.java target/.java-test
rm -rf target/classes
rm -rf target/generated-sources
rm -f target/*.jar
depclean: clean
rm -f $(CLASSPATH)
rm -Rf target/dependency
PKGNAME=maxwell-${MAXWELL_VERSION}
MAVEN_DIR=target/classes/META-INF/maven/com.zendesk/maxwell
MAXWELL_JARFILE=target/$(PKGNAME).jar
package-jar: all
rm -f ${MAXWELL_JARFILE}
mkdir -p ${MAVEN_DIR}
sed -e "s/VERSION/${MAXWELL_VERSION}/" build/pom.properties > ${MAVEN_DIR}/pom.properties
cp pom.xml ${MAVEN_DIR}
echo "Implementation-Version: ${MAXWELL_VERSION}" >target/jar-manifest
jar cvmf target/jar-manifest ${MAXWELL_JARFILE} -C target/classes .
TARDIR=target/$(PKGNAME)
TARFILE=target/$(PKGNAME).tar.gz
package-tar:
rm -Rf target/dependency-build
build/maven_fetcher -p -o target/dependency-build >/dev/null
# Include kafka 0.8 jar
build/maven_fetcher -f org.apache.kafka/kafka-clients/$(ADDITIONAL_PACKAGED_KAFKA_08) --skip-dependencies -o target/dependency-build >/dev/null
build/maven_fetcher -f org.apache.kafka/kafka-clients/$(ADDITIONAL_PACKAGED_KAFKA_010) --skip-dependencies -o target/dependency-build >/dev/null
build/maven_fetcher -f org.apache.kafka/kafka-clients/$(ADDITIONAL_PACKAGED_KAFKA_01010) --skip-dependencies -o target/dependency-build >/dev/null
rm -Rf $(TARDIR) $(TARFILE)
mkdir $(TARDIR)
cp $(DISTFILES) $(TARDIR)
cp -a bin $(TARDIR)
mkdir $(TARDIR)/lib
cp -a $(MAXWELL_JARFILE) target/dependency-build/* $(TARDIR)/lib
tar czvf $(TARFILE) -C target $(PKGNAME)
package: depclean package-jar package-tar