7c8c13a4f0 | ||
---|---|---|
.github/ISSUE_TEMPLATE | ||
akka-modules | ||
algorithms-modules | ||
apache-cxf-modules | ||
apache-httpclient | ||
apache-httpclient-2 | ||
apache-httpclient4 | ||
apache-kafka | ||
apache-kafka-2 | ||
apache-libraries | ||
apache-libraries-2 | ||
apache-olingo | ||
apache-poi | ||
apache-poi-2 | ||
apache-poi-3 | ||
apache-spark | ||
apache-thrift | ||
apache-velocity | ||
atomix | ||
aws-modules | ||
azure | ||
bazel | ||
checker-framework | ||
clojure-modules/clojure-ring | ||
core-groovy-modules | ||
core-java-modules | ||
custom-pmd | ||
data-structures | ||
deeplearning4j | ||
di-modules | ||
disruptor | ||
docker-modules | ||
dozer | ||
drools | ||
dubbo | ||
ethereum | ||
feign | ||
gcp-firebase | ||
geotools | ||
google-auto-project | ||
google-cloud | ||
gradle-modules | ||
graphql-modules | ||
grpc | ||
guava-modules | ||
hazelcast | ||
httpclient-simple | ||
hystrix | ||
image-compressing | ||
image-processing | ||
intelliJ-modules | ||
jackson-modules | ||
jackson-simple | ||
java-blockchain | ||
java-jdi | ||
java-nashorn | ||
java-numbers-2/src | ||
java-panama | ||
javafx | ||
javax-sound | ||
javaxval | ||
javaxval-2 | ||
jaxb | ||
jbang | ||
jenkins-modules | ||
jeromq | ||
jetbrains | ||
jgit | ||
jhipster-6 | ||
jhipster-modules | ||
jmh | ||
json-modules | ||
jsoup | ||
jws | ||
ksqldb | ||
kubernetes-modules | ||
language-interop | ||
libraries | ||
libraries-2 | ||
libraries-3 | ||
libraries-4 | ||
libraries-ai | ||
libraries-apache-commons | ||
libraries-apache-commons-2 | ||
libraries-apache-commons-collections | ||
libraries-apache-commons-io | ||
libraries-bytecode | ||
libraries-cli | ||
libraries-concurrency | ||
libraries-data | ||
libraries-data-2 | ||
libraries-data-3 | ||
libraries-data-db | ||
libraries-data-io | ||
libraries-data-io-2 | ||
libraries-files | ||
libraries-http | ||
libraries-http-2 | ||
libraries-io | ||
libraries-jdk8 | ||
libraries-llms | ||
libraries-primitive | ||
libraries-reporting | ||
libraries-rpc | ||
libraries-security | ||
libraries-server | ||
libraries-server-2 | ||
libraries-stream | ||
libraries-testing | ||
libraries-testing-2 | ||
libraries-transform | ||
lightrun | ||
linux-bash-modules | ||
logging-modules | ||
lombok-modules | ||
lucene | ||
mapstruct | ||
maven-modules | ||
mesos-marathon | ||
messaging-modules | ||
metrics | ||
microservices-modules | ||
muleesb | ||
mustache | ||
mybatis | ||
netflix-modules | ||
nginx-forward-proxy | ||
optaplanner | ||
orika | ||
osgi | ||
pants | ||
parent-boot-1 | ||
parent-boot-2 | ||
parent-boot-3 | ||
parent-spring-4 | ||
parent-spring-5 | ||
parent-spring-6 | ||
patterns-modules | ||
performance-tests | ||
persistence-modules | ||
pmd | ||
podman | ||
protobuffer | ||
quarkus-modules | ||
reactive-systems | ||
reactor-core | ||
rsocket | ||
rule-engines-modules | ||
rxjava-modules | ||
saas-modules | ||
security-modules | ||
server-modules | ||
spf4j | ||
spring-4 | ||
spring-5 | ||
spring-5-webflux | ||
spring-5-webflux-2 | ||
spring-6 | ||
spring-6-rsocket | ||
spring-activiti | ||
spring-actuator | ||
spring-ai | ||
spring-aop | ||
spring-aop-2 | ||
spring-batch | ||
spring-batch-2 | ||
spring-boot-modules | ||
spring-boot-rest | ||
spring-cloud-modules | ||
spring-core | ||
spring-core-2 | ||
spring-core-3 | ||
spring-core-4 | ||
spring-credhub | ||
spring-cucumber | ||
spring-di | ||
spring-di-2 | ||
spring-di-3 | ||
spring-di-4 | ||
spring-drools | ||
spring-ejb-modules | ||
spring-exceptions | ||
spring-integration | ||
spring-jenkins-pipeline | ||
spring-jersey | ||
spring-jinq | ||
spring-kafka | ||
spring-kafka-2 | ||
spring-kafka-3 | ||
spring-katharsis | ||
spring-mobile | ||
spring-native | ||
spring-protobuf | ||
spring-pulsar | ||
spring-quartz | ||
spring-reactive-modules | ||
spring-remoting-modules | ||
spring-roo | ||
spring-scheduling | ||
spring-security-modules | ||
spring-shell | ||
spring-soap | ||
spring-spel | ||
spring-state-machine | ||
spring-static-resources | ||
spring-swagger-codegen | ||
spring-threads | ||
spring-vault | ||
spring-web-modules | ||
spring-websockets | ||
static-analysis | ||
tablesaw | ||
tensorflow-java | ||
terraform-modules | ||
testing-modules | ||
text-processing-libraries-modules | ||
timefold-solver | ||
vaadin | ||
vavr-modules | ||
vertx-modules | ||
video-tutorials | ||
web-modules | ||
webrtc | ||
xml | ||
xml-2 | ||
xstream | ||
.gitignore | ||
CONTRIBUTING.md | ||
LICENSE | ||
README.md | ||
baeldung-pmd-rules.xml | ||
custom-pmd-0.0.1.jar | ||
logback-config.xml | ||
pom.xml |
README.md
Cloning the repository
If you are getting an error while cloning the repository, try running: git config --global http.postBuffer 5000000
This will increase the size of the buffer from the default 1MiB to 5MiB.
To revert this value to the default, use: git config --global http.postBuffer 1000000
The Courses
Here's the new "Learn Spring" course:
>> LEARN SPRING - THE MASTER CLASS
Here's the Master Class of "REST With Spring" (along with the new announced Boot 2 material):
>> THE REST WITH SPRING - MASTER CLASS
And here's the Master Class of "Learn Spring Security":
>> LEARN SPRING SECURITY - MASTER CLASS
Java and Spring Tutorials
This project is a collection of small and focused tutorials - each covering a single and well defined area of development in the Java ecosystem. A strong focus of these is, of course, the Spring Framework - Spring, Spring Boot and Spring Security. In addition to Spring, the modules here cover a number of aspects of Java.
Profile based segregation
We are using maven build profiles to segregate the huge list of individual projects we have in our repository.
As for now, vast majority of the modules require JDK8 to build and run correctly.
The projects are broadly divided into 3 lists: first, second and heavy.
Next, they are segregated further on the basis of the tests that we want to execute.
Additionally, there are 2 profiles dedicated for JDK9 and above builds - which require JDK 17.
We also have a parents profile to build only parent modules.
Therefore, we have a total of 9 profiles:
Profile | Includes | Type of test enabled |
---|---|---|
default-first | First set of projects | *UnitTest |
integration-lite-first | First set of projects | *IntegrationTest |
default-second | Second set of projects | *UnitTest |
integration-lite-second | Second set of projects | *IntegrationTest |
default-heavy | Heavy/long running projects | *UnitTest |
integration-heavy | Heavy/long running projects | *IntegrationTest |
default-jdk9-and-above | JDK9 and above projects | *UnitTest |
integration-jdk9-and-above | JDK9 and above projects | *IntegrationTest |
parents | Set of parent modules | None |
Building the project
Though it should not be needed often to build the entire repository at once because we are usually concerned with a specific module.
But if we want to, we can invoke the below command from the root of the repository if we want to build the entire repository with only Unit Tests enabled:
mvn clean install -Pdefault-first,default-second,default-heavy
or if we want to build the entire repository with Integration Tests enabled, we can do:
mvn clean install -Pintegration-lite-first,integration-lite-second,integration-heavy
Analogously, for the JDK9 and above projects the commands are:
mvn clean install -Pdefault-jdk9-and-above
and
mvn clean install -Pintegration-jdk9-and-above
Building a single module
To build a specific module, run the command: mvn clean install
in the module directory.
It can happen that your module is part of a parent module e.g. parent-boot-1
,parent-spring-5
etc, then you will need to build the parent module first so that you can build your module.
We have created a parents
profile that you can use to build just the parent modules, just run the profile as:
mvn clean install -Pparents
Building modules from the root of the repository
To build specific modules from the root of the repository, run the command: mvn clean install --pl asm,atomikos -Pdefault-first
in the root directory.
Here asm
and atomikos
are the modules that we want to build and default-first
is the maven profile in which these modules are present.
Running a Spring Boot module
To run a Spring Boot module, run the command: mvn spring-boot:run
in the module directory.
Working with the IDE
This repo contains a large number of modules. When you're working with an individual module, there's no need to import all of them (or build all of them) - you can simply import that particular module in either Eclipse or IntelliJ.
Running Tests
The command mvn clean install
from within a module will run the unit tests in that module.
For Spring modules this will also run the SpringContextTest
if present.
To run the integration tests, use the command:
mvn clean install -Pintegration-lite-first
or
mvn clean install -Pintegration-lite-second
or
mvn clean install -Pintegration-heavy
or
mvn clean install -Pintegration-jdk9-and-above
depending on the list where our module exists