Merge branch 'eugenp:master' into danielmcnally285_last_n_characters
This commit is contained in:
commit
ab35aeabf7
|
@ -4,8 +4,8 @@
|
||||||
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<artifactId>akka-modules</artifactId>
|
<artifactId>akka-modules</artifactId>
|
||||||
<name>akka-modules</name>
|
|
||||||
<packaging>pom</packaging>
|
<packaging>pom</packaging>
|
||||||
|
<name>akka-modules</name>
|
||||||
|
|
||||||
<parent>
|
<parent>
|
||||||
<artifactId>parent-modules</artifactId>
|
<artifactId>parent-modules</artifactId>
|
||||||
|
|
|
@ -4,8 +4,8 @@
|
||||||
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
|
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<artifactId>cxf-spring</artifactId>
|
<artifactId>cxf-spring</artifactId>
|
||||||
<name>cxf-spring</name>
|
|
||||||
<packaging>war</packaging>
|
<packaging>war</packaging>
|
||||||
|
<name>cxf-spring</name>
|
||||||
|
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>com.baeldung</groupId>
|
<groupId>com.baeldung</groupId>
|
||||||
|
|
|
@ -5,8 +5,9 @@
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<artifactId>apache-cxf-modules</artifactId>
|
<artifactId>apache-cxf-modules</artifactId>
|
||||||
<version>0.0.1-SNAPSHOT</version>
|
<version>0.0.1-SNAPSHOT</version>
|
||||||
<name>apache-cxf-modules</name>
|
|
||||||
<packaging>pom</packaging>
|
<packaging>pom</packaging>
|
||||||
|
<name>apache-cxf-modules</name>
|
||||||
|
|
||||||
|
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>com.baeldung</groupId>
|
<groupId>com.baeldung</groupId>
|
||||||
|
|
|
@ -4,8 +4,8 @@
|
||||||
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<artifactId>sse-jaxrs</artifactId>
|
<artifactId>sse-jaxrs</artifactId>
|
||||||
<name>sse-jaxrs</name>
|
|
||||||
<packaging>pom</packaging>
|
<packaging>pom</packaging>
|
||||||
|
<name>sse-jaxrs</name>
|
||||||
|
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>com.baeldung</groupId>
|
<groupId>com.baeldung</groupId>
|
||||||
|
|
|
@ -4,8 +4,8 @@
|
||||||
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<artifactId>sse-jaxrs-server</artifactId>
|
<artifactId>sse-jaxrs-server</artifactId>
|
||||||
<name>sse-jaxrs-server</name>
|
|
||||||
<packaging>war</packaging>
|
<packaging>war</packaging>
|
||||||
|
<name>sse-jaxrs-server</name>
|
||||||
|
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>com.baeldung</groupId>
|
<groupId>com.baeldung</groupId>
|
||||||
|
|
|
@ -5,8 +5,8 @@
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<artifactId>apache-httpclient4</artifactId>
|
<artifactId>apache-httpclient4</artifactId>
|
||||||
<version>0.1-SNAPSHOT</version>
|
<version>0.1-SNAPSHOT</version>
|
||||||
<name>apache-httpclient4</name>
|
|
||||||
<packaging>war</packaging>
|
<packaging>war</packaging>
|
||||||
|
<name>apache-httpclient4</name>
|
||||||
|
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>com.baeldung</groupId>
|
<groupId>com.baeldung</groupId>
|
||||||
|
@ -193,7 +193,6 @@
|
||||||
<filtering>true</filtering>
|
<filtering>true</filtering>
|
||||||
</resource>
|
</resource>
|
||||||
</resources>
|
</resources>
|
||||||
|
|
||||||
</build>
|
</build>
|
||||||
|
|
||||||
<profiles>
|
<profiles>
|
||||||
|
|
|
@ -24,14 +24,12 @@
|
||||||
<artifactId>camel-core</artifactId>
|
<artifactId>camel-core</artifactId>
|
||||||
<version>${camel.version}</version>
|
<version>${camel.version}</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>org.apache.camel</groupId>
|
<groupId>org.apache.camel</groupId>
|
||||||
<artifactId>camel-test-junit5</artifactId>
|
<artifactId>camel-test-junit5</artifactId>
|
||||||
<version>${camel.version}</version>
|
<version>${camel.version}</version>
|
||||||
<scope>test</scope>
|
<scope>test</scope>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>org.apache.camel</groupId>
|
<groupId>org.apache.camel</groupId>
|
||||||
<artifactId>camel-main</artifactId>
|
<artifactId>camel-main</artifactId>
|
||||||
|
|
|
@ -5,8 +5,8 @@
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<artifactId>apache-spark</artifactId>
|
<artifactId>apache-spark</artifactId>
|
||||||
<version>1.0-SNAPSHOT</version>
|
<version>1.0-SNAPSHOT</version>
|
||||||
<name>apache-spark</name>
|
|
||||||
<packaging>jar</packaging>
|
<packaging>jar</packaging>
|
||||||
|
<name>apache-spark</name>
|
||||||
|
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>com.baeldung</groupId>
|
<groupId>com.baeldung</groupId>
|
||||||
|
|
|
@ -5,8 +5,8 @@
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<artifactId>apache-thrift</artifactId>
|
<artifactId>apache-thrift</artifactId>
|
||||||
<version>0.0.1-SNAPSHOT</version>
|
<version>0.0.1-SNAPSHOT</version>
|
||||||
<name>apache-thrift</name>
|
|
||||||
<packaging>pom</packaging>
|
<packaging>pom</packaging>
|
||||||
|
<name>apache-thrift</name>
|
||||||
|
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>com.baeldung</groupId>
|
<groupId>com.baeldung</groupId>
|
||||||
|
|
|
@ -5,8 +5,8 @@
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<artifactId>apache-velocity</artifactId>
|
<artifactId>apache-velocity</artifactId>
|
||||||
<version>0.1-SNAPSHOT</version>
|
<version>0.1-SNAPSHOT</version>
|
||||||
<name>apache-velocity</name>
|
|
||||||
<packaging>war</packaging>
|
<packaging>war</packaging>
|
||||||
|
<name>apache-velocity</name>
|
||||||
|
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>com.baeldung</groupId>
|
<groupId>com.baeldung</groupId>
|
||||||
|
|
|
@ -5,8 +5,8 @@
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<artifactId>aws-dynamodb</artifactId>
|
<artifactId>aws-dynamodb</artifactId>
|
||||||
<version>0.1.0-SNAPSHOT</version>
|
<version>0.1.0-SNAPSHOT</version>
|
||||||
<name>aws-dynamodb</name>
|
|
||||||
<packaging>jar</packaging>
|
<packaging>jar</packaging>
|
||||||
|
<name>aws-dynamodb</name>
|
||||||
|
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>com.baeldung</groupId>
|
<groupId>com.baeldung</groupId>
|
||||||
|
|
|
@ -4,8 +4,8 @@
|
||||||
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<artifactId>lambda-function</artifactId>
|
<artifactId>lambda-function</artifactId>
|
||||||
<version>0.1.0-SNAPSHOT</version>
|
|
||||||
<name>lambda-function</name>
|
<name>lambda-function</name>
|
||||||
|
<version>0.1.0-SNAPSHOT</version>
|
||||||
<packaging>jar</packaging>
|
<packaging>jar</packaging>
|
||||||
|
|
||||||
<parent>
|
<parent>
|
||||||
|
|
|
@ -4,8 +4,8 @@
|
||||||
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<artifactId>aws-lambda-modules</artifactId>
|
<artifactId>aws-lambda-modules</artifactId>
|
||||||
<name>aws-lambda-modules</name>
|
|
||||||
<packaging>pom</packaging>
|
<packaging>pom</packaging>
|
||||||
|
<name>aws-lambda-modules</name>
|
||||||
|
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>com.baeldung</groupId>
|
<groupId>com.baeldung</groupId>
|
||||||
|
|
|
@ -3,8 +3,8 @@
|
||||||
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
|
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<artifactId>ShippingFunction</artifactId>
|
<artifactId>ShippingFunction</artifactId>
|
||||||
<version>1.0</version>
|
|
||||||
<name>ShippingFunction</name>
|
<name>ShippingFunction</name>
|
||||||
|
<version>1.0</version>
|
||||||
<packaging>jar</packaging>
|
<packaging>jar</packaging>
|
||||||
|
|
||||||
<parent>
|
<parent>
|
||||||
|
|
|
@ -4,8 +4,8 @@
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<groupId>helloworld</groupId>
|
<groupId>helloworld</groupId>
|
||||||
<artifactId>ToDoFunction</artifactId>
|
<artifactId>ToDoFunction</artifactId>
|
||||||
<version>1.0</version>
|
|
||||||
<name>ToDoFunction</name>
|
<name>ToDoFunction</name>
|
||||||
|
<version>1.0</version>
|
||||||
<packaging>jar</packaging>
|
<packaging>jar</packaging>
|
||||||
|
|
||||||
<parent>
|
<parent>
|
||||||
|
|
|
@ -5,8 +5,8 @@
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<artifactId>aws-miscellaneous</artifactId>
|
<artifactId>aws-miscellaneous</artifactId>
|
||||||
<version>0.1.0-SNAPSHOT</version>
|
<version>0.1.0-SNAPSHOT</version>
|
||||||
<name>aws-miscellaneous</name>
|
|
||||||
<packaging>jar</packaging>
|
<packaging>jar</packaging>
|
||||||
|
<name>aws-miscellaneous</name>
|
||||||
|
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>com.baeldung</groupId>
|
<groupId>com.baeldung</groupId>
|
||||||
|
|
|
@ -5,8 +5,8 @@
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<artifactId>aws-s3</artifactId>
|
<artifactId>aws-s3</artifactId>
|
||||||
<version>0.1.0-SNAPSHOT</version>
|
<version>0.1.0-SNAPSHOT</version>
|
||||||
<name>aws-s3</name>
|
|
||||||
<packaging>jar</packaging>
|
<packaging>jar</packaging>
|
||||||
|
<name>aws-s3</name>
|
||||||
|
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>com.baeldung</groupId>
|
<groupId>com.baeldung</groupId>
|
||||||
|
@ -26,7 +26,6 @@
|
||||||
<version>${aws.java.sdk.version}</version>
|
<version>${aws.java.sdk.version}</version>
|
||||||
<scope>test</scope>
|
<scope>test</scope>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>commons-io</groupId>
|
<groupId>commons-io</groupId>
|
||||||
<artifactId>commons-io</artifactId>
|
<artifactId>commons-io</artifactId>
|
||||||
|
@ -56,7 +55,6 @@
|
||||||
<version>${com.adobe.testing.version}</version>
|
<version>${com.adobe.testing.version}</version>
|
||||||
<scope>test</scope>
|
<scope>test</scope>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>org.testcontainers</groupId>
|
<groupId>org.testcontainers</groupId>
|
||||||
<artifactId>junit-jupiter</artifactId>
|
<artifactId>junit-jupiter</artifactId>
|
||||||
|
|
|
@ -4,6 +4,7 @@
|
||||||
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<artifactId>aws-modules</artifactId>
|
<artifactId>aws-modules</artifactId>
|
||||||
|
<packaging>pom</packaging>
|
||||||
<name>aws-modules</name>
|
<name>aws-modules</name>
|
||||||
|
|
||||||
<parent>
|
<parent>
|
||||||
|
@ -12,16 +13,6 @@
|
||||||
<version>1.0.0-SNAPSHOT</version>
|
<version>1.0.0-SNAPSHOT</version>
|
||||||
</parent>
|
</parent>
|
||||||
|
|
||||||
<dependencies>
|
|
||||||
<dependency>
|
|
||||||
<groupId>com.amazonaws</groupId>
|
|
||||||
<artifactId>aws-java-sdk-dynamodb</artifactId>
|
|
||||||
<version>1.12.523</version>
|
|
||||||
<scope>compile</scope>
|
|
||||||
</dependency>
|
|
||||||
</dependencies>
|
|
||||||
<packaging>pom</packaging>
|
|
||||||
|
|
||||||
<modules>
|
<modules>
|
||||||
<module>aws-app-sync</module>
|
<module>aws-app-sync</module>
|
||||||
<module>aws-dynamodb</module>
|
<module>aws-dynamodb</module>
|
||||||
|
@ -31,6 +22,15 @@
|
||||||
<module>aws-s3</module>
|
<module>aws-s3</module>
|
||||||
</modules>
|
</modules>
|
||||||
|
|
||||||
|
<dependencies>
|
||||||
|
<dependency>
|
||||||
|
<groupId>com.amazonaws</groupId>
|
||||||
|
<artifactId>aws-java-sdk-dynamodb</artifactId>
|
||||||
|
<version>1.12.523</version>
|
||||||
|
<scope>compile</scope>
|
||||||
|
</dependency>
|
||||||
|
</dependencies>
|
||||||
|
|
||||||
<properties>
|
<properties>
|
||||||
<aws-java-sdk.version>1.12.331</aws-java-sdk.version>
|
<aws-java-sdk.version>1.12.331</aws-java-sdk.version>
|
||||||
<aws-java-sdk-v2.version>2.24.9</aws-java-sdk-v2.version>
|
<aws-java-sdk-v2.version>2.24.9</aws-java-sdk-v2.version>
|
||||||
|
|
|
@ -5,8 +5,8 @@
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<artifactId>azure</artifactId>
|
<artifactId>azure</artifactId>
|
||||||
<version>0.1</version>
|
<version>0.1</version>
|
||||||
<name>azure</name>
|
|
||||||
<packaging>war</packaging>
|
<packaging>war</packaging>
|
||||||
|
<name>azure</name>
|
||||||
<description>Demo project for Spring Boot on Azure</description>
|
<description>Demo project for Spring Boot on Azure</description>
|
||||||
|
|
||||||
<parent>
|
<parent>
|
||||||
|
|
|
@ -0,0 +1,45 @@
|
||||||
|
package com.baeldung.checkiftimebetweentwotimes;
|
||||||
|
|
||||||
|
import org.junit.Test;
|
||||||
|
|
||||||
|
import java.time.LocalTime;
|
||||||
|
import java.util.Calendar;
|
||||||
|
import java.util.Date;
|
||||||
|
|
||||||
|
import static org.junit.Assert.assertTrue;
|
||||||
|
|
||||||
|
public class CheckIfTimeBetweenTwoTimesUnitTest {
|
||||||
|
private LocalTime startTime = LocalTime.parse("09:00:00");
|
||||||
|
private LocalTime endTime = LocalTime.parse("17:00:00");
|
||||||
|
private LocalTime targetTime = LocalTime.parse("12:30:00");
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void givenLocalTime_whenUsingIsAfterIsBefore_thenTimeIsBetween() {
|
||||||
|
assertTrue(!targetTime.isBefore(startTime) && !targetTime.isAfter(endTime));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void givenLocalTime_whenUsingCompareTo_thenTimeIsBetween() {
|
||||||
|
assertTrue(targetTime.compareTo(startTime) >= 0 && targetTime.compareTo(endTime) <= 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void givenDate_whenUsingAfterBefore_thenTimeIsBetween() {
|
||||||
|
Calendar startCalendar = Calendar.getInstance();
|
||||||
|
startCalendar.set(Calendar.HOUR_OF_DAY, 9);
|
||||||
|
startCalendar.set(Calendar.MINUTE, 0);
|
||||||
|
Date startTime = startCalendar.getTime();
|
||||||
|
|
||||||
|
Calendar endCalendar = Calendar.getInstance();
|
||||||
|
endCalendar.set(Calendar.HOUR_OF_DAY, 17);
|
||||||
|
endCalendar.set(Calendar.MINUTE, 0);
|
||||||
|
Date endTime = endCalendar.getTime();
|
||||||
|
|
||||||
|
Calendar targetCalendar = Calendar.getInstance();
|
||||||
|
targetCalendar.set(Calendar.HOUR_OF_DAY, 12);
|
||||||
|
targetCalendar.set(Calendar.MINUTE, 30);
|
||||||
|
Date targetTime = targetCalendar.getTime();
|
||||||
|
|
||||||
|
assertTrue(!targetTime.before(startTime) && !targetTime.after(endTime));
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,3 @@
|
||||||
|
=========
|
||||||
|
|
||||||
|
### Relevant articles:
|
|
@ -0,0 +1,15 @@
|
||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<project xmlns="http://maven.apache.org/POM/4.0.0"
|
||||||
|
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
|
||||||
|
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
||||||
|
<modelVersion>4.0.0</modelVersion>
|
||||||
|
<artifactId>core-java-lang-math-4</artifactId>
|
||||||
|
<name>core-java-lang-math-4</name>
|
||||||
|
|
||||||
|
<parent>
|
||||||
|
<groupId>com.baeldung.core-java-modules</groupId>
|
||||||
|
<artifactId>core-java-modules</artifactId>
|
||||||
|
<version>0.0.1-SNAPSHOT</version>
|
||||||
|
</parent>
|
||||||
|
|
||||||
|
</project>
|
|
@ -0,0 +1,78 @@
|
||||||
|
package com.baeldung.percentile;
|
||||||
|
|
||||||
|
import static org.junit.jupiter.api.Assertions.assertEquals;
|
||||||
|
import static org.junit.jupiter.api.Assertions.assertThrows;
|
||||||
|
|
||||||
|
import java.util.Arrays;
|
||||||
|
import java.util.Collection;
|
||||||
|
import java.util.Collections;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.stream.Collectors;
|
||||||
|
import java.util.stream.IntStream;
|
||||||
|
|
||||||
|
import org.junit.jupiter.api.Test;
|
||||||
|
|
||||||
|
public class CalculatePercentileUnitTest {
|
||||||
|
|
||||||
|
public static <T extends Comparable<T>> T getPercentile(Collection<T> input, double percentile) {
|
||||||
|
if (input == null || input.isEmpty()) {
|
||||||
|
throw new IllegalArgumentException("The input dataset cannot be null or empty.");
|
||||||
|
}
|
||||||
|
if (percentile < 0 || percentile > 100) {
|
||||||
|
throw new IllegalArgumentException("Percentile must be between 0 and 100(exclusive)");
|
||||||
|
}
|
||||||
|
List<T> sortedList = input.stream()
|
||||||
|
.sorted()
|
||||||
|
.collect(Collectors.toList());
|
||||||
|
|
||||||
|
int rank = percentile == 0 ? 1 : (int) Math.ceil(percentile / 100.0 * input.size());
|
||||||
|
return sortedList.get(rank - 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
void whenCallingGetPercentileWithAList_thenGetExpectedResult() {
|
||||||
|
assertThrows(IllegalArgumentException.class, () -> getPercentile(List.of(1, 2, 3), -1));
|
||||||
|
assertThrows(IllegalArgumentException.class, () -> getPercentile(List.of(1, 2, 3), 101));
|
||||||
|
|
||||||
|
List<Integer> list100 = IntStream.rangeClosed(1, 100)
|
||||||
|
.boxed()
|
||||||
|
.collect(Collectors.toList());
|
||||||
|
Collections.shuffle(list100);
|
||||||
|
|
||||||
|
assertEquals(1, getPercentile(list100, 0));
|
||||||
|
assertEquals(10, getPercentile(list100, 10));
|
||||||
|
assertEquals(25, getPercentile(list100, 25));
|
||||||
|
assertEquals(50, getPercentile(list100, 50));
|
||||||
|
assertEquals(76, getPercentile(list100, 75.3));
|
||||||
|
assertEquals(100, getPercentile(list100, 100));
|
||||||
|
|
||||||
|
List<Integer> list8 = IntStream.of(-1, 200, 30, 42, -5, 7, 8, 92)
|
||||||
|
.boxed()
|
||||||
|
.collect(Collectors.toList());
|
||||||
|
|
||||||
|
assertEquals(-5, getPercentile(list8, 0));
|
||||||
|
assertEquals(-5, getPercentile(list8, 10));
|
||||||
|
assertEquals(-1, getPercentile(list8, 25));
|
||||||
|
assertEquals(8, getPercentile(list8, 50));
|
||||||
|
assertEquals(92, getPercentile(list8, 75.3));
|
||||||
|
assertEquals(200, getPercentile(list8, 100));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
void whenCallingGetPercentileWithAnArray_thenGetExpectedResult() {
|
||||||
|
|
||||||
|
long[] theArray = new long[] { -1, 200, 30, 42, -5, 7, 8, 92 };
|
||||||
|
|
||||||
|
//convert the long[] array to a List<Long>
|
||||||
|
List<Long> list8 = Arrays.stream(theArray)
|
||||||
|
.boxed()
|
||||||
|
.toList();
|
||||||
|
|
||||||
|
assertEquals(-5, getPercentile(list8, 0));
|
||||||
|
assertEquals(-5, getPercentile(list8, 10));
|
||||||
|
assertEquals(-1, getPercentile(list8, 25));
|
||||||
|
assertEquals(8, getPercentile(list8, 50));
|
||||||
|
assertEquals(92, getPercentile(list8, 75.3));
|
||||||
|
assertEquals(200, getPercentile(list8, 100));
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,66 @@
|
||||||
|
package com.baeldung.integersatbitlevel;
|
||||||
|
|
||||||
|
import org.junit.jupiter.api.Test;
|
||||||
|
|
||||||
|
import static org.junit.Assert.assertEquals;
|
||||||
|
|
||||||
|
class IntegersBitLevelUnitTest {
|
||||||
|
|
||||||
|
@Test
|
||||||
|
void givenNumbers_whenBitwiseAND_thenResultIsExpected() {
|
||||||
|
int result = 0b1100 & 0b0111;
|
||||||
|
assertEquals(0b0100, result);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
void givenNumbers_whenBitwiseOR_thenResultIsExpected() {
|
||||||
|
int result = 0b1100 | 0b0111;
|
||||||
|
assertEquals(0b1111, result);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
void givenNumbers_whenBitwiseXOR_thenResultIsExpected() {
|
||||||
|
int result = 0b1100 ^ 0b0111;
|
||||||
|
assertEquals(0b1011, result);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
void givenNumber_whenBitwiseNOT_thenResultIsExpected() {
|
||||||
|
int result = ~0b0101;
|
||||||
|
assertEquals(-0b0110, result);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
void givenNumber_whenBitwiseLeftShift_thenResultIsExpected() {
|
||||||
|
int result = 0b0101 << 2;
|
||||||
|
assertEquals(0b10100, result);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
void givenNumber_whenBitwiseRightShift_thenResultIsExpected() {
|
||||||
|
int result = 0b0101 >> 1;
|
||||||
|
assertEquals(0b10, result);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
void givenOriginalColor_whenApplyingMask_thenObtainModifiedColor() {
|
||||||
|
int originalColor = 0xFF336699;
|
||||||
|
|
||||||
|
int alphaMask = 0xFF000000;
|
||||||
|
int redMask = 0x00FF0000;
|
||||||
|
int greenMask = 0x0000FF00;
|
||||||
|
int blueMask = 0x000000FF;
|
||||||
|
|
||||||
|
int alpha = (originalColor & alphaMask) >>> 24;
|
||||||
|
int red = (originalColor & redMask) >>> 16;
|
||||||
|
int green = (originalColor & greenMask) >>> 8;
|
||||||
|
int blue = originalColor & blueMask;
|
||||||
|
|
||||||
|
red = Math.min(255, red + 50);
|
||||||
|
green = Math.min(255, green + 30);
|
||||||
|
|
||||||
|
int modifiedColor = (alpha << 24) | (red << 16) | (green << 8) | blue;
|
||||||
|
|
||||||
|
assertEquals(-10124135, modifiedColor);
|
||||||
|
}
|
||||||
|
}
|
|
@ -55,7 +55,7 @@
|
||||||
</build>
|
</build>
|
||||||
|
|
||||||
<properties>
|
<properties>
|
||||||
<validator.version>1.7</validator.version>
|
<validator.version>1.8.0</validator.version>
|
||||||
<emoji-java.version>5.1.1</emoji-java.version>
|
<emoji-java.version>5.1.1</emoji-java.version>
|
||||||
<apache-commons-text.version>1.10.0</apache-commons-text.version>
|
<apache-commons-text.version>1.10.0</apache-commons-text.version>
|
||||||
</properties>
|
</properties>
|
||||||
|
|
|
@ -144,6 +144,7 @@
|
||||||
<module>core-java-lang-6</module>
|
<module>core-java-lang-6</module>
|
||||||
<module>core-java-lang-math</module>
|
<module>core-java-lang-math</module>
|
||||||
<module>core-java-lang-math-2</module>
|
<module>core-java-lang-math-2</module>
|
||||||
|
<module>core-java-lang-math-4</module>
|
||||||
<module>core-java-lang-oop-constructors</module>
|
<module>core-java-lang-oop-constructors</module>
|
||||||
<module>core-java-lang-oop-patterns</module>
|
<module>core-java-lang-oop-patterns</module>
|
||||||
<module>core-java-lang-oop-generics</module>
|
<module>core-java-lang-oop-generics</module>
|
||||||
|
|
|
@ -4,8 +4,8 @@
|
||||||
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
|
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<artifactId>deeplearning4j</artifactId>
|
<artifactId>deeplearning4j</artifactId>
|
||||||
<name>deeplearning4j</name>
|
|
||||||
<packaging>jar</packaging>
|
<packaging>jar</packaging>
|
||||||
|
<name>deeplearning4j</name>
|
||||||
|
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>com.baeldung</groupId>
|
<groupId>com.baeldung</groupId>
|
||||||
|
|
|
@ -4,8 +4,8 @@
|
||||||
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<artifactId>guice</artifactId>
|
<artifactId>guice</artifactId>
|
||||||
<name>guice</name>
|
|
||||||
<packaging>jar</packaging>
|
<packaging>jar</packaging>
|
||||||
|
<name>guice</name>
|
||||||
|
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>com.baeldung</groupId>
|
<groupId>com.baeldung</groupId>
|
||||||
|
|
|
@ -4,8 +4,8 @@
|
||||||
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<artifactId>di-modules</artifactId>
|
<artifactId>di-modules</artifactId>
|
||||||
<name>di-modules</name>
|
|
||||||
<packaging>pom</packaging>
|
<packaging>pom</packaging>
|
||||||
|
<name>di-modules</name>
|
||||||
|
|
||||||
<parent>
|
<parent>
|
||||||
<artifactId>parent-modules</artifactId>
|
<artifactId>parent-modules</artifactId>
|
||||||
|
|
|
@ -4,8 +4,8 @@
|
||||||
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<artifactId>disruptor</artifactId>
|
<artifactId>disruptor</artifactId>
|
||||||
<name>disruptor</name>
|
|
||||||
<packaging>jar</packaging>
|
<packaging>jar</packaging>
|
||||||
|
<name>disruptor</name>
|
||||||
|
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>com.baeldung</groupId>
|
<groupId>com.baeldung</groupId>
|
||||||
|
|
|
@ -6,8 +6,8 @@
|
||||||
<groupId>com.baeldung</groupId>
|
<groupId>com.baeldung</groupId>
|
||||||
<artifactId>multi-module-caching</artifactId>
|
<artifactId>multi-module-caching</artifactId>
|
||||||
<version>0.0.1-SNAPSHOT</version>
|
<version>0.0.1-SNAPSHOT</version>
|
||||||
<description>Multi-module Maven caching example</description>
|
|
||||||
<packaging>pom</packaging>
|
<packaging>pom</packaging>
|
||||||
|
<description>Multi-module Maven caching example</description>
|
||||||
|
|
||||||
<modules>
|
<modules>
|
||||||
<module>runner-module</module>
|
<module>runner-module</module>
|
||||||
|
|
|
@ -4,8 +4,8 @@
|
||||||
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<artifactId>docker-caching</artifactId>
|
<artifactId>docker-caching</artifactId>
|
||||||
<name>docker-caching</name>
|
|
||||||
<packaging>pom</packaging>
|
<packaging>pom</packaging>
|
||||||
|
<name>docker-caching</name>
|
||||||
|
|
||||||
<parent>
|
<parent>
|
||||||
<artifactId>docker-modules</artifactId>
|
<artifactId>docker-modules</artifactId>
|
||||||
|
|
|
@ -4,8 +4,8 @@
|
||||||
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
|
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<artifactId>docker-compose-2</artifactId>
|
<artifactId>docker-compose-2</artifactId>
|
||||||
<description>Demo project for Spring Boot and Docker - Module docker-compose-2</description>
|
|
||||||
<packaging>pom</packaging>
|
<packaging>pom</packaging>
|
||||||
|
<description>Demo project for Spring Boot and Docker - Module docker-compose-2</description>
|
||||||
|
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>com.baeldung</groupId>
|
<groupId>com.baeldung</groupId>
|
||||||
|
|
|
@ -4,8 +4,8 @@
|
||||||
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<artifactId>geotools</artifactId>
|
<artifactId>geotools</artifactId>
|
||||||
<name>geotools</name>
|
|
||||||
<packaging>jar</packaging>
|
<packaging>jar</packaging>
|
||||||
|
<name>geotools</name>
|
||||||
|
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>com.baeldung</groupId>
|
<groupId>com.baeldung</groupId>
|
||||||
|
|
|
@ -5,8 +5,8 @@
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<artifactId>google-auto-project</artifactId>
|
<artifactId>google-auto-project</artifactId>
|
||||||
<version>1.0</version>
|
<version>1.0</version>
|
||||||
<name>google-auto-project</name>
|
|
||||||
<packaging>pom</packaging>
|
<packaging>pom</packaging>
|
||||||
|
<name>google-auto-project</name>
|
||||||
|
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>com.baeldung</groupId>
|
<groupId>com.baeldung</groupId>
|
||||||
|
|
|
@ -4,8 +4,8 @@
|
||||||
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<artifactId>google-cloud</artifactId>
|
<artifactId>google-cloud</artifactId>
|
||||||
<name>google-cloud</name>
|
|
||||||
<packaging>jar</packaging>
|
<packaging>jar</packaging>
|
||||||
|
<name>google-cloud</name>
|
||||||
<description>Google Cloud Tutorials</description>
|
<description>Google Cloud Tutorials</description>
|
||||||
|
|
||||||
<parent>
|
<parent>
|
||||||
|
|
|
@ -5,8 +5,8 @@
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<groupId>com.baeldung.graphql</groupId>
|
<groupId>com.baeldung.graphql</groupId>
|
||||||
<artifactId>graphql-modules</artifactId>
|
<artifactId>graphql-modules</artifactId>
|
||||||
<name>graphql-modules</name>
|
|
||||||
<packaging>pom</packaging>
|
<packaging>pom</packaging>
|
||||||
|
<name>graphql-modules</name>
|
||||||
|
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>com.baeldung</groupId>
|
<groupId>com.baeldung</groupId>
|
||||||
|
|
|
@ -4,8 +4,8 @@
|
||||||
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<artifactId>grpc</artifactId>
|
<artifactId>grpc</artifactId>
|
||||||
<name>grpc</name>
|
|
||||||
<packaging>jar</packaging>
|
<packaging>jar</packaging>
|
||||||
|
<name>grpc</name>
|
||||||
|
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>com.baeldung</groupId>
|
<groupId>com.baeldung</groupId>
|
||||||
|
|
|
@ -4,9 +4,9 @@
|
||||||
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<artifactId>guava-modules</artifactId>
|
<artifactId>guava-modules</artifactId>
|
||||||
<name>guava-modules</name>
|
|
||||||
<version>0.0.1-SNAPSHOT</version>
|
<version>0.0.1-SNAPSHOT</version>
|
||||||
<packaging>pom</packaging>
|
<packaging>pom</packaging>
|
||||||
|
<name>guava-modules</name>
|
||||||
|
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>com.baeldung</groupId>
|
<groupId>com.baeldung</groupId>
|
||||||
|
|
|
@ -4,8 +4,8 @@
|
||||||
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<artifactId>httpclient-simple</artifactId>
|
<artifactId>httpclient-simple</artifactId>
|
||||||
<name>httpclient-simple</name>
|
|
||||||
<packaging>war</packaging>
|
<packaging>war</packaging>
|
||||||
|
<name>httpclient-simple</name>
|
||||||
|
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>com.baeldung</groupId>
|
<groupId>com.baeldung</groupId>
|
||||||
|
|
|
@ -4,8 +4,8 @@
|
||||||
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<artifactId>jackson-jr</artifactId>
|
<artifactId>jackson-jr</artifactId>
|
||||||
<name>jackson-jr</name>
|
|
||||||
<packaging>pom</packaging>
|
<packaging>pom</packaging>
|
||||||
|
<name>jackson-jr</name>
|
||||||
|
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>com.baeldung</groupId>
|
<groupId>com.baeldung</groupId>
|
||||||
|
|
|
@ -4,9 +4,9 @@
|
||||||
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<artifactId>jackson-modules</artifactId>
|
<artifactId>jackson-modules</artifactId>
|
||||||
<name>jackson-modules</name>
|
|
||||||
<version>0.0.1-SNAPSHOT</version>
|
<version>0.0.1-SNAPSHOT</version>
|
||||||
<packaging>pom</packaging>
|
<packaging>pom</packaging>
|
||||||
|
<name>jackson-modules</name>
|
||||||
|
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>com.baeldung</groupId>
|
<groupId>com.baeldung</groupId>
|
||||||
|
|
|
@ -5,8 +5,8 @@
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<groupId>com.baeldung.blockchain</groupId>
|
<groupId>com.baeldung.blockchain</groupId>
|
||||||
<artifactId>java-blockchain</artifactId>
|
<artifactId>java-blockchain</artifactId>
|
||||||
<name>java-blockchain</name>
|
|
||||||
<packaging>jar</packaging>
|
<packaging>jar</packaging>
|
||||||
|
<name>java-blockchain</name>
|
||||||
|
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>com.baeldung</groupId>
|
<groupId>com.baeldung</groupId>
|
||||||
|
|
|
@ -4,8 +4,8 @@
|
||||||
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<artifactId>java-jdi</artifactId>
|
<artifactId>java-jdi</artifactId>
|
||||||
<name>java-jdi</name>
|
|
||||||
<packaging>jar</packaging>
|
<packaging>jar</packaging>
|
||||||
|
<name>java-jdi</name>
|
||||||
|
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>com.baeldung</groupId>
|
<groupId>com.baeldung</groupId>
|
||||||
|
|
|
@ -5,8 +5,8 @@
|
||||||
<groupId>com.baeldung.java.panama</groupId>
|
<groupId>com.baeldung.java.panama</groupId>
|
||||||
<artifactId>java-panama</artifactId>
|
<artifactId>java-panama</artifactId>
|
||||||
<version>1.0</version>
|
<version>1.0</version>
|
||||||
<name>java-panama</name>
|
|
||||||
<packaging>jar</packaging>
|
<packaging>jar</packaging>
|
||||||
|
<name>java-panama</name>
|
||||||
|
|
||||||
<dependencies>
|
<dependencies>
|
||||||
<dependency>
|
<dependency>
|
||||||
|
|
|
@ -5,8 +5,8 @@
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<groupId>com.baeldung.javax-sound</groupId>
|
<groupId>com.baeldung.javax-sound</groupId>
|
||||||
<artifactId>javax-sound</artifactId>
|
<artifactId>javax-sound</artifactId>
|
||||||
<name>javax-sound</name>
|
|
||||||
<packaging>jar</packaging>
|
<packaging>jar</packaging>
|
||||||
|
<name>javax-sound</name>
|
||||||
|
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>com.baeldung</groupId>
|
<groupId>com.baeldung</groupId>
|
||||||
|
|
|
@ -4,8 +4,8 @@
|
||||||
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<artifactId>jenkins-modules</artifactId>
|
<artifactId>jenkins-modules</artifactId>
|
||||||
<name>jenkins-modules</name>
|
|
||||||
<packaging>pom</packaging>
|
<packaging>pom</packaging>
|
||||||
|
<name>jenkins-modules</name>
|
||||||
|
|
||||||
<parent>
|
<parent>
|
||||||
<artifactId>parent-modules</artifactId>
|
<artifactId>parent-modules</artifactId>
|
||||||
|
|
|
@ -5,8 +5,8 @@
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<artifactId>jetbrains</artifactId>
|
<artifactId>jetbrains</artifactId>
|
||||||
<version>1.0-SNAPSHOT</version>
|
<version>1.0-SNAPSHOT</version>
|
||||||
<name>jetbrains</name>
|
|
||||||
<packaging>jar</packaging>
|
<packaging>jar</packaging>
|
||||||
|
<name>jetbrains</name>
|
||||||
|
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>com.baeldung</groupId>
|
<groupId>com.baeldung</groupId>
|
||||||
|
|
|
@ -4,8 +4,8 @@
|
||||||
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<artifactId>jgit</artifactId>
|
<artifactId>jgit</artifactId>
|
||||||
<name>jgit</name>
|
|
||||||
<packaging>jar</packaging>
|
<packaging>jar</packaging>
|
||||||
|
<name>jgit</name>
|
||||||
|
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>com.baeldung</groupId>
|
<groupId>com.baeldung</groupId>
|
||||||
|
|
|
@ -5,8 +5,8 @@
|
||||||
<groupId>com.baeldung.jhipster</groupId>
|
<groupId>com.baeldung.jhipster</groupId>
|
||||||
<artifactId>jhipster-6</artifactId>
|
<artifactId>jhipster-6</artifactId>
|
||||||
<version>1.0.0-SNAPSHOT</version>
|
<version>1.0.0-SNAPSHOT</version>
|
||||||
<name>jhipster-6</name>
|
|
||||||
<packaging>pom</packaging>
|
<packaging>pom</packaging>
|
||||||
|
<name>jhipster-6</name>
|
||||||
|
|
||||||
<parent>
|
<parent>
|
||||||
<artifactId>parent-boot-2</artifactId>
|
<artifactId>parent-boot-2</artifactId>
|
||||||
|
|
|
@ -4,8 +4,8 @@
|
||||||
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<artifactId>jhipster-uaa</artifactId>
|
<artifactId>jhipster-uaa</artifactId>
|
||||||
<name>jhipster-uaa</name>
|
|
||||||
<packaging>pom</packaging>
|
<packaging>pom</packaging>
|
||||||
|
<name>jhipster-uaa</name>
|
||||||
|
|
||||||
<parent>
|
<parent>
|
||||||
<artifactId>jhipster-modules</artifactId>
|
<artifactId>jhipster-modules</artifactId>
|
||||||
|
|
|
@ -6,8 +6,8 @@
|
||||||
<groupId>com.baeldung.jhipster</groupId>
|
<groupId>com.baeldung.jhipster</groupId>
|
||||||
<artifactId>jhipster-modules</artifactId>
|
<artifactId>jhipster-modules</artifactId>
|
||||||
<version>1.0.0-SNAPSHOT</version>
|
<version>1.0.0-SNAPSHOT</version>
|
||||||
<name>jhipster-modules</name>
|
|
||||||
<packaging>pom</packaging>
|
<packaging>pom</packaging>
|
||||||
|
<name>jhipster-modules</name>
|
||||||
|
|
||||||
<parent>
|
<parent>
|
||||||
<!-- Jhipster project is autogenerated and upgrading it will need a newly generated project.
|
<!-- Jhipster project is autogenerated and upgrading it will need a newly generated project.
|
||||||
|
|
|
@ -4,8 +4,8 @@
|
||||||
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
|
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<artifactId>jmh</artifactId>
|
<artifactId>jmh</artifactId>
|
||||||
<name>jmh</name>
|
|
||||||
<packaging>jar</packaging>
|
<packaging>jar</packaging>
|
||||||
|
<name>jmh</name>
|
||||||
|
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>com.baeldung</groupId>
|
<groupId>com.baeldung</groupId>
|
||||||
|
|
|
@ -29,6 +29,11 @@
|
||||||
<artifactId>jackson-databind</artifactId>
|
<artifactId>jackson-databind</artifactId>
|
||||||
<version>${jackson.version}</version>
|
<version>${jackson.version}</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.apache.poi</groupId>
|
||||||
|
<artifactId>poi-ooxml</artifactId>
|
||||||
|
<version>5.2.3</version>
|
||||||
|
</dependency>
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>com.google.guava</groupId>
|
<groupId>com.google.guava</groupId>
|
||||||
<artifactId>guava</artifactId>
|
<artifactId>guava</artifactId>
|
||||||
|
|
|
@ -0,0 +1,84 @@
|
||||||
|
package com.baeldung.exceltojson;
|
||||||
|
|
||||||
|
import com.fasterxml.jackson.core.JsonProcessingException;
|
||||||
|
import com.fasterxml.jackson.databind.ObjectMapper;
|
||||||
|
import org.apache.poi.ss.usermodel.*;
|
||||||
|
import org.apache.poi.xssf.usermodel.XSSFWorkbook;
|
||||||
|
import org.json.JSONArray;
|
||||||
|
import org.junit.Test;
|
||||||
|
|
||||||
|
import java.io.FileInputStream;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.io.InputStream;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Objects;
|
||||||
|
|
||||||
|
import static org.junit.Assert.assertEquals;
|
||||||
|
|
||||||
|
public class ExcelToJsonUnitTest {
|
||||||
|
public static String filePath = Objects.requireNonNull(ExcelToJsonUnitTest.class.getClassLoader().getResource("Book1.xlsx")).getFile();
|
||||||
|
public String expectedJson = "[[\"C1\",\"C2\",\"C3\",\"C4\",\"C5\"]," +
|
||||||
|
"[\"1.0\",\"2.0\",\"3.0\",\"4.0\",\"5.0\"]," +
|
||||||
|
"[\"1.0\",\"2.0\",\"3.0\",\"4.0\",\"5.0\"]," +
|
||||||
|
"[\"1.0\",\"2.0\",\"3.0\",\"4.0\",\"5.0\"]," +
|
||||||
|
"[\"1.0\",\"2.0\",\"3.0\",\"4.0\",\"5.0\"]]";
|
||||||
|
private Workbook workbook;
|
||||||
|
private Sheet sheet;
|
||||||
|
private InputStream inputStream;
|
||||||
|
|
||||||
|
public ExcelToJsonUnitTest() throws IOException {
|
||||||
|
inputStream = new FileInputStream(filePath);
|
||||||
|
workbook = new XSSFWorkbook(inputStream);
|
||||||
|
sheet = workbook.getSheetAt(0);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void givenExcelFile_whenUsingApachePOIConversion_thenConvertToJson() {
|
||||||
|
JSONArray jsonArray = new JSONArray();
|
||||||
|
|
||||||
|
Row headerRow = sheet.getRow(0);
|
||||||
|
List<String> headers = new ArrayList<>();
|
||||||
|
for (Cell cell : headerRow) {
|
||||||
|
headers.add(cell.toString());
|
||||||
|
}
|
||||||
|
jsonArray.put(headers);
|
||||||
|
|
||||||
|
for (int i = 1; i <= sheet.getLastRowNum(); i++) {
|
||||||
|
Row row = sheet.getRow(i);
|
||||||
|
List<String> rowData = new ArrayList<>();
|
||||||
|
for (Cell cell : row) {
|
||||||
|
rowData.add(cell.toString());
|
||||||
|
}
|
||||||
|
jsonArray.put(rowData);
|
||||||
|
}
|
||||||
|
|
||||||
|
assertEquals(expectedJson, jsonArray.toString());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void givenExcelFile_whenUsingJacksonConversion_thenConvertToJson() throws JsonProcessingException {
|
||||||
|
List<List<String>> data = new ArrayList<>();
|
||||||
|
|
||||||
|
Row headerRow = sheet.getRow(0);
|
||||||
|
List<String> headers = new ArrayList<>();
|
||||||
|
for (Cell cell : headerRow) {
|
||||||
|
headers.add(cell.toString());
|
||||||
|
}
|
||||||
|
data.add(headers);
|
||||||
|
|
||||||
|
for (int i = 1; i <= sheet.getLastRowNum(); i++) {
|
||||||
|
Row row = sheet.getRow(i);
|
||||||
|
List<String> rowData = new ArrayList<>();
|
||||||
|
for (Cell cell : row) {
|
||||||
|
rowData.add(cell.toString());
|
||||||
|
}
|
||||||
|
data.add(rowData);
|
||||||
|
}
|
||||||
|
|
||||||
|
ObjectMapper objectMapper = new ObjectMapper();
|
||||||
|
String json = objectMapper.writeValueAsString(data);
|
||||||
|
|
||||||
|
assertEquals(expectedJson, json);
|
||||||
|
}
|
||||||
|
}
|
Binary file not shown.
|
@ -4,8 +4,8 @@
|
||||||
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<artifactId>json-modules</artifactId>
|
<artifactId>json-modules</artifactId>
|
||||||
<name>json-modules</name>
|
|
||||||
<packaging>pom</packaging>
|
<packaging>pom</packaging>
|
||||||
|
<name>json-modules</name>
|
||||||
|
|
||||||
<parent>
|
<parent>
|
||||||
<artifactId>parent-modules</artifactId>
|
<artifactId>parent-modules</artifactId>
|
||||||
|
|
|
@ -4,8 +4,8 @@
|
||||||
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<artifactId>jsoup</artifactId>
|
<artifactId>jsoup</artifactId>
|
||||||
<name>jsoup</name>
|
|
||||||
<packaging>jar</packaging>
|
<packaging>jar</packaging>
|
||||||
|
<name>jsoup</name>
|
||||||
|
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>com.baeldung</groupId>
|
<groupId>com.baeldung</groupId>
|
||||||
|
|
|
@ -4,8 +4,8 @@
|
||||||
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
|
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<artifactId>jws</artifactId>
|
<artifactId>jws</artifactId>
|
||||||
<name>jws</name>
|
|
||||||
<packaging>war</packaging>
|
<packaging>war</packaging>
|
||||||
|
<name>jws</name>
|
||||||
|
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>com.baeldung</groupId>
|
<groupId>com.baeldung</groupId>
|
||||||
|
|
|
@ -5,8 +5,8 @@
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<artifactId>k8s-operator</artifactId>
|
<artifactId>k8s-operator</artifactId>
|
||||||
<version>0.1.0-SNAPSHOT</version>
|
<version>0.1.0-SNAPSHOT</version>
|
||||||
<name>k8s-operator</name>
|
|
||||||
<packaging>jar</packaging>
|
<packaging>jar</packaging>
|
||||||
|
<name>k8s-operator</name>
|
||||||
|
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>com.baeldung</groupId>
|
<groupId>com.baeldung</groupId>
|
||||||
|
|
|
@ -5,8 +5,8 @@
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<artifactId>libraries-bytecode</artifactId>
|
<artifactId>libraries-bytecode</artifactId>
|
||||||
<version>0.0.1-SNAPSHOT</version>
|
<version>0.0.1-SNAPSHOT</version>
|
||||||
<name>libraries-bytecode</name>
|
|
||||||
<packaging>jar</packaging>
|
<packaging>jar</packaging>
|
||||||
|
<name>libraries-bytecode</name>
|
||||||
|
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>com.baeldung</groupId>
|
<groupId>com.baeldung</groupId>
|
||||||
|
|
|
@ -5,8 +5,8 @@
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<artifactId>libraries-cli</artifactId>
|
<artifactId>libraries-cli</artifactId>
|
||||||
<version>0.0.1-SNAPSHOT</version>
|
<version>0.0.1-SNAPSHOT</version>
|
||||||
<name>libraries-cli</name>
|
|
||||||
<packaging>jar</packaging>
|
<packaging>jar</packaging>
|
||||||
|
<name>libraries-cli</name>
|
||||||
|
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>com.baeldung</groupId>
|
<groupId>com.baeldung</groupId>
|
||||||
|
|
|
@ -121,7 +121,6 @@
|
||||||
<artifactId>flexy-micrometer-metrics</artifactId>
|
<artifactId>flexy-micrometer-metrics</artifactId>
|
||||||
<version>${flexy-pool.version}</version>
|
<version>${flexy-pool.version}</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>com.vladmihalcea.flexy-pool</groupId>
|
<groupId>com.vladmihalcea.flexy-pool</groupId>
|
||||||
<artifactId>flexy-hikaricp</artifactId>
|
<artifactId>flexy-hikaricp</artifactId>
|
||||||
|
|
|
@ -3,15 +3,15 @@
|
||||||
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
|
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
|
||||||
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
|
<artifactId>libraries-data-io-2</artifactId>
|
||||||
|
<name>libraries-data-io-3</name>
|
||||||
|
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>com.baeldung</groupId>
|
<groupId>com.baeldung</groupId>
|
||||||
<artifactId>parent-modules</artifactId>
|
<artifactId>parent-modules</artifactId>
|
||||||
<version>1.0.0-SNAPSHOT</version>
|
<version>1.0.0-SNAPSHOT</version>
|
||||||
</parent>
|
</parent>
|
||||||
|
|
||||||
<artifactId>libraries-data-io-2</artifactId>
|
|
||||||
<name>libraries-data-io-3</name>
|
|
||||||
|
|
||||||
<properties>
|
<properties>
|
||||||
<maven.compiler.source>19</maven.compiler.source>
|
<maven.compiler.source>19</maven.compiler.source>
|
||||||
<maven.compiler.target>19</maven.compiler.target>
|
<maven.compiler.target>19</maven.compiler.target>
|
||||||
|
|
|
@ -165,7 +165,6 @@
|
||||||
<artifactId>javax.persistence-api</artifactId>
|
<artifactId>javax.persistence-api</artifactId>
|
||||||
<version>2.2</version>
|
<version>2.2</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
</dependencies>
|
</dependencies>
|
||||||
|
|
||||||
<build>
|
<build>
|
||||||
|
|
|
@ -5,8 +5,8 @@
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<artifactId>libraries-reporting</artifactId>
|
<artifactId>libraries-reporting</artifactId>
|
||||||
<version>0.0.1-SNAPSHOT</version>
|
<version>0.0.1-SNAPSHOT</version>
|
||||||
<name>libraries-reporting</name>
|
|
||||||
<packaging>jar</packaging>
|
<packaging>jar</packaging>
|
||||||
|
<name>libraries-reporting</name>
|
||||||
|
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>com.baeldung</groupId>
|
<groupId>com.baeldung</groupId>
|
||||||
|
|
|
@ -4,8 +4,8 @@
|
||||||
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
|
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<artifactId>libraries-rpc</artifactId>
|
<artifactId>libraries-rpc</artifactId>
|
||||||
<name>libraries-rpc</name>
|
|
||||||
<packaging>jar</packaging>
|
<packaging>jar</packaging>
|
||||||
|
<name>libraries-rpc</name>
|
||||||
|
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>com.baeldung</groupId>
|
<groupId>com.baeldung</groupId>
|
||||||
|
|
|
@ -4,8 +4,8 @@
|
||||||
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<artifactId>libraries-security</artifactId>
|
<artifactId>libraries-security</artifactId>
|
||||||
<name>libraries-security</name>
|
|
||||||
<packaging>jar</packaging>
|
<packaging>jar</packaging>
|
||||||
|
<name>libraries-security</name>
|
||||||
|
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>com.baeldung</groupId>
|
<groupId>com.baeldung</groupId>
|
||||||
|
|
|
@ -5,8 +5,8 @@
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<artifactId>libraries-server-2</artifactId>
|
<artifactId>libraries-server-2</artifactId>
|
||||||
<version>0.0.1-SNAPSHOT</version>
|
<version>0.0.1-SNAPSHOT</version>
|
||||||
<name>libraries-server-2</name>
|
|
||||||
<packaging>war</packaging>
|
<packaging>war</packaging>
|
||||||
|
<name>libraries-server-2</name>
|
||||||
|
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>com.baeldung</groupId>
|
<groupId>com.baeldung</groupId>
|
||||||
|
@ -35,7 +35,6 @@
|
||||||
<artifactId>netty-all</artifactId>
|
<artifactId>netty-all</artifactId>
|
||||||
<version>${netty.version}</version>
|
<version>${netty.version}</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
</dependencies>
|
</dependencies>
|
||||||
|
|
||||||
<build>
|
<build>
|
||||||
|
|
|
@ -5,8 +5,8 @@
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<artifactId>libraries-stream</artifactId>
|
<artifactId>libraries-stream</artifactId>
|
||||||
<version>0.0.1-SNAPSHOT</version>
|
<version>0.0.1-SNAPSHOT</version>
|
||||||
<name>libraries-stream</name>
|
|
||||||
<packaging>jar</packaging>
|
<packaging>jar</packaging>
|
||||||
|
<name>libraries-stream</name>
|
||||||
|
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>com.baeldung</groupId>
|
<groupId>com.baeldung</groupId>
|
||||||
|
|
|
@ -17,7 +17,6 @@
|
||||||
<artifactId>spoon-core</artifactId>
|
<artifactId>spoon-core</artifactId>
|
||||||
<version>${spoon-core.version}</version>
|
<version>${spoon-core.version}</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
</dependencies>
|
</dependencies>
|
||||||
|
|
||||||
<properties>
|
<properties>
|
||||||
|
|
|
@ -6,9 +6,9 @@
|
||||||
<groupId>com.baelduung</groupId>
|
<groupId>com.baelduung</groupId>
|
||||||
<artifactId>lightrun</artifactId>
|
<artifactId>lightrun</artifactId>
|
||||||
<version>0.0.1-SNAPSHOT</version>
|
<version>0.0.1-SNAPSHOT</version>
|
||||||
|
<packaging>pom</packaging>
|
||||||
<name>lightrun</name>
|
<name>lightrun</name>
|
||||||
<description>Services for LightRun Article</description>
|
<description>Services for LightRun Article</description>
|
||||||
<packaging>pom</packaging>
|
|
||||||
|
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>com.baeldung</groupId>
|
<groupId>com.baeldung</groupId>
|
||||||
|
|
|
@ -5,8 +5,8 @@
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<artifactId>log-mdc</artifactId>
|
<artifactId>log-mdc</artifactId>
|
||||||
<version>0.0.1-SNAPSHOT</version>
|
<version>0.0.1-SNAPSHOT</version>
|
||||||
<name>log-mdc</name>
|
|
||||||
<packaging>war</packaging>
|
<packaging>war</packaging>
|
||||||
|
<name>log-mdc</name>
|
||||||
<description>tutorial on logging with MDC and NDC</description>
|
<description>tutorial on logging with MDC and NDC</description>
|
||||||
|
|
||||||
<parent>
|
<parent>
|
||||||
|
|
|
@ -4,8 +4,8 @@
|
||||||
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<artifactId>lombok-custom</artifactId>
|
<artifactId>lombok-custom</artifactId>
|
||||||
<version>0.1-SNAPSHOT</version>
|
|
||||||
<name>lombok-custom</name>
|
<name>lombok-custom</name>
|
||||||
|
<version>0.1-SNAPSHOT</version>
|
||||||
|
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>com.baeldung</groupId>
|
<groupId>com.baeldung</groupId>
|
||||||
|
|
|
@ -5,8 +5,8 @@
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<artifactId>lombok-modules</artifactId>
|
<artifactId>lombok-modules</artifactId>
|
||||||
<version>1.0.0-SNAPSHOT</version>
|
<version>1.0.0-SNAPSHOT</version>
|
||||||
<name>lombok-modules</name>
|
|
||||||
<packaging>pom</packaging>
|
<packaging>pom</packaging>
|
||||||
|
<name>lombok-modules</name>
|
||||||
|
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>com.baeldung</groupId>
|
<groupId>com.baeldung</groupId>
|
||||||
|
|
|
@ -5,8 +5,8 @@
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<artifactId>mapstruct</artifactId>
|
<artifactId>mapstruct</artifactId>
|
||||||
<version>1.0</version>
|
<version>1.0</version>
|
||||||
<name>mapstruct</name>
|
|
||||||
<packaging>jar</packaging>
|
<packaging>jar</packaging>
|
||||||
|
<name>mapstruct</name>
|
||||||
|
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>com.baeldung</groupId>
|
<groupId>com.baeldung</groupId>
|
||||||
|
|
|
@ -5,8 +5,8 @@
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<artifactId>animal-sniffer-mvn-plugin</artifactId>
|
<artifactId>animal-sniffer-mvn-plugin</artifactId>
|
||||||
<version>1.0-SNAPSHOT</version>
|
<version>1.0-SNAPSHOT</version>
|
||||||
<name>animal-sniffer-mvn-plugin</name>
|
|
||||||
<packaging>jar</packaging>
|
<packaging>jar</packaging>
|
||||||
|
<name>animal-sniffer-mvn-plugin</name>
|
||||||
<url>http://maven.apache.org</url>
|
<url>http://maven.apache.org</url>
|
||||||
|
|
||||||
<parent>
|
<parent>
|
||||||
|
|
|
@ -4,8 +4,8 @@
|
||||||
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<artifactId>core-java-exclusions</artifactId>
|
<artifactId>core-java-exclusions</artifactId>
|
||||||
<name>core-java-exclusions</name>
|
|
||||||
<packaging>jar</packaging>
|
<packaging>jar</packaging>
|
||||||
|
<name>core-java-exclusions</name>
|
||||||
|
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>com.baeldung.dependency-exclusion</groupId>
|
<groupId>com.baeldung.dependency-exclusion</groupId>
|
||||||
|
@ -19,7 +19,6 @@
|
||||||
<artifactId>junit</artifactId>
|
<artifactId>junit</artifactId>
|
||||||
<scope>test</scope>
|
<scope>test</scope>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
</dependencies>
|
</dependencies>
|
||||||
|
|
||||||
<build>
|
<build>
|
||||||
|
|
|
@ -5,8 +5,8 @@
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<groupId>com.baeldung.dependency-exclusion</groupId>
|
<groupId>com.baeldung.dependency-exclusion</groupId>
|
||||||
<artifactId>dependency-exclusion</artifactId>
|
<artifactId>dependency-exclusion</artifactId>
|
||||||
<name>dependency-exclusion</name>
|
|
||||||
<packaging>pom</packaging>
|
<packaging>pom</packaging>
|
||||||
|
<name>dependency-exclusion</name>
|
||||||
|
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>com.baeldung</groupId>
|
<groupId>com.baeldung</groupId>
|
||||||
|
|
|
@ -5,8 +5,8 @@
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<groupId>com.baeldung.jacoco-coverage-aggregation</groupId>
|
<groupId>com.baeldung.jacoco-coverage-aggregation</groupId>
|
||||||
<artifactId>jacoco-coverage-aggregate-report</artifactId>
|
<artifactId>jacoco-coverage-aggregate-report</artifactId>
|
||||||
<name>jacoco-coverage-aggregate-report</name>
|
|
||||||
<packaging>pom</packaging>
|
<packaging>pom</packaging>
|
||||||
|
<name>jacoco-coverage-aggregate-report</name>
|
||||||
|
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>com.baeldung</groupId>
|
<groupId>com.baeldung</groupId>
|
||||||
|
|
|
@ -5,8 +5,8 @@
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<groupId>com.baeldung.jacoco-coverage-aggregation</groupId>
|
<groupId>com.baeldung.jacoco-coverage-aggregation</groupId>
|
||||||
<artifactId>jacoco-coverage-controllers-example</artifactId>
|
<artifactId>jacoco-coverage-controllers-example</artifactId>
|
||||||
<name>jacoco-coverage-controllers-example</name>
|
|
||||||
<packaging>jar</packaging>
|
<packaging>jar</packaging>
|
||||||
|
<name>jacoco-coverage-controllers-example</name>
|
||||||
|
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>com.baeldung</groupId>
|
<groupId>com.baeldung</groupId>
|
||||||
|
|
|
@ -5,8 +5,8 @@
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<groupId>com.baeldung.jacoco-coverage-aggregation</groupId>
|
<groupId>com.baeldung.jacoco-coverage-aggregation</groupId>
|
||||||
<artifactId>jacoco-coverage-services-example</artifactId>
|
<artifactId>jacoco-coverage-services-example</artifactId>
|
||||||
<name>jacoco-coverage-services-example</name>
|
|
||||||
<packaging>jar</packaging>
|
<packaging>jar</packaging>
|
||||||
|
<name>jacoco-coverage-services-example</name>
|
||||||
|
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>com.baeldung</groupId>
|
<groupId>com.baeldung</groupId>
|
||||||
|
|
|
@ -5,8 +5,8 @@
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<artifactId>jacoco-coverage-aggregation</artifactId>
|
<artifactId>jacoco-coverage-aggregation</artifactId>
|
||||||
<version>1.0</version>
|
<version>1.0</version>
|
||||||
<name>jacoco-coverage-aggregation</name>
|
|
||||||
<packaging>pom</packaging>
|
<packaging>pom</packaging>
|
||||||
|
<name>jacoco-coverage-aggregation</name>
|
||||||
|
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>com.baeldung</groupId>
|
<groupId>com.baeldung</groupId>
|
||||||
|
|
|
@ -6,8 +6,8 @@
|
||||||
<groupId>com.baeldung.archetypes</groupId>
|
<groupId>com.baeldung.archetypes</groupId>
|
||||||
<artifactId>maven-archetype</artifactId>
|
<artifactId>maven-archetype</artifactId>
|
||||||
<version>1.0-SNAPSHOT</version>
|
<version>1.0-SNAPSHOT</version>
|
||||||
<name>maven-archetype</name>
|
|
||||||
<packaging>maven-archetype</packaging>
|
<packaging>maven-archetype</packaging>
|
||||||
|
<name>maven-archetype</name>
|
||||||
<description>Archetype used to generate rest application based on jaxrs 2.1</description>
|
<description>Archetype used to generate rest application based on jaxrs 2.1</description>
|
||||||
|
|
||||||
<build>
|
<build>
|
||||||
|
|
|
@ -3,19 +3,14 @@
|
||||||
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
|
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
|
||||||
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
|
<artifactId>maven-build-lifecycle</artifactId>
|
||||||
|
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>com.baeldung</groupId>
|
<groupId>com.baeldung</groupId>
|
||||||
<artifactId>maven-modules</artifactId>
|
<artifactId>maven-modules</artifactId>
|
||||||
<version>0.0.1-SNAPSHOT</version>
|
<version>0.0.1-SNAPSHOT</version>
|
||||||
</parent>
|
</parent>
|
||||||
|
|
||||||
<artifactId>maven-build-lifecycle</artifactId>
|
|
||||||
|
|
||||||
<properties>
|
|
||||||
<maven.surefire.version>3.1.2</maven.surefire.version>
|
|
||||||
<maven.failsafe.version>3.1.2</maven.failsafe.version>
|
|
||||||
<junit.jupiter.version>5.3.1</junit.jupiter.version>
|
|
||||||
</properties>
|
|
||||||
<build>
|
<build>
|
||||||
<plugins>
|
<plugins>
|
||||||
<!-- Maven Surefire Plugin for unit tests -->
|
<!-- Maven Surefire Plugin for unit tests -->
|
||||||
|
@ -49,4 +44,10 @@
|
||||||
</plugins>
|
</plugins>
|
||||||
</build>
|
</build>
|
||||||
|
|
||||||
|
<properties>
|
||||||
|
<maven.surefire.version>3.1.2</maven.surefire.version>
|
||||||
|
<maven.failsafe.version>3.1.2</maven.failsafe.version>
|
||||||
|
<junit.jupiter.version>5.3.1</junit.jupiter.version>
|
||||||
|
</properties>
|
||||||
|
|
||||||
</project>
|
</project>
|
|
@ -5,8 +5,8 @@
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<artifactId>maven-build-optimization</artifactId>
|
<artifactId>maven-build-optimization</artifactId>
|
||||||
<version>0.0.1-SNAPSHOT</version>
|
<version>0.0.1-SNAPSHOT</version>
|
||||||
<name>maven-build-optimization</name>
|
|
||||||
<packaging>pom</packaging>
|
<packaging>pom</packaging>
|
||||||
|
<name>maven-build-optimization</name>
|
||||||
|
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>com.baeldung</groupId>
|
<groupId>com.baeldung</groupId>
|
||||||
|
|
|
@ -5,8 +5,8 @@
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<artifactId>maven-copy-files</artifactId>
|
<artifactId>maven-copy-files</artifactId>
|
||||||
<version>1.0-SNAPSHOT</version>
|
<version>1.0-SNAPSHOT</version>
|
||||||
<name>maven-copy-files</name>
|
|
||||||
<packaging>pom</packaging>
|
<packaging>pom</packaging>
|
||||||
|
<name>maven-copy-files</name>
|
||||||
<!-- FIXME change it to the project's website -->
|
<!-- FIXME change it to the project's website -->
|
||||||
<url>http://www.example.com</url>
|
<url>http://www.example.com</url>
|
||||||
|
|
||||||
|
|
|
@ -6,8 +6,8 @@
|
||||||
<groupId>com.baeldung</groupId>
|
<groupId>com.baeldung</groupId>
|
||||||
<artifactId>counter-maven-plugin</artifactId>
|
<artifactId>counter-maven-plugin</artifactId>
|
||||||
<version>0.0.1-SNAPSHOT</version>
|
<version>0.0.1-SNAPSHOT</version>
|
||||||
<name>counter-maven-plugin</name>
|
|
||||||
<packaging>maven-plugin</packaging>
|
<packaging>maven-plugin</packaging>
|
||||||
|
<name>counter-maven-plugin</name>
|
||||||
<url>http://maven.apache.org</url>
|
<url>http://maven.apache.org</url>
|
||||||
|
|
||||||
<organization>
|
<organization>
|
||||||
|
|
|
@ -5,8 +5,8 @@
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<artifactId>maven-custom-plugin</artifactId>
|
<artifactId>maven-custom-plugin</artifactId>
|
||||||
<version>0.0.1-SNAPSHOT</version>
|
<version>0.0.1-SNAPSHOT</version>
|
||||||
<name>maven-custom-plugin</name>
|
|
||||||
<packaging>pom</packaging>
|
<packaging>pom</packaging>
|
||||||
|
<name>maven-custom-plugin</name>
|
||||||
|
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>com.baeldung</groupId>
|
<groupId>com.baeldung</groupId>
|
||||||
|
|
|
@ -5,8 +5,8 @@
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<artifactId>maven-generate-war</artifactId>
|
<artifactId>maven-generate-war</artifactId>
|
||||||
<version>0.0.1-SNAPSHOT</version>
|
<version>0.0.1-SNAPSHOT</version>
|
||||||
<name>maven-generate-war</name>
|
|
||||||
<packaging>war</packaging>
|
<packaging>war</packaging>
|
||||||
|
<name>maven-generate-war</name>
|
||||||
<description>Spring boot project to demonstrate war file generation</description>
|
<description>Spring boot project to demonstrate war file generation</description>
|
||||||
|
|
||||||
<parent>
|
<parent>
|
||||||
|
|
|
@ -5,8 +5,8 @@
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<artifactId>maven-integration-test</artifactId>
|
<artifactId>maven-integration-test</artifactId>
|
||||||
<version>0.0.1-SNAPSHOT</version>
|
<version>0.0.1-SNAPSHOT</version>
|
||||||
<name>maven-integration-test</name>
|
|
||||||
<packaging>war</packaging>
|
<packaging>war</packaging>
|
||||||
|
<name>maven-integration-test</name>
|
||||||
|
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>com.baeldung</groupId>
|
<groupId>com.baeldung</groupId>
|
||||||
|
|
|
@ -5,8 +5,8 @@
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<artifactId>maven-polyglot</artifactId>
|
<artifactId>maven-polyglot</artifactId>
|
||||||
<version>0.0.1-SNAPSHOT</version>
|
<version>0.0.1-SNAPSHOT</version>
|
||||||
<name>maven-polyglot</name>
|
|
||||||
<packaging>pom</packaging>
|
<packaging>pom</packaging>
|
||||||
|
<name>maven-polyglot</name>
|
||||||
|
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>com.baeldung</groupId>
|
<groupId>com.baeldung</groupId>
|
||||||
|
|
|
@ -6,11 +6,13 @@
|
||||||
<artifactId>patient-web</artifactId>
|
<artifactId>patient-web</artifactId>
|
||||||
<version>1.0-SNAPSHOT</version>
|
<version>1.0-SNAPSHOT</version>
|
||||||
<name>patient-web</name>
|
<name>patient-web</name>
|
||||||
|
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>com.baeldung</groupId>
|
<groupId>com.baeldung</groupId>
|
||||||
<artifactId>maven-reactor</artifactId>
|
<artifactId>maven-reactor</artifactId>
|
||||||
<version>1.0-SNAPSHOT</version>
|
<version>1.0-SNAPSHOT</version>
|
||||||
</parent>
|
</parent>
|
||||||
|
|
||||||
<dependencies>
|
<dependencies>
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>com.baeldung</groupId>
|
<groupId>com.baeldung</groupId>
|
||||||
|
|
|
@ -85,7 +85,7 @@
|
||||||
<properties>
|
<properties>
|
||||||
<dropwizard.metrics.version>4.2.17</dropwizard.metrics.version>
|
<dropwizard.metrics.version>4.2.17</dropwizard.metrics.version>
|
||||||
<netflix.servo.version>0.13.2</netflix.servo.version>
|
<netflix.servo.version>0.13.2</netflix.servo.version>
|
||||||
<micrometer-registry-atlas.version>1.11.0</micrometer-registry-atlas.version>
|
<micrometer-registry-atlas.version>1.12.3</micrometer-registry-atlas.version>
|
||||||
<spring-boot-starter-web.version>3.1.0</spring-boot-starter-web.version>
|
<spring-boot-starter-web.version>3.1.0</spring-boot-starter-web.version>
|
||||||
<metrics-aspectj-deps.version>1.2.0</metrics-aspectj-deps.version>
|
<metrics-aspectj-deps.version>1.2.0</metrics-aspectj-deps.version>
|
||||||
<spectator-api.version>1.7.7</spectator-api.version>
|
<spectator-api.version>1.7.7</spectator-api.version>
|
||||||
|
|
|
@ -9,7 +9,9 @@ import static org.junit.Assert.assertSame;
|
||||||
|
|
||||||
import jakarta.persistence.PersistenceException;
|
import jakarta.persistence.PersistenceException;
|
||||||
|
|
||||||
|
import org.h2.tools.RunScript;
|
||||||
import org.hibernate.HibernateException;
|
import org.hibernate.HibernateException;
|
||||||
|
import org.hibernate.ReplicationMode;
|
||||||
import org.hibernate.Session;
|
import org.hibernate.Session;
|
||||||
import org.hibernate.SessionFactory;
|
import org.hibernate.SessionFactory;
|
||||||
import org.hibernate.boot.registry.StandardServiceRegistryBuilder;
|
import org.hibernate.boot.registry.StandardServiceRegistryBuilder;
|
||||||
|
@ -24,35 +26,58 @@ import org.junit.Test;
|
||||||
|
|
||||||
import com.baeldung.persistence.model.Person;
|
import com.baeldung.persistence.model.Person;
|
||||||
|
|
||||||
|
import java.io.InputStream;
|
||||||
|
import java.io.InputStreamReader;
|
||||||
|
import java.sql.Connection;
|
||||||
|
import java.sql.DriverManager;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Testing specific implementation details for different methods:
|
* Testing specific implementation details for different methods:
|
||||||
* persist, save, merge, update, saveOrUpdate.
|
* persist, save, merge, update, saveOrUpdate, refresh, replicate
|
||||||
*/
|
*/
|
||||||
public class SaveMethodsIntegrationTest {
|
public class SaveMethodsIntegrationTest {
|
||||||
|
|
||||||
private static SessionFactory sessionFactory;
|
private static SessionFactory sessionFactory1;
|
||||||
|
|
||||||
private Session session;
|
private static SessionFactory sessionFactory2;
|
||||||
|
|
||||||
|
private Session session1;
|
||||||
|
|
||||||
|
private Session session2;
|
||||||
private boolean doNotCommit = false;
|
private boolean doNotCommit = false;
|
||||||
|
|
||||||
@BeforeClass
|
private static SessionFactory createSessionFactoryAndInitializeDBs(String dbUrl) throws Exception {
|
||||||
public static void beforeTests() {
|
|
||||||
Configuration configuration = new Configuration().addAnnotatedClass(Person.class)
|
Configuration configuration = new Configuration().addAnnotatedClass(Person.class)
|
||||||
.setProperty("hibernate.dialect", HSQLDialect.class.getName())
|
.setProperty("hibernate.dialect", HSQLDialect.class.getName())
|
||||||
.setProperty("hibernate.connection.driver_class", org.hsqldb.jdbcDriver.class.getName())
|
.setProperty("hibernate.connection.driver_class", org.hsqldb.jdbcDriver.class.getName())
|
||||||
.setProperty("hibernate.connection.url", "jdbc:hsqldb:mem:test")
|
.setProperty("hibernate.connection.url", dbUrl)
|
||||||
.setProperty("hibernate.connection.username", "sa")
|
.setProperty("hibernate.connection.username", "sa")
|
||||||
.setProperty("hibernate.connection.password", "")
|
.setProperty("hibernate.connection.password", "")
|
||||||
.setProperty("hibernate.hbm2ddl.auto", "update");
|
.setProperty("hibernate.hbm2ddl.auto", "update");
|
||||||
|
Connection connection = DriverManager.getConnection(dbUrl, "sa", "");
|
||||||
ServiceRegistry serviceRegistry = new StandardServiceRegistryBuilder().applySettings(configuration.getProperties())
|
ServiceRegistry serviceRegistry = new StandardServiceRegistryBuilder().applySettings(configuration.getProperties())
|
||||||
.build();
|
.build();
|
||||||
sessionFactory = configuration.buildSessionFactory(serviceRegistry);
|
SessionFactory sf = configuration.buildSessionFactory(serviceRegistry);
|
||||||
|
try (InputStream h2InitStream = Thread.currentThread().getContextClassLoader().getResourceAsStream("h2-trigger.sql")) {
|
||||||
|
assert h2InitStream != null;
|
||||||
|
try (InputStreamReader h2InitReader = new InputStreamReader(h2InitStream)) {
|
||||||
|
RunScript.execute(connection, h2InitReader);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return sf;
|
||||||
|
}
|
||||||
|
@BeforeClass
|
||||||
|
public static void beforeTests() throws Exception{
|
||||||
|
sessionFactory1 = createSessionFactoryAndInitializeDBs("jdbc:hsqldb:mem:test");
|
||||||
|
sessionFactory2 = createSessionFactoryAndInitializeDBs("jdbc:hsqldb:mem:test2");
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Before
|
@Before
|
||||||
public void setUp() {
|
public void setUp() throws Exception {
|
||||||
session = sessionFactory.openSession();
|
session1 = sessionFactory1.openSession();
|
||||||
session.beginTransaction();
|
session1.beginTransaction();
|
||||||
|
|
||||||
doNotCommit = false;
|
doNotCommit = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -61,16 +86,16 @@ public class SaveMethodsIntegrationTest {
|
||||||
|
|
||||||
Person person = new Person();
|
Person person = new Person();
|
||||||
person.setName("John");
|
person.setName("John");
|
||||||
session.persist(person);
|
session1.persist(person);
|
||||||
|
|
||||||
session.getTransaction()
|
session1.getTransaction()
|
||||||
.commit();
|
.commit();
|
||||||
session.close();
|
session1.close();
|
||||||
|
|
||||||
session = sessionFactory.openSession();
|
session1 = sessionFactory1.openSession();
|
||||||
session.beginTransaction();
|
session1.beginTransaction();
|
||||||
|
|
||||||
assertNotNull(session.get(Person.class, person.getId()));
|
assertNotNull(session1.get(Person.class, person.getId()));
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -80,10 +105,10 @@ public class SaveMethodsIntegrationTest {
|
||||||
Person person = new Person();
|
Person person = new Person();
|
||||||
person.setName("John");
|
person.setName("John");
|
||||||
|
|
||||||
session.persist(person);
|
session1.persist(person);
|
||||||
Long id1 = person.getId();
|
Long id1 = person.getId();
|
||||||
|
|
||||||
session.persist(person);
|
session1.persist(person);
|
||||||
Long id2 = person.getId();
|
Long id2 = person.getId();
|
||||||
|
|
||||||
assertEquals(id1, id2);
|
assertEquals(id1, id2);
|
||||||
|
@ -96,10 +121,10 @@ public class SaveMethodsIntegrationTest {
|
||||||
|
|
||||||
Person person = new Person();
|
Person person = new Person();
|
||||||
person.setName("John");
|
person.setName("John");
|
||||||
session.persist(person);
|
session1.persist(person);
|
||||||
session.evict(person);
|
session1.evict(person);
|
||||||
|
|
||||||
session.persist(person);
|
session1.persist(person);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
@ -107,12 +132,12 @@ public class SaveMethodsIntegrationTest {
|
||||||
|
|
||||||
Person person = new Person();
|
Person person = new Person();
|
||||||
person.setName("John");
|
person.setName("John");
|
||||||
session.save(person);
|
session1.save(person);
|
||||||
session.flush();
|
session1.flush();
|
||||||
session.evict(person);
|
session1.evict(person);
|
||||||
|
|
||||||
person.setName("Mary");
|
person.setName("Mary");
|
||||||
Person mergedPerson = (Person) session.merge(person);
|
Person mergedPerson = (Person) session1.merge(person);
|
||||||
|
|
||||||
assertNotSame(person, mergedPerson);
|
assertNotSame(person, mergedPerson);
|
||||||
assertEquals("Mary", mergedPerson.getName());
|
assertEquals("Mary", mergedPerson.getName());
|
||||||
|
@ -127,20 +152,20 @@ public class SaveMethodsIntegrationTest {
|
||||||
|
|
||||||
assertNull(person.getId());
|
assertNull(person.getId());
|
||||||
|
|
||||||
Long id = (Long) session.save(person);
|
Long id = (Long) session1.save(person);
|
||||||
|
|
||||||
assertNotNull(id);
|
assertNotNull(id);
|
||||||
|
|
||||||
session.getTransaction()
|
session1.getTransaction()
|
||||||
.commit();
|
.commit();
|
||||||
session.close();
|
session1.close();
|
||||||
|
|
||||||
assertEquals(id, person.getId());
|
assertEquals(id, person.getId());
|
||||||
|
|
||||||
session = sessionFactory.openSession();
|
session1 = sessionFactory1.openSession();
|
||||||
session.beginTransaction();
|
session1.beginTransaction();
|
||||||
|
|
||||||
assertNotNull(session.get(Person.class, person.getId()));
|
assertNotNull(session1.get(Person.class, person.getId()));
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -149,8 +174,8 @@ public class SaveMethodsIntegrationTest {
|
||||||
|
|
||||||
Person person = new Person();
|
Person person = new Person();
|
||||||
person.setName("John");
|
person.setName("John");
|
||||||
Long id1 = (Long) session.save(person);
|
Long id1 = (Long) session1.save(person);
|
||||||
Long id2 = (Long) session.save(person);
|
Long id2 = (Long) session1.save(person);
|
||||||
assertEquals(id1, id2);
|
assertEquals(id1, id2);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -160,10 +185,10 @@ public class SaveMethodsIntegrationTest {
|
||||||
|
|
||||||
Person person = new Person();
|
Person person = new Person();
|
||||||
person.setName("John");
|
person.setName("John");
|
||||||
Long id1 = (Long) session.save(person);
|
Long id1 = (Long) session1.save(person);
|
||||||
session.evict(person);
|
session1.evict(person);
|
||||||
|
|
||||||
Long id2 = (Long) session.save(person);
|
Long id2 = (Long) session1.save(person);
|
||||||
assertNotEquals(id1, id2);
|
assertNotEquals(id1, id2);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -173,11 +198,11 @@ public class SaveMethodsIntegrationTest {
|
||||||
|
|
||||||
Person person = new Person();
|
Person person = new Person();
|
||||||
person.setName("John");
|
person.setName("John");
|
||||||
Person mergedPerson = (Person) session.merge(person);
|
Person mergedPerson = (Person) session1.merge(person);
|
||||||
|
|
||||||
session.getTransaction()
|
session1.getTransaction()
|
||||||
.commit();
|
.commit();
|
||||||
session.beginTransaction();
|
session1.beginTransaction();
|
||||||
|
|
||||||
assertNotNull(person.getId());
|
assertNotNull(person.getId());
|
||||||
assertNotNull(mergedPerson.getId());
|
assertNotNull(mergedPerson.getId());
|
||||||
|
@ -189,9 +214,9 @@ public class SaveMethodsIntegrationTest {
|
||||||
|
|
||||||
Person person = new Person();
|
Person person = new Person();
|
||||||
person.setName("John");
|
person.setName("John");
|
||||||
session.save(person);
|
session1.save(person);
|
||||||
|
|
||||||
Person mergedPerson = (Person) session.merge(person);
|
Person mergedPerson = (Person) session1.merge(person);
|
||||||
|
|
||||||
assertSame(person, mergedPerson);
|
assertSame(person, mergedPerson);
|
||||||
|
|
||||||
|
@ -202,11 +227,11 @@ public class SaveMethodsIntegrationTest {
|
||||||
|
|
||||||
Person person = new Person();
|
Person person = new Person();
|
||||||
person.setName("John");
|
person.setName("John");
|
||||||
session.save(person);
|
session1.save(person);
|
||||||
session.evict(person);
|
session1.evict(person);
|
||||||
|
|
||||||
person.setName("Mary");
|
person.setName("Mary");
|
||||||
session.update(person);
|
session1.update(person);
|
||||||
assertEquals("Mary", person.getName());
|
assertEquals("Mary", person.getName());
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -216,7 +241,7 @@ public class SaveMethodsIntegrationTest {
|
||||||
|
|
||||||
Person person = new Person();
|
Person person = new Person();
|
||||||
person.setName("John");
|
person.setName("John");
|
||||||
session.update(person);
|
session1.update(person);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -225,9 +250,9 @@ public class SaveMethodsIntegrationTest {
|
||||||
|
|
||||||
Person person = new Person();
|
Person person = new Person();
|
||||||
person.setName("John");
|
person.setName("John");
|
||||||
session.save(person);
|
session1.save(person);
|
||||||
|
|
||||||
session.update(person);
|
session1.update(person);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -236,11 +261,11 @@ public class SaveMethodsIntegrationTest {
|
||||||
|
|
||||||
Person person = new Person();
|
Person person = new Person();
|
||||||
person.setName("John");
|
person.setName("John");
|
||||||
session.save(person);
|
session1.save(person);
|
||||||
session.evict(person);
|
session1.evict(person);
|
||||||
|
|
||||||
person.setName("Mary");
|
person.setName("Mary");
|
||||||
session.saveOrUpdate(person);
|
session1.saveOrUpdate(person);
|
||||||
assertEquals("Mary", person.getName());
|
assertEquals("Mary", person.getName());
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -250,16 +275,75 @@ public class SaveMethodsIntegrationTest {
|
||||||
|
|
||||||
Person person = new Person();
|
Person person = new Person();
|
||||||
person.setName("John");
|
person.setName("John");
|
||||||
session.saveOrUpdate(person);
|
session1.saveOrUpdate(person);
|
||||||
|
|
||||||
session.getTransaction()
|
session1.getTransaction()
|
||||||
.commit();
|
.commit();
|
||||||
session.close();
|
session1.close();
|
||||||
|
|
||||||
session = sessionFactory.openSession();
|
session1 = sessionFactory1.openSession();
|
||||||
session.beginTransaction();
|
session1.beginTransaction();
|
||||||
|
|
||||||
assertNotNull(session.get(Person.class, person.getId()));
|
assertNotNull(session1.get(Person.class, person.getId()));
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void whenSaveAndTriggerUpdatedAndRefresh_thenRefreshPersistentEntity() {
|
||||||
|
|
||||||
|
Person person = new Person();
|
||||||
|
person.setName("Zeeshan Arif");
|
||||||
|
session1.persist(person);
|
||||||
|
session1.getTransaction()
|
||||||
|
.commit();
|
||||||
|
session1.close();
|
||||||
|
|
||||||
|
session1 = sessionFactory1.openSession();
|
||||||
|
session1.beginTransaction();
|
||||||
|
session1.refresh(person);
|
||||||
|
session1.getTransaction()
|
||||||
|
.commit();
|
||||||
|
session1.close();
|
||||||
|
|
||||||
|
session1 = sessionFactory1.openSession();
|
||||||
|
session1.beginTransaction();
|
||||||
|
assertEquals(person.getName(), "Neymar Santos");
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void whenReplicate_thenRefreshPersistentEntity() {
|
||||||
|
|
||||||
|
Person p = new Person();
|
||||||
|
p.setName("Ronaldinho Gaucho");
|
||||||
|
session1.persist(p);
|
||||||
|
session1.getTransaction()
|
||||||
|
.commit();
|
||||||
|
session1.close();
|
||||||
|
|
||||||
|
Session session2 = sessionFactory2.openSession();
|
||||||
|
session2.beginTransaction();
|
||||||
|
session2.replicate(p, ReplicationMode.LATEST_VERSION);
|
||||||
|
session2.getTransaction()
|
||||||
|
.commit();
|
||||||
|
session2.close();
|
||||||
|
|
||||||
|
session2 = sessionFactory2.openSession();
|
||||||
|
session2.beginTransaction();
|
||||||
|
Person actual = session2.get(Person.class, p.getId());
|
||||||
|
session2.getTransaction().commit();
|
||||||
|
session2.close();
|
||||||
|
|
||||||
|
session1 = sessionFactory1.openSession();
|
||||||
|
session1.beginTransaction();
|
||||||
|
Person expected = session1.get(Person.class, p.getId());
|
||||||
|
session1.getTransaction().commit();
|
||||||
|
session1.close();
|
||||||
|
|
||||||
|
session1 = sessionFactory1.openSession();
|
||||||
|
session1.beginTransaction();
|
||||||
|
assertEquals(expected.getId(), actual.getId());
|
||||||
|
assertEquals(expected.getName(), actual.getName());
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -268,24 +352,25 @@ public class SaveMethodsIntegrationTest {
|
||||||
|
|
||||||
Person person = new Person();
|
Person person = new Person();
|
||||||
person.setName("John");
|
person.setName("John");
|
||||||
session.save(person);
|
session1.save(person);
|
||||||
|
|
||||||
session.saveOrUpdate(person);
|
session1.saveOrUpdate(person);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@After
|
@After
|
||||||
public void tearDown() {
|
public void tearDown() {
|
||||||
if (!doNotCommit) {
|
if (!doNotCommit) {
|
||||||
session.getTransaction()
|
session1.getTransaction()
|
||||||
.commit();
|
.commit();
|
||||||
}
|
}
|
||||||
session.close();
|
session1.close();
|
||||||
}
|
}
|
||||||
|
|
||||||
@AfterClass
|
@AfterClass
|
||||||
public static void afterTests() {
|
public static void afterTests() {
|
||||||
sessionFactory.close();
|
sessionFactory1.close();
|
||||||
|
sessionFactory2.close();
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,5 @@
|
||||||
|
CREATE TRIGGER IF NOT EXISTS TGR_UpdatePersonName AFTER INSERT
|
||||||
|
ON Person FOR EACH ROW UPDATE PERSON SET NAME = 'Neymar Santos' where NAME = 'Zeeshan Arif'
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -15,6 +15,18 @@
|
||||||
</parent>
|
</parent>
|
||||||
|
|
||||||
<dependencies>
|
<dependencies>
|
||||||
|
<!-- Spring Data -->
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.springframework.boot</groupId>
|
||||||
|
<artifactId>spring-boot-starter-data-jpa</artifactId>
|
||||||
|
<version>${spring-boot.version}</version>
|
||||||
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.springframework.boot</groupId>
|
||||||
|
<artifactId>spring-boot-starter-test</artifactId>
|
||||||
|
<scope>test</scope>
|
||||||
|
<version>${spring-boot.version}</version>
|
||||||
|
</dependency>
|
||||||
<!-- QueryDSL -->
|
<!-- QueryDSL -->
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>com.querydsl</groupId>
|
<groupId>com.querydsl</groupId>
|
||||||
|
@ -36,6 +48,16 @@
|
||||||
<version>${hibernate-core.version}</version>
|
<version>${hibernate-core.version}</version>
|
||||||
<scope>compile</scope>
|
<scope>compile</scope>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.hibernate</groupId>
|
||||||
|
<artifactId>hibernate-jpamodelgen</artifactId>
|
||||||
|
<version>${hibernate-core.version}</version>
|
||||||
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.bsc.maven</groupId>
|
||||||
|
<artifactId>maven-processor-plugin</artifactId>
|
||||||
|
<version>5.0</version>
|
||||||
|
</dependency>
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>commons-dbcp</groupId>
|
<groupId>commons-dbcp</groupId>
|
||||||
<artifactId>commons-dbcp</artifactId>
|
<artifactId>commons-dbcp</artifactId>
|
||||||
|
@ -103,24 +125,36 @@
|
||||||
<version>${maven-compiler-plugin.version}</version>
|
<version>${maven-compiler-plugin.version}</version>
|
||||||
<configuration>
|
<configuration>
|
||||||
<compilerArgument>-proc:none</compilerArgument>
|
<compilerArgument>-proc:none</compilerArgument>
|
||||||
|
<source>17</source>
|
||||||
|
<target>17</target>
|
||||||
</configuration>
|
</configuration>
|
||||||
</plugin>
|
</plugin>
|
||||||
<!-- QueryDSL plugin -->
|
|
||||||
<plugin>
|
<plugin>
|
||||||
<groupId>com.mysema.maven</groupId>
|
<groupId>org.bsc.maven</groupId>
|
||||||
<artifactId>apt-maven-plugin</artifactId>
|
<artifactId>maven-processor-plugin</artifactId>
|
||||||
<version>${apt-maven-plugin.version}</version>
|
<version>5.0</version>
|
||||||
<executions>
|
<executions>
|
||||||
<execution>
|
<execution>
|
||||||
|
<id>process</id>
|
||||||
<goals>
|
<goals>
|
||||||
<goal>process</goal>
|
<goal>process</goal>
|
||||||
</goals>
|
</goals>
|
||||||
|
<phase>generate-sources</phase>
|
||||||
<configuration>
|
<configuration>
|
||||||
<outputDirectory>target/generated-sources/java</outputDirectory>
|
<processors>
|
||||||
|
<processor>org.hibernate.jpamodelgen.JPAMetaModelEntityProcessor</processor>
|
||||||
<processor>com.querydsl.apt.jpa.JPAAnnotationProcessor</processor>
|
<processor>com.querydsl.apt.jpa.JPAAnnotationProcessor</processor>
|
||||||
|
</processors>
|
||||||
</configuration>
|
</configuration>
|
||||||
</execution>
|
</execution>
|
||||||
</executions>
|
</executions>
|
||||||
|
<dependencies>
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.hibernate</groupId>
|
||||||
|
<artifactId>hibernate-jpamodelgen</artifactId>
|
||||||
|
<version>${hibernate-core.version}</version>
|
||||||
|
</dependency>
|
||||||
|
</dependencies>
|
||||||
</plugin>
|
</plugin>
|
||||||
</plugins>
|
</plugins>
|
||||||
</build>
|
</build>
|
||||||
|
@ -132,6 +166,7 @@
|
||||||
<commons-dbcp.version>1.4</commons-dbcp.version>
|
<commons-dbcp.version>1.4</commons-dbcp.version>
|
||||||
<apt-maven-plugin.version>1.1.3</apt-maven-plugin.version>
|
<apt-maven-plugin.version>1.1.3</apt-maven-plugin.version>
|
||||||
<hibernate-core.version>6.4.2.Final</hibernate-core.version>
|
<hibernate-core.version>6.4.2.Final</hibernate-core.version>
|
||||||
|
<spring-boot.version>3.2.3</spring-boot.version>
|
||||||
</properties>
|
</properties>
|
||||||
|
|
||||||
</project>
|
</project>
|
|
@ -0,0 +1,59 @@
|
||||||
|
package com.baeldung.querydslvsjpacriteria.entities;
|
||||||
|
|
||||||
|
import java.util.HashSet;
|
||||||
|
import java.util.Set;
|
||||||
|
|
||||||
|
import jakarta.persistence.CascadeType;
|
||||||
|
import jakarta.persistence.Entity;
|
||||||
|
import jakarta.persistence.GeneratedValue;
|
||||||
|
import jakarta.persistence.Id;
|
||||||
|
import jakarta.persistence.ManyToMany;
|
||||||
|
import jakarta.persistence.OneToMany;
|
||||||
|
|
||||||
|
@Entity
|
||||||
|
public class GroupUser {
|
||||||
|
|
||||||
|
@Id
|
||||||
|
@GeneratedValue
|
||||||
|
private Long id;
|
||||||
|
|
||||||
|
private String login;
|
||||||
|
|
||||||
|
@ManyToMany(mappedBy = "groupUsers", cascade = CascadeType.PERSIST)
|
||||||
|
private Set<UserGroup> userGroups = new HashSet<>();
|
||||||
|
|
||||||
|
@OneToMany(cascade = CascadeType.PERSIST, mappedBy = "groupUser")
|
||||||
|
private Set<Task> tasks = new HashSet<>(0);
|
||||||
|
|
||||||
|
public Long getId() {
|
||||||
|
return id;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setId(Long id) {
|
||||||
|
this.id = id;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getLogin() {
|
||||||
|
return login;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setLogin(String login) {
|
||||||
|
this.login = login;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Set<UserGroup> getUserGroups() {
|
||||||
|
return userGroups;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setUserGroups(Set<UserGroup> userGroups) {
|
||||||
|
this.userGroups = userGroups;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Set<Task> getTasks() {
|
||||||
|
return tasks;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setTasks(Set<Task> tasks) {
|
||||||
|
this.tasks = tasks;
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,43 @@
|
||||||
|
package com.baeldung.querydslvsjpacriteria.entities;
|
||||||
|
|
||||||
|
import jakarta.persistence.Entity;
|
||||||
|
import jakarta.persistence.GeneratedValue;
|
||||||
|
import jakarta.persistence.Id;
|
||||||
|
import jakarta.persistence.ManyToOne;
|
||||||
|
|
||||||
|
@Entity
|
||||||
|
public class Task {
|
||||||
|
|
||||||
|
@Id
|
||||||
|
@GeneratedValue
|
||||||
|
private Long id;
|
||||||
|
|
||||||
|
private String description;
|
||||||
|
|
||||||
|
@ManyToOne
|
||||||
|
private GroupUser groupUser;
|
||||||
|
|
||||||
|
public Long getId() {
|
||||||
|
return id;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setId(Long id) {
|
||||||
|
this.id = id;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getDescription() {
|
||||||
|
return description;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setDescription(String description) {
|
||||||
|
this.description = description;
|
||||||
|
}
|
||||||
|
|
||||||
|
public GroupUser getUser() {
|
||||||
|
return groupUser;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setUser(GroupUser groupUser) {
|
||||||
|
this.groupUser = groupUser;
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,47 @@
|
||||||
|
package com.baeldung.querydslvsjpacriteria.entities;
|
||||||
|
|
||||||
|
import java.util.HashSet;
|
||||||
|
import java.util.Set;
|
||||||
|
|
||||||
|
import jakarta.persistence.CascadeType;
|
||||||
|
import jakarta.persistence.Entity;
|
||||||
|
import jakarta.persistence.GeneratedValue;
|
||||||
|
import jakarta.persistence.Id;
|
||||||
|
import jakarta.persistence.ManyToMany;
|
||||||
|
|
||||||
|
@Entity
|
||||||
|
public class UserGroup {
|
||||||
|
|
||||||
|
@Id
|
||||||
|
@GeneratedValue
|
||||||
|
private Long id;
|
||||||
|
|
||||||
|
private String name;
|
||||||
|
|
||||||
|
@ManyToMany(cascade = CascadeType.PERSIST)
|
||||||
|
private Set<GroupUser> groupUsers = new HashSet<>();
|
||||||
|
|
||||||
|
public Long getId() {
|
||||||
|
return id;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setId(Long id) {
|
||||||
|
this.id = id;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getName() {
|
||||||
|
return name;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setName(String name) {
|
||||||
|
this.name = name;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Set<GroupUser> getGroupUsers() {
|
||||||
|
return groupUsers;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setGroupUsers(Set<GroupUser> groupUsers) {
|
||||||
|
this.groupUsers = groupUsers;
|
||||||
|
}
|
||||||
|
}
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue