Using IntelliJ
This section describes how to install and setup JetBrains' IntelliJ IDEA, then how to import an application into IntelliJ and run it.
Installing and Importing
This section covers installation and setup. These notes/screenshots were prepared using IntelliJ IDEA Community Edition 2023.1.2, but is believed to be compatible with more recent versions/other editions of the IDE.
Download and Install
Download latest version of IntelliJ Community Edition, and install.
Import Project
In IntelliJ a project can contain multiple modules; these need not be physically located together.
Download either the HelloWorld or SimpleApp starter app to your filesystem.
From the welcome screen, select "open project":
data:image/s3,"s3://crabby-images/b47bc/b47bcd97e4fc54b55d8803e0d0506f1775425014" alt="010 welcome"
Navigate to the top-level pom.xml of the starter app:
data:image/s3,"s3://crabby-images/e8cbe/e8cbe00a2cf97ca54c44ac44fbd067d08404e5dc" alt="020 import pom"
Acknowledge that the containing directory can be trusted:
data:image/s3,"s3://crabby-images/bfd87/bfd8724b4e78b7994df91877619de6c31bc398c4" alt="025 trust directory"
Project opened:
data:image/s3,"s3://crabby-images/75f49/75f49d1822b8214125e807ea47854614ed9e592d" alt="030 imported"
Use
to confirm that JDK 11 is configured:data:image/s3,"s3://crabby-images/5ce28/5ce2863751b528ac43e04eaa7477e4750c5f2c4c" alt="040 project structure"
Configuring
Compiler Settings
There are a number of compiler settings that influence the compiler. We highly recommend you set these.
On the Compiler Settings page, ensure that build automatically
is enabled, and optionally compile independent modules in parallel
.
You might also want to increase the heap size, eg to 2048.
data:image/s3,"s3://crabby-images/088ec/088ecef4d81785cc421f7cd8cced29534726d6a3" alt="010 build automatically"
On the Annotation Processors page, confirm that these are enabled for all modules with the … sources directory
correctly defined.
(In most recent editions of IntelliJ, this is detected automatically; no changes are required).
data:image/s3,"s3://crabby-images/72c2c/72c2c2106a6e60521bf15925772a4882c2bb527d" alt="020 annotation processor"
If using JDO/DataNucleus, this setting enables the generation of the It is also required for frameworks such as Lombok. |
Plugins
You might want to set up some additional plugins.
You can do this using File > Settings > Plugins
(or equivalently File > Other Settings > Configure Plugins
).
Highly recommended are:
-
Lombok plugin (bundled with the IDE, and pre-enabled)
If you plan to use Project Lombok to reduce boilerplate.
-
Maven Helper plugin
-
AsciiDoctor plugin
Extremely useful if you are doing any authoring of documents (plugin’s git repo is here)
-
diagrams.net plugin * Allows diagrams to be authored within the IDE; works well with the AsciiDoctor plugin.
Running
Let’s see how to run both the app and the tests.
We run the application by creating a Run configuration, using Run > Edit Configurations
.
There is one complication, which is the ORM. If the app uses JPA, then dynamic class weaving should be configured. If the app uses JDO, then Datanucleus enhancer should be configured.
Running the App (JPA)
The screenshot below shows a run configuration for JPA:
data:image/s3,"s3://crabby-images/e0728/e0728047afa634d872c2bffebb80e4be94837b45" alt="012 run configuration jpa"
With JPA, the classes need to be "weaved" in order to support lazy loading and (more performant) dirty object tracking.
This is typically done dynamically at runtime, using a Java agent.
The SimpleApp and HelloWorld starter apps demonstrate this, bundling the spring-instrument.jar
file.
To run, use:
-javaagent:lib/spring-instrument.jar
as a JVM argument (where the system properties also are located.)
Running the App (JDO)
DataNucleus requires that all entities are bytecode enhanced.
When building from the command line using Maven, the datanucleus:enhance
Maven plugin takes care of this.
We can just have IntelliJ run the enhance as a separate run configuration before the run configuration that runs the app itself.
First, set up the run configuration to do the enhance:
data:image/s3,"s3://crabby-images/eb7ed/eb7ed406539440cf19244c04821a99f91132d276" alt="005 datanucleus enhance run configuration"
Check "work offline" (in Maven Options) to speed this up slightly. |
If on Windows you encounter "The command line is too long", then set '-Dfork=false' as a VM option, in Java options: ![]() |
Then, set up the run configuration for the app:
data:image/s3,"s3://crabby-images/e8a45/e8a452dfb1a812e37a6d35ff2e97e7f54c98e2fe" alt="010 run configuration"
Note how it runs the "enhance" configuration first, specified using "Modify options".
Because we are using Maven to enhance the app, build the app at least once from the Maven command line:
mvn install -DskipTests -T1C
You should now be able to run the app using Run > Run Configuration
.
The same configuration can also be used to debug the app if you so need.
Running the Unit Tests
The easiest way to run the unit tests is just to right click on the relevant package in the Project Window, and choose run unit tests. Hopefully your tests will pass (!).
data:image/s3,"s3://crabby-images/b4500/b45004e8c2455c9ec262ebf047234d2845352ca0" alt="030 running unit tests"
As a side-effect, this will create a run configuration, very similar to the one we manually created for the main app.
Running the Integration Tests
Integration tests can be run in the same way as unit tests.
One approach is to initially run the tests use the right click on the integtests
module:
data:image/s3,"s3://crabby-images/ee956/ee9561c0aa0d1e7b8dfcc46ea04e7606a6d5e408" alt="045 running integ tests"
There are also tests in the webapp-tests
module:
data:image/s3,"s3://crabby-images/f2d08/f2d088800a562957ec7e1f10fd5752a2fa8d4e14" alt="046 running integ tests webapp tests"
If the app uses JDO, then the tests might fail because the entities won’t have been enhanced. However, we can then easily update the automatically-created run configuration to run the datanucleus enhancer goal (same as when running the application):
data:image/s3,"s3://crabby-images/39802/398021b2d1599dc33c9f3fe0cb473a9f51b2c7ba" alt="050 running integration tests run configuration"