2021-05-14 15:59:59 -04:00
|
|
|
Hibernate ORM is a library providing Object/Relational Mapping (ORM) support
|
|
|
|
to applications, libraries, and frameworks.
|
|
|
|
|
|
|
|
It also provides an implementation of the JPA specification, which is the standard Java specification for ORM.
|
|
|
|
|
2021-06-07 06:47:53 -04:00
|
|
|
This is the repository of its source code; see https://hibernate.org/orm/[Hibernate.org] for additional information.
|
2021-05-14 15:59:59 -04:00
|
|
|
|
2021-06-07 06:47:53 -04:00
|
|
|
image:https://ci.hibernate.org/job/hibernate-orm-main-h2-main/badge/icon[Build Status,link=https://ci.hibernate.org/job/hibernate-orm-main-h2-main/]
|
2021-05-14 15:59:59 -04:00
|
|
|
image:https://img.shields.io/lgtm/grade/java/g/hibernate/hibernate-orm.svg?logo=lgtm&logoWidth=18[Language grade: Java,link=https://lgtm.com/projects/g/hibernate/hibernate-orm/context:java]
|
|
|
|
|
|
|
|
== Continuous Integration
|
|
|
|
|
2021-06-07 06:47:53 -04:00
|
|
|
Hibernate uses both https://jenkins-ci.org[Jenkins] and https://github.com/features/actions[GitHub Actions]
|
2021-05-14 15:59:59 -04:00
|
|
|
for its CI needs. See
|
|
|
|
|
2021-06-07 06:47:53 -04:00
|
|
|
* https://ci.hibernate.org/view/ORM/[Jenkins Jobs]
|
2021-05-14 15:59:59 -04:00
|
|
|
* https://github.com/hibernate/hibernate-orm/actions[GitHub Actions Jobs]
|
|
|
|
|
|
|
|
== Building from sources
|
|
|
|
|
2021-11-26 11:24:34 -05:00
|
|
|
The build requires at least Java 11 JDK.
|
2021-05-14 15:59:59 -04:00
|
|
|
|
|
|
|
Hibernate uses https://gradle.org[Gradle] as its build tool. See the _Gradle Primer_ section below if you are new to
|
|
|
|
Gradle.
|
|
|
|
|
|
|
|
Contributors should read the link:CONTRIBUTING.md[Contributing Guide].
|
|
|
|
|
2021-06-07 06:47:53 -04:00
|
|
|
See the guides for setting up https://hibernate.org/community/contribute/intellij-idea/[IntelliJ] or
|
2021-05-14 15:59:59 -04:00
|
|
|
https://hibernate.org/community/contribute/eclipse-ide/[Eclipse] as your development environment.
|
|
|
|
|
|
|
|
== Gradle Primer
|
|
|
|
|
|
|
|
The Gradle build tool has amazing documentation. 2 in particular that are indispensable:
|
|
|
|
|
|
|
|
* https://docs.gradle.org/current/userguide/userguide_single.html[Gradle User Guide] is a typical user guide in that
|
|
|
|
it follows a topical approach to describing all of the capabilities of Gradle.
|
|
|
|
* https://docs.gradle.org/current/dsl/index.html[Gradle DSL Guide] is unique and excellent in quickly
|
|
|
|
getting up to speed on certain aspects of Gradle.
|
|
|
|
|
|
|
|
We will cover the basics developers and contributors new to Gradle need to know to get productive quickly.
|
|
|
|
|
|
|
|
NOTE: The project defines a https://docs.gradle.org/current/userguide/gradle_wrapper.html[Gradle Wrapper].
|
|
|
|
The rest of the section will assume execution through the wrapper.
|
|
|
|
|
|
|
|
=== Executing Tasks
|
|
|
|
|
|
|
|
Gradle uses the concept of build tasks (equivalent to Ant targets or Maven phases/goals). You can get a list of
|
|
|
|
available tasks via
|
|
|
|
|
|
|
|
----
|
|
|
|
gradle tasks
|
|
|
|
----
|
|
|
|
|
|
|
|
To execute a task across all modules, simply perform that task from the root directory. Gradle will visit each
|
|
|
|
sub-project and execute that task if the sub-project defines it. To execute a task in a specific module you can
|
|
|
|
either:
|
|
|
|
|
|
|
|
. `cd` into that module directory and execute the task
|
|
|
|
. name the "task path". For example, to run the tests for the _hibernate-core_ module from the root directory
|
|
|
|
you could say `gradle hibernate-core:test`
|
|
|
|
|
|
|
|
=== Common tasks
|
|
|
|
|
|
|
|
The common tasks you might use in building Hibernate include:
|
|
|
|
|
|
|
|
* _build_ - Assembles (jars) and tests this project
|
|
|
|
* _compile_ - Performs all compilation tasks including staging resources from both main and test
|
|
|
|
* _jar_ - Generates a jar archive with all the compiled classes
|
|
|
|
* _test_ - Runs the tests
|
|
|
|
* _publishToMavenLocal_ - Installs the project jar to your local maven cache (aka ~/.m2/repository). Note that Gradle
|
|
|
|
never uses this, but it can be useful for testing your build with other local Maven-based builds.
|
|
|
|
* _clean_ - Cleans the build directory
|
|
|
|
|
|
|
|
== Testing and databases
|
|
|
|
|
|
|
|
Testing against a specific database can be achieved in 2 different ways:
|
|
|
|
|
|
|
|
=== Using the "Matrix Testing Plugin" for Gradle.
|
|
|
|
|
|
|
|
Coming later…
|
|
|
|
|
|
|
|
=== Using "profiles"
|
|
|
|
|
|
|
|
The Hibernate build defines several database testing "profiles" in `databases.gradle`. These
|
|
|
|
profiles can be activated by name using the `db` build property which can be passed either as
|
|
|
|
a JVM system prop (`-D`) or as a Gradle project property (`-P`). Examples below use the Gradle
|
|
|
|
project property approach.
|
|
|
|
|
|
|
|
----
|
|
|
|
gradle clean build -Pdb=pgsql
|
|
|
|
----
|
|
|
|
|
|
|
|
To run a test from your IDE, you need to ensure the property expansions happen.
|
|
|
|
Use the following command:
|
|
|
|
|
|
|
|
----
|
|
|
|
gradle clean compile -Pdb=pgsql
|
|
|
|
----
|
|
|
|
|
|
|
|
__NOTE: If you are running tests against a JDBC driver that is not available via Maven central be sure to
|
|
|
|
add these drivers to your local Maven repo cache (~/.m2/repository) or (better) add it to a personal Maven repo server__
|
|
|
|
|
|
|
|
=== Running database-specific tests from the IDE using "profiles"
|
|
|
|
|
|
|
|
You can run any test on any particular database that is configured in a `databases.gradle` profile.
|
|
|
|
|
|
|
|
All you have to do is run the following command:
|
|
|
|
|
|
|
|
----
|
|
|
|
gradlew setDataBase -Pdb=pgsql
|
|
|
|
----
|
|
|
|
|
|
|
|
or you can use the shortcut version:
|
|
|
|
|
|
|
|
----
|
|
|
|
gradlew sDB -Pdb=pgsql
|
|
|
|
----
|
|
|
|
|
|
|
|
You can do this from the module which you are interested in testing or from the `hibernate-orm` root folder.
|
|
|
|
|
|
|
|
Afterward, just pick any test from the IDE and run it as usual. Hibernate will pick the database configuration from the `hibernate.properties`
|
|
|
|
file that was set up by the `setDataBase` Gradle task.
|
|
|
|
|
|
|
|
=== Starting test databases locally as docker containers
|
|
|
|
|
|
|
|
You don't have to install all databases locally to be able to test against them in case you have docker available.
|
|
|
|
The script `docker_db.sh` allows you to start a pre-configured database which can be used for testing.
|
|
|
|
|
|
|
|
All you have to do is run the following command:
|
|
|
|
|
|
|
|
----
|
|
|
|
./docker_db.sh postgresql_9_5
|
|
|
|
----
|
|
|
|
|
|
|
|
omitting the argument will print a list of possible options.
|
|
|
|
|
|
|
|
When the database is properly started, you can run tests with special profiles that are suffixed with `_ci`
|
|
|
|
e.g. `pgsql_ci` for PostgreSQL. By using the system property `dbHost` you can configure the IP address of your docker host.
|
|
|
|
|
|
|
|
The command for running tests could look like the following:
|
|
|
|
|
|
|
|
----
|
|
|
|
gradlew test -Pdb=pgsql_ci "-DdbHost=192.168.99.100"
|
2022-01-04 06:32:17 -05:00
|
|
|
----
|
|
|
|
|
|
|
|
The following table illustrates a list of commands for various databases that can be tested locally.
|
|
|
|
|
|
|
|
|===
|
|
|
|
|Database |`docker_db.sh` |Gradle command
|
|
|
|
|
|
|
|
|H2
|
|
|
|
|-
|
|
|
|
|`gradlew test -Pdb=h2`
|
|
|
|
|
|
|
|
|HSQLDB
|
|
|
|
|-
|
|
|
|
|`gradlew test -Pdb=hsqldb`
|
|
|
|
|
|
|
|
|Apache Derby
|
|
|
|
|-
|
|
|
|
|`gradlew test -Pdb=derby`
|
|
|
|
|
|
|
|
|MySQL 5.7
|
|
|
|
|`./docker_db.sh mysql_5_7`
|
|
|
|
|`gradlew test -Pdb=mysql_ci`
|
|
|
|
|
|
|
|
|MySQL 8.0
|
|
|
|
|`./docker_db.sh mysql_8_0`
|
|
|
|
|`gradlew test -Pdb=mysql_ci`
|
|
|
|
|
|
|
|
|MariaDB
|
|
|
|
|`./docker_db.sh mariadb`
|
|
|
|
|`gradlew test -Pdb=mariadb_ci`
|
|
|
|
|
|
|
|
|PostgreSQL 9.5
|
|
|
|
|`./docker_db.sh postgresql_9_5`
|
|
|
|
|`gradlew test -Pdb=pgsql_ci`
|
|
|
|
|
|
|
|
|PostgreSQL 13
|
|
|
|
|`./docker_db.sh postgresql_13`
|
|
|
|
|`gradlew test -Pdb=pgsql_ci`
|
|
|
|
|
|
|
|
|EnterpriseDB
|
|
|
|
|`./docker_db.sh edb`
|
|
|
|
|`gradlew test -Pdb=edb_ci`
|
|
|
|
|
|
|
|
|Oracle XE
|
|
|
|
|`./docker_db.sh oracle`
|
|
|
|
|`gradlew test -Pdb=oracle_ci`
|
|
|
|
|
|
|
|
|Oracle EE
|
|
|
|
|`./docker_db.sh oracle_ee`
|
|
|
|
|`gradlew test -Pdb=oracle_docker`
|
|
|
|
|
|
|
|
|DB2
|
|
|
|
|`./docker_db.sh db2`
|
|
|
|
|`gradlew test -Pdb=db2_ci`
|
|
|
|
|
|
|
|
|SQL Server
|
|
|
|
|`./docker_db.sh mssql`
|
|
|
|
|`gradlew test -Pdb=mssql_ci`
|
|
|
|
|
|
|
|
|Sybase ASE
|
|
|
|
|`./docker_db.sh sybase`
|
|
|
|
|`gradlew test -Pdb=sybase_ci`
|
|
|
|
|
|
|
|
|SAP HANA
|
|
|
|
|`./docker_db.sh hana`
|
|
|
|
|`gradlew test -Pdb=hana_ci`
|
|
|
|
|
|
|
|
|CockroachDB
|
|
|
|
|`./docker_db.sh cockroachdb`
|
|
|
|
|`gradlew test -Pdb=cockroachdb`
|
|
|
|
|===
|