Skip to content

Commit e5f468d

Browse files
Merge pull request #111 from igorcampos-dev/feature/spring-batch-examples
Feature/spring batch examples
2 parents 042eaa5 + a3b55e4 commit e5f468d

File tree

82 files changed

+3633
-1
lines changed

Some content is hidden

Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.

82 files changed

+3633
-1
lines changed
Lines changed: 68 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,68 @@
1+
name: spring-batch-db-examples CI Build
2+
3+
on:
4+
pull_request:
5+
branches: [master]
6+
paths:
7+
- "spring-batch-db-examples/**"
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: spring-batch-db-examples
21+
strategy:
22+
matrix:
23+
distribution: [ 'temurin' ]
24+
java: [ '21' ]
25+
steps:
26+
- uses: actions/checkout@v5
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@v5
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 ./spring-batch-db-examples/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: './spring-batch-db-examples/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 }}"
Lines changed: 68 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,68 @@
1+
name: spring-batch-file-examples CI Build
2+
3+
on:
4+
pull_request:
5+
branches: [master]
6+
paths:
7+
- "spring-batch-file-examples/**"
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: spring-batch-file-examples
21+
strategy:
22+
matrix:
23+
distribution: [ 'temurin' ]
24+
java: [ '21' ]
25+
steps:
26+
- uses: actions/checkout@v5
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@v5
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 ./spring-batch-file-examples/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: './spring-batch-file-examples/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: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -16,6 +16,8 @@ Below you will find a summary table of each subproject. For more details, please
1616

1717
| Name | Description |
1818
|---------------------------------------------------------------------------|-----------------------------------------------------------------------------------|
19+
| [Spring Boot + Spring Batch + Database](./spring-batch-db-examples) | Demonstrates a basic integration between Spring Batch and Databases |
20+
| [Spring Boot + Spring Batch + File](./spring-batch-file-examples) | Demonstrates a basic integration between Spring Batch and Files |
1921
| [Spring Boot + Jasper](./spring-jasper-example) | Demonstrates a basic integration between Spring Boot and Jasper. |
2022
| [Spring Boot Multi Module](./spring-multimodule-example) | Basic demonstration of multi-module configuration in Spring Boot |
2123
| [Spring Boot + Kafka](./spring-kafka-example) | Demonstrates a basic integration between Spring Boot and Apache Kafka. |

pom.xml

Lines changed: 3 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -20,6 +20,8 @@
2020
<module>spring-mysql-example</module>
2121
<module>spring-postgres-example</module>
2222
<module>spring-oracle-example</module>
23+
<module>spring-batch-file-examples</module>
24+
<module>spring-batch-db-examples</module>
2325
</modules>
2426

25-
</project>
27+
</project>
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*
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@v5
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
Lines changed: 32 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,32 @@
1+
target/
2+
.mvn/wrapper/maven-wrapper.jar
3+
!**/src/main/**/target/
4+
!**/src/test/**/target/
5+
6+
### STS ###
7+
.apt_generated
8+
.classpath
9+
.factorypath
10+
.project
11+
.settings
12+
.springBeans
13+
.sts4-cache
14+
15+
### IntelliJ IDEA ###
16+
.idea
17+
*.iws
18+
*.iml
19+
*.ipr
20+
21+
### NetBeans ###
22+
/nbproject/private/
23+
/nbbuild/
24+
/dist/
25+
/nbdist/
26+
/.nb-gradle/
27+
build/
28+
!**/src/main/**/build/
29+
!**/src/test/**/build/
30+
31+
### VS Code ###
32+
.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
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 8082
46+
47+
ENTRYPOINT [ "java", "org.springframework.boot.loader.launch.JarLauncher" ]

0 commit comments

Comments
 (0)