Skip to content
/ komet Public

Komet is a health care interoperability solution that seeks to translate and integrate terminology standards used in health care settings.

License

Notifications You must be signed in to change notification settings

ikmdev/komet

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Komet-java

SonarCloud Security Rating Coverage

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.

Team Ownership - Product Owner

Install App Team

Project Overview

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.

Getting Started

Installation Instructions

Pre-requisites:

  1. You should have copy of a local DB available and configured. If not then please request for one.
  2. Uninstall any previously installed versions of Komet.

Installing Komet on your local machine:

  1. 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.img_1.png
  2. Download the appropriate installation file for your machine (example, for Windows OS download Komet-X.X.X-Installer-Windows-Unsigned.msi).
  3. Once the download is complete, run the downloaded file and install Komet.
  4. Follow the (if-any) installation instructions. For Windows if you get a security alert click on "Run anyway" option.img_2.png
  5. Komet is now installed on your local machine. You can now run Komet from programs or installed directory.

Follow the instructions below to set up the local environment for Komet

Pre-requisites:

  1. Local Git repo and GitBash or similar shell-prompt installed/configured on your local machine.
  2. Set up GitHub by following the instructions provided here
  3. Download and install Open JDK Java 21 or greater latest version
  4. Download and install Apache Maven 3.9 or greater link here
  5. Prior to building Komet, there are additional repositories to clone and build. Please use the tinkar-core README file to build the tinkar-core project and its prerequisites before building komet.

Building and Running Komet locally:

  1. Once you have access to komet repository on GitHub, fork the repository using instructions provided in "Fork the Repository" section in GitHub document.

  2. Clone the forked Komet repository on your local machine by running the git bash command.

    git clone [email protected]:your-github-username/komet.git
  3. Change the local directory location to komet

  4. Enter the following command to build the application:

    mvn clean install
  5. Run the Komet application with the following command:

    mvn -f application javafx:run
  6. 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
    

Running Komet with JPro locally

After building Komet, you can run it with JPro on your local machine by following these steps:

  1. Execute the following command to run the Komet application in your web browser:
    mvn -f application -Pjpro jpro:run
    The default web browser should open automatically, displaying the Komet application. If it doesn't, navigate to http://localhost:8080 in your browser.
  2. To stop the application, press Ctrl + C in the terminal where the application is running.
  3. To rerun the application, repeat step 1.

Running Komet with JPro in a Docker Container

To run Komet with JPro in a Docker container, follow these steps:

  1. Create the application release zip for deployment using the following command:
    mvn clean -f application -Pjpro jpro:release
    The release zip will be created in the application/target directory, named komet-jpro.zip.
  2. Transfer the komet-jpro.zip file to the directory where you want to run the Docker container.
  3. Extract the contents of komet-jpro.zip file and navigate to the extracted folder.
  4. 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:
    docker run -d -v ~/Solor:/root/Solor -p 8080:8080 komet-jpro
    Note: -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.
  • 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
  1. 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.

TestFX Framework for GUI Testing in Komet JavaFX Application

Running Komet GUI Unit Tests Using the TestFX Framework

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.

  1. 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
  2. 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
  3. Running Specific Tests
  • To run a specific test class in a specific module, for example the LoginUTestFX class in the kview 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 the LoginUTestFX class in the kview module:
    mvn test -pl kview -DrunUTestFX -Dtest=LoginUTestFX#testSuccessfulAuthentication -Dtestfx.headless=false

Running Integration Tests Using the TestFX Framework

In addition to unit tests, Komet includes integration tests to ensure that different components work seamlessly together.

  1. 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.

  2. 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 to false:

    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.

  3. 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 the PatternWindowITestFX 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

Usage Examples:

This section details on the basic design methodology used for developing nex-gen Komet UI.

  1. Komet UI application is moving towards the nex-gen implementation which follows Model-View-View-Model (MVVM) design pattern.
  2. 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());
       }
    }
  3. Komet's design also includes the cognitive framework to implement MVVM architecture framework. You can find more information along with the examples here
    1. Gradle:
      implementation 'org.carlfx:cognitive:1.3.0'
      
    2. Maven
      <dependency>
      <groupId>org.carlfx</groupId>
      <artifactId>cognitive</artifactId>
      <version>1.3.0</version>
      </dependency>
      
    3. Project using Java Modules (JPMS) will want to do the following in the consuming module:
      requires org.carlfx.cognitive;
      

Configuration Options

  1. No specific configuration is required to run the installed version of Komet.
  2. 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
    
  3. The DB needs to be configured under the 'users -> SOLAR' directory.
  4. Komet requires sample data to operate with full functionality

Issues and Contributions

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.

About

Komet is a health care interoperability solution that seeks to translate and integrate terminology standards used in health care settings.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages