Skip to content

Commit 8400b1c

Browse files
authored
Add CI action (#72)
* Add CI action * add wrapper directly to repo and update readme * test multiple gradle versions (will test different java separately) * Handle deprecations * No for gradle 5
1 parent 8ef01ce commit 8400b1c

File tree

10 files changed

+378
-22
lines changed

10 files changed

+378
-22
lines changed

.github/workflows/gradle.yml

Lines changed: 70 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,70 @@
1+
name: Java CI
2+
3+
on:
4+
push:
5+
branches:
6+
- master
7+
pull_request:
8+
branches:
9+
- master
10+
11+
jobs:
12+
build:
13+
runs-on: ubuntu-latest
14+
strategy:
15+
matrix:
16+
java: ["8"]
17+
gradle: ["6.0", "6.1", "6.2"]
18+
steps:
19+
- uses: actions/checkout@722adc6
20+
with:
21+
fetch-depth: 0
22+
23+
- name: Set up JDK ${{ matrix.java }}
24+
uses: actions/setup-java@081536e
25+
with:
26+
java-version: ${{ matrix.java }}
27+
28+
- name: Set up Node.js 12
29+
uses: actions/setup-node@8de2f9f
30+
with:
31+
node-version: 12
32+
33+
- uses: actions/cache@cffae95
34+
with:
35+
path: ~/.gradle/caches
36+
key: ${{ runner.os }}-gradle-${{ hashFiles('**/*.gradle') }}
37+
restore-keys: |
38+
${{ runner.os }}-gradle-
39+
40+
- name: Gradle Wrapper Validation
41+
uses: gradle/wrapper-validation-action@v1
42+
43+
- name: Build with Gradle
44+
run: ./gradlew build --no-daemon -Dsnom.test.functional.gradle=${{ matrix.gradle }}
45+
# TODO: Enable release, sonar and artifacts
46+
#- name: Run Semantic Release
47+
# run: |
48+
# echo "gradle.publish.key=${{ secrets.GRADLE_PUBLISH_KEY }}" > ~/.gradle/gradle.properties
49+
# echo "gradle.publish.secret=${{ secrets.GRADLE_PUBLISH_SECRET }}" >> ~/.gradle/gradle.properties
50+
# rm -rf build/libs/*.jar
51+
# npm ci
52+
# npm run semantic-release
53+
# if: matrix.gradle == '6.0'
54+
# env:
55+
# GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
56+
# - name: Run SonarQube Scanner
57+
# run: |
58+
# if [ "$SONAR_LOGIN" != "" ]; then
59+
# ./gradlew sonarqube -Dsonar.login=$SONAR_LOGIN --no-daemon
60+
# fi
61+
# if: matrix.gradle == '6.0'
62+
# env:
63+
# GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
64+
# SONAR_LOGIN: ${{ secrets.SONAR_LOGIN }}
65+
# TODO: upload artifacts
66+
# - uses: actions/upload-artifact@3446296
67+
# if: always()
68+
# with:
69+
# name: reports
70+
# path: build/reports

.github/workflows/javadoc.yml

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -20,7 +20,7 @@ jobs:
2020
with:
2121
node-version: 12
2222
- name: Generate doc
23-
run: gradle javadoc
23+
run: ./gradlew --no-daemon javadoc
2424
- name: Deploy
2525
uses: JamesIves/github-pages-deploy-action@releases/v3
2626
with:

.gitignore

Lines changed: 3 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -6,9 +6,9 @@ build/
66

77
.gradle/
88
gradle.properties
9-
gradle/
10-
gradlew
11-
gradlew.bat
9+
gradle/*
10+
!gradle/wrapper
11+
!gradle/wrapper/*.jar
1212
out/
1313
target/
1414
bin/

.travis.yml

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -14,6 +14,6 @@ before_script:
1414
- wget -O google-java-format https://github.com/google/google-java-format/releases/download/google-java-format-1.7/google-java-format-1.7-all-deps.jar
1515
- find . -name "*.java" | xargs java -jar google-java-format --set-exit-if-changed --replace
1616
script:
17-
- gradle test
17+
- ./gradlew test
1818
#after_success:
1919
#- ".travis/publish.sh"

README.md

Lines changed: 1 addition & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -43,9 +43,7 @@ Javadocs are available [here](https://getstream.github.io/stream-java/).
4343

4444
### Building & Testing
4545

46-
Run `gradle wrapper --gradle-version 5.1.1` to generate gradle wrapper files
47-
48-
Run `gradle test` to execute integration tests
46+
Run `gradlew test` to execute integration tests
4947

5048
### Copyright and License Information
5149

build.gradle

Lines changed: 11 additions & 14 deletions
Original file line numberDiff line numberDiff line change
@@ -15,23 +15,20 @@ dependencies {
1515
sourceCompatibility = 1.8
1616
targetCompatibility = 1.8
1717

18-
testCompile 'junit:junit:4.12'
19-
testCompile 'com.pholser:junit-quickcheck-core:0.8.1'
20-
testCompile 'com.pholser:junit-quickcheck-generators:0.8.1'
21-
testRuntime 'org.junit.vintage:junit-vintage-engine:5.2.0'
18+
testImplementation 'junit:junit:4.12'
19+
testImplementation 'com.pholser:junit-quickcheck-core:0.8.1'
20+
testImplementation 'com.pholser:junit-quickcheck-generators:0.8.1'
21+
testRuntimeOnly 'org.junit.vintage:junit-vintage-engine:5.2.0'
2222

2323
implementation 'com.google.guava:guava:20.0'
24-
2524
implementation 'com.squareup.okhttp3:okhttp:3.11.0'
26-
27-
compile 'net.sourceforge.streamsupport:streamsupport:1.7.0'
28-
compile 'net.sourceforge.streamsupport:streamsupport-cfuture:1.7.0'
29-
compile 'com.fasterxml.jackson.core:jackson-core:2.9.6'
30-
compile 'com.fasterxml.jackson.core:jackson-core:2.9.6'
31-
compile 'com.fasterxml.jackson.core:jackson-annotations:2.9.6'
32-
compile 'com.fasterxml.jackson.core:jackson-databind:2.9.6'
33-
34-
compile 'com.auth0:java-jwt:3.4.0'
25+
implementation 'net.sourceforge.streamsupport:streamsupport:1.7.0'
26+
implementation 'net.sourceforge.streamsupport:streamsupport-cfuture:1.7.0'
27+
implementation 'com.fasterxml.jackson.core:jackson-core:2.9.6'
28+
implementation 'com.fasterxml.jackson.core:jackson-core:2.9.6'
29+
implementation 'com.fasterxml.jackson.core:jackson-annotations:2.9.6'
30+
implementation 'com.fasterxml.jackson.core:jackson-databind:2.9.6'
31+
implementation 'com.auth0:java-jwt:3.4.0'
3532
}
3633

3734
retrolambda {

gradle/wrapper/gradle-wrapper.jar

57.3 KB
Binary file not shown.
Lines changed: 5 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,5 @@
1+
distributionBase=GRADLE_USER_HOME
2+
distributionPath=wrapper/dists
3+
distributionUrl=https\://services.gradle.org/distributions/gradle-6.2.2-all.zip
4+
zipStoreBase=GRADLE_USER_HOME
5+
zipStorePath=wrapper/dists

gradlew

Lines changed: 183 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,183 @@
1+
#!/usr/bin/env sh
2+
3+
#
4+
# Copyright 2015 the original author or authors.
5+
#
6+
# Licensed under the Apache License, Version 2.0 (the "License");
7+
# you may not use this file except in compliance with the License.
8+
# You may obtain a copy of the License at
9+
#
10+
# https://www.apache.org/licenses/LICENSE-2.0
11+
#
12+
# Unless required by applicable law or agreed to in writing, software
13+
# distributed under the License is distributed on an "AS IS" BASIS,
14+
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15+
# See the License for the specific language governing permissions and
16+
# limitations under the License.
17+
#
18+
19+
##############################################################################
20+
##
21+
## Gradle start up script for UN*X
22+
##
23+
##############################################################################
24+
25+
# Attempt to set APP_HOME
26+
# Resolve links: $0 may be a link
27+
PRG="$0"
28+
# Need this for relative symlinks.
29+
while [ -h "$PRG" ] ; do
30+
ls=`ls -ld "$PRG"`
31+
link=`expr "$ls" : '.*-> \(.*\)$'`
32+
if expr "$link" : '/.*' > /dev/null; then
33+
PRG="$link"
34+
else
35+
PRG=`dirname "$PRG"`"/$link"
36+
fi
37+
done
38+
SAVED="`pwd`"
39+
cd "`dirname \"$PRG\"`/" >/dev/null
40+
APP_HOME="`pwd -P`"
41+
cd "$SAVED" >/dev/null
42+
43+
APP_NAME="Gradle"
44+
APP_BASE_NAME=`basename "$0"`
45+
46+
# Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
47+
DEFAULT_JVM_OPTS='"-Xmx64m" "-Xms64m"'
48+
49+
# Use the maximum available, or set MAX_FD != -1 to use that value.
50+
MAX_FD="maximum"
51+
52+
warn () {
53+
echo "$*"
54+
}
55+
56+
die () {
57+
echo
58+
echo "$*"
59+
echo
60+
exit 1
61+
}
62+
63+
# OS specific support (must be 'true' or 'false').
64+
cygwin=false
65+
msys=false
66+
darwin=false
67+
nonstop=false
68+
case "`uname`" in
69+
CYGWIN* )
70+
cygwin=true
71+
;;
72+
Darwin* )
73+
darwin=true
74+
;;
75+
MINGW* )
76+
msys=true
77+
;;
78+
NONSTOP* )
79+
nonstop=true
80+
;;
81+
esac
82+
83+
CLASSPATH=$APP_HOME/gradle/wrapper/gradle-wrapper.jar
84+
85+
# Determine the Java command to use to start the JVM.
86+
if [ -n "$JAVA_HOME" ] ; then
87+
if [ -x "$JAVA_HOME/jre/sh/java" ] ; then
88+
# IBM's JDK on AIX uses strange locations for the executables
89+
JAVACMD="$JAVA_HOME/jre/sh/java"
90+
else
91+
JAVACMD="$JAVA_HOME/bin/java"
92+
fi
93+
if [ ! -x "$JAVACMD" ] ; then
94+
die "ERROR: JAVA_HOME is set to an invalid directory: $JAVA_HOME
95+
96+
Please set the JAVA_HOME variable in your environment to match the
97+
location of your Java installation."
98+
fi
99+
else
100+
JAVACMD="java"
101+
which java >/dev/null 2>&1 || die "ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
102+
103+
Please set the JAVA_HOME variable in your environment to match the
104+
location of your Java installation."
105+
fi
106+
107+
# Increase the maximum file descriptors if we can.
108+
if [ "$cygwin" = "false" -a "$darwin" = "false" -a "$nonstop" = "false" ] ; then
109+
MAX_FD_LIMIT=`ulimit -H -n`
110+
if [ $? -eq 0 ] ; then
111+
if [ "$MAX_FD" = "maximum" -o "$MAX_FD" = "max" ] ; then
112+
MAX_FD="$MAX_FD_LIMIT"
113+
fi
114+
ulimit -n $MAX_FD
115+
if [ $? -ne 0 ] ; then
116+
warn "Could not set maximum file descriptor limit: $MAX_FD"
117+
fi
118+
else
119+
warn "Could not query maximum file descriptor limit: $MAX_FD_LIMIT"
120+
fi
121+
fi
122+
123+
# For Darwin, add options to specify how the application appears in the dock
124+
if $darwin; then
125+
GRADLE_OPTS="$GRADLE_OPTS \"-Xdock:name=$APP_NAME\" \"-Xdock:icon=$APP_HOME/media/gradle.icns\""
126+
fi
127+
128+
# For Cygwin or MSYS, switch paths to Windows format before running java
129+
if [ "$cygwin" = "true" -o "$msys" = "true" ] ; then
130+
APP_HOME=`cygpath --path --mixed "$APP_HOME"`
131+
CLASSPATH=`cygpath --path --mixed "$CLASSPATH"`
132+
JAVACMD=`cygpath --unix "$JAVACMD"`
133+
134+
# We build the pattern for arguments to be converted via cygpath
135+
ROOTDIRSRAW=`find -L / -maxdepth 1 -mindepth 1 -type d 2>/dev/null`
136+
SEP=""
137+
for dir in $ROOTDIRSRAW ; do
138+
ROOTDIRS="$ROOTDIRS$SEP$dir"
139+
SEP="|"
140+
done
141+
OURCYGPATTERN="(^($ROOTDIRS))"
142+
# Add a user-defined pattern to the cygpath arguments
143+
if [ "$GRADLE_CYGPATTERN" != "" ] ; then
144+
OURCYGPATTERN="$OURCYGPATTERN|($GRADLE_CYGPATTERN)"
145+
fi
146+
# Now convert the arguments - kludge to limit ourselves to /bin/sh
147+
i=0
148+
for arg in "$@" ; do
149+
CHECK=`echo "$arg"|egrep -c "$OURCYGPATTERN" -`
150+
CHECK2=`echo "$arg"|egrep -c "^-"` ### Determine if an option
151+
152+
if [ $CHECK -ne 0 ] && [ $CHECK2 -eq 0 ] ; then ### Added a condition
153+
eval `echo args$i`=`cygpath --path --ignore --mixed "$arg"`
154+
else
155+
eval `echo args$i`="\"$arg\""
156+
fi
157+
i=`expr $i + 1`
158+
done
159+
case $i in
160+
0) set -- ;;
161+
1) set -- "$args0" ;;
162+
2) set -- "$args0" "$args1" ;;
163+
3) set -- "$args0" "$args1" "$args2" ;;
164+
4) set -- "$args0" "$args1" "$args2" "$args3" ;;
165+
5) set -- "$args0" "$args1" "$args2" "$args3" "$args4" ;;
166+
6) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" ;;
167+
7) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" ;;
168+
8) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" ;;
169+
9) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" "$args8" ;;
170+
esac
171+
fi
172+
173+
# Escape application args
174+
save () {
175+
for i do printf %s\\n "$i" | sed "s/'/'\\\\''/g;1s/^/'/;\$s/\$/' \\\\/" ; done
176+
echo " "
177+
}
178+
APP_ARGS=`save "$@"`
179+
180+
# Collect all arguments for the java command, following the shell quoting and substitution rules
181+
eval set -- $DEFAULT_JVM_OPTS $JAVA_OPTS $GRADLE_OPTS "\"-Dorg.gradle.appname=$APP_BASE_NAME\"" -classpath "\"$CLASSPATH\"" org.gradle.wrapper.GradleWrapperMain "$APP_ARGS"
182+
183+
exec "$JAVACMD" "$@"

0 commit comments

Comments
 (0)