Komet was created to harmonize existing medical terminology and create interoperable data. This file will explain best practices for getting started, building, running, and contributing code in Komet.
Install App Team
This intention of this (Komet) project is to provide a user-friendly interface that lets the user view, analyze, change, create, import and export the various medical terminologies. All the terminology changes and their relationships are saved and can be viewed historically.
- You should have copy of a local DB available and configured. If not then please request for one.
- Uninstall any previously installed versions of Komet.
- To get started with installing and using Komet, browse to the available releases in GitHub. See the documentation about the new features included in each release.
- Download the appropriate installation file for your machine (example, for Windows OS download Komet-X.X.X-Installer-Windows-Unsigned.msi).
- Once the download is complete, run the downloaded file and install Komet.
- Follow the (if-any) installation instructions. For Windows if you get a security alert click on "Run anyway" option.
- Komet is now installed on your local machine. You can now run Komet from programs or installed directory.
- Local Git repo and GitBash or similar shell-prompt installed/configured on your local machine.
- Set up GitHub by following the instructions provided here
- Download and install Open JDK Java 21 or greater latest version
- Download and install Apache Maven 3.9 or greater link here
- Prior to building Komet, there are additional repositories to clone and build. Please use
the
tinkar-core
README file to build thetinkar-core
project and its prerequisites before buildingkomet
.
-
Once you have access to komet repository on GitHub, fork the repository using instructions provided in "Fork the Repository" section in GitHub document.
-
Clone the forked Komet repository on your local machine by running the git bash command.
git clone [email protected]:your-github-username/komet.git
-
Change the local directory location to
komet
-
Enter the following command to build the application:
mvn clean install
-
Run the Komet application with the following command:
mvn -f application javafx:run
-
You can open Komet code using your favorite IDE like Eclipse or IntelliJ Idea and try running it from there. While running Komet UI from your IDE, you many have to add the following VM arguments:
-Xmx10g --add-exports javafx.controls/com.sun.javafx.scene.control.behavior=dev.ikm.komet.navigator
After building Komet, you can run it with JPro on your local machine by following these steps:
- Execute the following command to run the Komet application in your web browser:
The default web browser should open automatically, displaying the Komet application. If it doesn't, navigate to
mvn -f application -Pjpro jpro:run
http://localhost:8080
in your browser. - To stop the application, press
Ctrl + C
in the terminal where the application is running. - To rerun the application, repeat step 1.
To run Komet with JPro in a Docker container, follow these steps:
- Create the application release zip for deployment using the following command:
The release zip will be created in the
mvn clean -f application -Pjpro jpro:release
application/target
directory, namedkomet-jpro.zip
. - Transfer the
komet-jpro.zip
file to the directory where you want to run the Docker container. - Extract the contents of
komet-jpro.zip
file and navigate to the extracted folder. - To run the application in a Docker container, choose one of the following options:
- Option 1: Build the Docker image and run the Docker container manually
- Inside the unzipped directory, locate the
Dockerfile
. - Build the Docker image with the following command:
docker build -t komet-jpro .
- Run the Docker container using the following command:
Note:docker run -d -v ~/Solor:/root/Solor -p 8080:8080 komet-jpro
-v ~/Solor:/root/Solor
: This option mounts a volume, mapping a directory on your host machine to a directory inside the container.- ~/Solor: Path to the dataset directory on your local system.
- /root/Solor: Path inside the container where the dataset will be accessible.
- Inside the unzipped directory, locate the
- Option 2: Use Docker Compose
- Within the extracted directory, find the
docker-compose.yml
file. - Start the Docker container with Docker Compose by running:
docker compose up -d
- Within the extracted directory, find the
- The application should now be running in the Docker container. Access it by navigating to
http://localhost:8080
in your web browser. If running on a remote server, replace localhost with the server’s IP address.
The Komet application includes GUI tests built with the TestFX framework. By default, these tests run in headless mode, which is ideal for continuous integration (CI) environments or situations where graphical interaction is unnecessary.
- Running TestFX Tests in Headless Mode (Default)
To execute all TestFX unit tests, in headless mode (without launching a GUI window), run:
mvn test -DrunUTestFX
- Running TestFX Tests in Graphical Mode (Non-Headless)
If you need to observe the GUI during testing—for instance, when debugging UI components—you can disable headless mode
by setting the headless property to false.
To run all tests in non-headless mode:
mvn test -DrunUTestFX -Dtestfx.headless=false
- Running Specific Tests
- To run a specific test class in a specific module, for example the
LoginUTestFX
class in thekview
module:mvn test -pl kview -DrunUTestFX -Dtest=LoginUTestFX -Dtestfx.headless=false
- To run a specific test method inside a specific class, for example the
testSuccessfulAuthentication
method in theLoginUTestFX
class in thekview
module:mvn test -pl kview -DrunUTestFX -Dtest=LoginUTestFX#testSuccessfulAuthentication -Dtestfx.headless=false
In addition to unit tests, Komet includes integration tests to ensure that different components work seamlessly together.
-
Running all Integration Tests in Headless Mode (Default) To execute all TestFX integration tests use the following command:
mvn verify -DrunITestFX
This command triggers the
verify
phase in Maven, running all TestFX integration tests defined in the project. By default, TestFX integration tests run in headless mode, suitable for CI environments. -
Running all Integration Tests in Graphical Mode If you need to observe the GUI during TestFX integration testing—for example, when debugging UI interactions—you can disable headless mode by setting the
testfx.headless
property tofalse
:mvn verify -DrunITestFX -Dtestfx.headless=false
This will launch the GUI windows during test execution, allowing you to visually monitor the tests as they run.
-
Running Specific Integration Tests To run a specific integration test class in a specific module, you can specify the module using the
-pl
parameter and the test class using the-Dit.test
parameter. For example, to run thePatternWindowITestFX
integration test class:mvn verify -pl application -DrunITestFX -Dit.test=PatternWindowITestFX
Important Note on Test Execution
- The tests will only run once after they pass successfully. To trigger the tests again, changes must be made to any part of the project.
- Adding the
-Dmaven.build.cache.enabled=false
parameter will disable the Maven build cache, preventing tests from being cached and reused, thus forcing fresh test execution. For example:mvn test -DrunUTestFX -Dmaven.build.cache.enabled=false
mvn verify -DrunITestFX -Dmaven.build.cache.enabled=false
This section details on the basic design methodology used for developing nex-gen Komet UI.
- Komet UI application is moving towards the nex-gen implementation which follows Model-View-View-Model (MVVM) design pattern.
- Komet application design is event-based where the subscriber to an event listens for a particular event and when it is triggered,
desired logic can be executed in the listener code.
Example:
import java.util.UUID; public class MyController { private EvtBus eventBus; private Subscriber<MyDefienedEvent> someMyDefinedEventSubscriber; public void initialize() { someMyDefinedEventSubscriber = evt -> { // Some logic to process the event. if (evt.getEventType() == MyDefienedEvent.SOME_EVENT_1) { // do something. } else if (evt.getEventType() == MyDefienedEvent.SOME_EVENT_2) { //do something else. } }; eventBus.subscribe(myTopic, MyDefienedEvent.class, someMyDefinedEventSubscriber); } } public class MyDefienedEvent extends Evt { public static final EvtType<MyDefienedEvent> SOME_EVENT_1 = new EvtType<>(Evt.ANY, "SOME_EVENT_1"); public static final EvtType<MyDefienedEvent> SOME_EVENT_2 = new EvtType<>(Evt.ANY, "SOME_EVENT_2"); /** * Constructs a prototypical Event. * You can optionally pass arguments in this constructor and set the value as final in the constructor. * The value can be retrived using the getter method for that variable. * @param source the object on which the Event initially occurred * @param eventType */ public MyDefienedEvent(Object source, EvtType eventType) { super(source, eventType); } } public class MySomeClass { private EvtBus eventBus; private UUID someTopic; public MySomeClass(UUID someTopic){ this.someTopic = someTopic; } public void someMethod() { eventBus.publish(someTopic, new MyDefienedEvent(this, MyDefienedEvent.SOME_EVENT_1)); } } public class MainClass { public static void main(String[] args) { MySomeClass mySomeClass = new MySomeClass(UUID.randomUUID()); } }
- Komet's design also includes the cognitive framework to implement MVVM architecture framework.
You can find more information along with the examples here
- Gradle:
implementation 'org.carlfx:cognitive:1.3.0'
- Maven
<dependency> <groupId>org.carlfx</groupId> <artifactId>cognitive</artifactId> <version>1.3.0</version> </dependency>
- Project using Java Modules (JPMS) will want to do the following in the consuming module:
requires org.carlfx.cognitive;
- Gradle:
- No specific configuration is required to run the installed version of Komet.
- To run Komet from an IDE (development environment), you will have to do some VM configuration as below:
-Xmx10g --add-exports javafx.controls/com.sun.javafx.scene.control.behavior=dev.ikm.komet.navigator
- The DB needs to be configured under the 'users -> SOLAR' directory.
- Komet requires sample data to operate with full functionality
Technical and non-technical issues can be reported to the Issue Tracker.
Contributions can be submitted via pull requests. Please check the contribution guide for more details.