Skip to content

Commit c0b9083

Browse files
Merge pull request #136 from igorcampos-dev/feature/spring-wolf
feat(springwolf-example): initialize Spring Wolf example project with…
2 parents 9e8ec2e + 85dfa9a commit c0b9083

File tree

23 files changed

+1181
-1
lines changed

23 files changed

+1181
-1
lines changed

.github/labeler.yml

Lines changed: 4 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -26,6 +26,10 @@
2626
- changed-files:
2727
- any-glob-to-any-file: 'spring-batch-file-examples/**/*'
2828

29+
"project: springwolf-example":
30+
- changed-files:
31+
- any-glob-to-any-file: 'spring-wolf-example/**/*'
32+
2933
"type: dependency-upgrade":
3034
- changed-files:
3135
- any-glob-to-any-file: "**/pom.xml"
Lines changed: 68 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,68 @@
1+
name: springwolf-example CI Build
2+
3+
on:
4+
pull_request:
5+
branches: [master]
6+
paths:
7+
- "springwolf-example/**"
8+
types:
9+
- opened
10+
- synchronize
11+
- reopened
12+
13+
jobs:
14+
15+
integration-tests:
16+
name: Run Unit & Integration Tests
17+
runs-on: ubuntu-latest
18+
defaults:
19+
run:
20+
working-directory: springwolf-example
21+
strategy:
22+
matrix:
23+
distribution: [ 'temurin' ]
24+
java: [ '21' ]
25+
steps:
26+
- uses: actions/checkout@v6
27+
with:
28+
fetch-depth: 0
29+
30+
- name: Set up JDK ${{ matrix.java }}
31+
uses: actions/[email protected]
32+
with:
33+
java-version: ${{ matrix.java }}
34+
distribution: ${{ matrix.distribution }}
35+
cache: 'maven'
36+
- name: Build and analyze
37+
run: ./mvnw clean verify
38+
39+
health-check:
40+
name: Health Check on Services
41+
runs-on: ubuntu-latest
42+
steps:
43+
- name: Checkout repository and submodules
44+
uses: actions/checkout@v6
45+
with:
46+
submodules: true
47+
48+
- name: Extract service names from docker compose
49+
id: services
50+
run: |
51+
echo "services<<EOF" >> $GITHUB_OUTPUT
52+
docker compose -f ./springwolf-example/compose.yaml config --services >> $GITHUB_OUTPUT
53+
echo "EOF" >> $GITHUB_OUTPUT
54+
55+
- name: Start containers with Compose Action
56+
uses: hoverkraft-tech/[email protected]
57+
with:
58+
compose-file: './springwolf-example/compose.yaml'
59+
services: ${{ steps.services.outputs.services }}
60+
up-flags: '--build'
61+
down-flags: '--volumes'
62+
63+
- name: Wait for containers to initialize
64+
run: sleep 10
65+
66+
- name: Check container health
67+
run: |
68+
./.github/scripts/check-container-health.sh "${{ steps.services.outputs.services }}"

README.md

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -26,7 +26,7 @@ Below you will find a summary table of each subproject. For more details, please
2626
| [Spring Boot + Postgres](./spring-postgres-example) | Demonstrates a basic integration between Spring Boot and Postgres. |
2727
| [Spring Boot + Mysql](./spring-mysql-example) | Demonstrates a basic integration between Spring Boot and Mysql. |
2828
| [Spring Boot + Grafana + Prometheus](./spring-prometheus-grafana-example) | Demonstrates a basic integration between Spring Boot With Grafana and Prometheus. |
29-
29+
| [Spring Boot + Spring Wolf](./spring-wolf-example) | Demonstrates a basic integration between Spring Boot and Spring Wolf. |
3030
---
3131

3232
## Tech Stack

pom.xml

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -22,6 +22,7 @@
2222
<module>spring-oracle-example</module>
2323
<module>spring-batch-file-examples</module>
2424
<module>spring-batch-db-examples</module>
25+
<module>spring-wolf-example</module>
2526
</modules>
2627

2728
</project>

spring-wolf-example/.dockerignore

Lines changed: 62 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,62 @@
1+
# Include any files or directories that you don't want to be copied to your
2+
# container here (e.g., local build artifacts, temporary files, etc.).
3+
#
4+
# For more help, visit the .dockerignore file reference guide at
5+
# https://docs.docker.com/go/build-context-dockerignore/
6+
7+
**/.DS_Store
8+
**/.classpath
9+
**/.dockerignore
10+
**/.env
11+
**/.factorypath
12+
**/.git
13+
**/.gitignore
14+
**/.idea
15+
**/.project
16+
**/.sts4-cache
17+
**/.settings
18+
**/.toolstarget
19+
**/.vs
20+
**/.vscode
21+
**/.next
22+
**/.cache
23+
**/*.dbmdl
24+
**/*.jfm
25+
**/charts
26+
**/docker-compose*
27+
**/compose.y*ml
28+
**/Dockerfile*
29+
**/secrets.dev.yaml
30+
**/values.dev.yaml
31+
**/vendor
32+
LICENSE
33+
README.md
34+
**/*.class
35+
**/*.iml
36+
**/*.ipr
37+
**/*.iws
38+
**/*.log
39+
**/.apt_generated
40+
**/.gradle
41+
**/.gradletasknamecache
42+
**/.nb-gradle
43+
**/.springBeans
44+
**/build
45+
**/dist
46+
**/gradle-app.setting
47+
**/nbbuild
48+
**/nbdist
49+
**/nbproject/private
50+
**/target
51+
*.ctxt
52+
.mtj.tmp
53+
.mvn/timing.properties
54+
buildNumber.properties
55+
dependency-reduced-pom.xml
56+
hs_err_pid*
57+
pom.xml.next
58+
pom.xml.releaseBackup
59+
pom.xml.tag
60+
pom.xml.versionsBackup
61+
release.properties
62+
replay_pid*

spring-wolf-example/.gitattributes

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,2 @@
1+
/mvnw text eol=lf
2+
*.cmd text eol=crlf
Lines changed: 30 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,30 @@
1+
name: CI Build
2+
3+
on:
4+
push:
5+
branches:
6+
- "**"
7+
8+
jobs:
9+
build:
10+
name: Build
11+
runs-on: ubuntu-latest
12+
strategy:
13+
matrix:
14+
distribution: [ 'temurin' ]
15+
java: [ '21' ]
16+
steps:
17+
- uses: actions/checkout@v6
18+
19+
- name: Setup Java 21
20+
uses: actions/setup-java@v5
21+
with:
22+
java-version: ${{ matrix.java }}
23+
distribution: ${{ matrix.distribution }}
24+
cache: 'maven'
25+
26+
- name: Grant execute permission for mvnw
27+
run: chmod +x mvnw
28+
29+
- name: Build with Maven
30+
run: ./mvnw clean verify

spring-wolf-example/.gitignore

Lines changed: 33 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,33 @@
1+
HELP.md
2+
target/
3+
.mvn/wrapper/maven-wrapper.jar
4+
!**/src/main/**/target/
5+
!**/src/test/**/target/
6+
7+
### STS ###
8+
.apt_generated
9+
.classpath
10+
.factorypath
11+
.project
12+
.settings
13+
.springBeans
14+
.sts4-cache
15+
16+
### IntelliJ IDEA ###
17+
.idea
18+
*.iws
19+
*.iml
20+
*.ipr
21+
22+
### NetBeans ###
23+
/nbproject/private/
24+
/nbbuild/
25+
/dist/
26+
/nbdist/
27+
/.nb-gradle/
28+
build/
29+
!**/src/main/**/build/
30+
!**/src/test/**/build/
31+
32+
### VS Code ###
33+
.vscode/
Lines changed: 3 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,3 @@
1+
wrapperVersion=3.3.4
2+
distributionType=only-script
3+
distributionUrl=https://repo.maven.apache.org/maven2/org/apache/maven/apache-maven/3.9.11/apache-maven-3.9.11-bin.zip

spring-wolf-example/Dockerfile

Lines changed: 47 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,47 @@
1+
FROM eclipse-temurin:21-jdk-jammy as deps
2+
3+
WORKDIR /build
4+
5+
COPY --chmod=0755 mvnw mvnw
6+
COPY .mvn/ .mvn/
7+
8+
RUN --mount=type=bind,source=pom.xml,target=pom.xml \
9+
--mount=type=cache,target=/root/.m2 ./mvnw dependency:go-offline -DskipTests
10+
11+
FROM deps as package
12+
13+
WORKDIR /build
14+
15+
COPY ./src src/
16+
RUN --mount=type=bind,source=pom.xml,target=pom.xml \
17+
--mount=type=cache,target=/root/.m2 \
18+
./mvnw package -DskipTests && \
19+
mv target/$(./mvnw help:evaluate -Dexpression=project.artifactId -q -DforceStdout)-$(./mvnw help:evaluate -Dexpression=project.version -q -DforceStdout).jar target/app.jar
20+
21+
FROM package as extract
22+
23+
WORKDIR /build
24+
25+
RUN java -Djarmode=layertools -jar target/app.jar extract --destination target/extracted
26+
27+
FROM eclipse-temurin:21-jre-jammy AS final
28+
29+
ARG UID=10001
30+
RUN adduser \
31+
--disabled-password \
32+
--gecos "" \
33+
--home "/nonexistent" \
34+
--shell "/sbin/nologin" \
35+
--no-create-home \
36+
--uid "${UID}" \
37+
appuser
38+
USER appuser
39+
40+
COPY --from=extract build/target/extracted/dependencies/ ./
41+
COPY --from=extract build/target/extracted/spring-boot-loader/ ./
42+
COPY --from=extract build/target/extracted/snapshot-dependencies/ ./
43+
COPY --from=extract build/target/extracted/application/ ./
44+
45+
EXPOSE 7075
46+
47+
ENTRYPOINT [ "java", "org.springframework.boot.loader.launch.JarLauncher" ]

0 commit comments

Comments
 (0)