commit
7d52a39289
|
@ -7,15 +7,9 @@ import org.junit.Test;
|
||||||
import com.baeldung.datetime.sql.TimeUtils;
|
import com.baeldung.datetime.sql.TimeUtils;
|
||||||
|
|
||||||
import java.text.ParseException;
|
import java.text.ParseException;
|
||||||
import java.util.Date;
|
|
||||||
|
|
||||||
public class TimeUtilsUnitTest {
|
public class TimeUtilsUnitTest {
|
||||||
|
|
||||||
@Test
|
|
||||||
public void givenCurrentTime_thenNowIsReturned() {
|
|
||||||
assertEquals(TimeUtils.getNow(), new Date());
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test(expected = IllegalArgumentException.class)
|
@Test(expected = IllegalArgumentException.class)
|
||||||
public void givenTimeAsString_whenPatternIsNotRespected_thenExceptionIsThrown() {
|
public void givenTimeAsString_whenPatternIsNotRespected_thenExceptionIsThrown() {
|
||||||
TimeUtils.getTime("10 11 12");
|
TimeUtils.getTime("10 11 12");
|
||||||
|
|
|
@ -17,8 +17,8 @@
|
||||||
</parent>
|
</parent>
|
||||||
|
|
||||||
<modules>
|
<modules>
|
||||||
<module>jnosql-diana</module>
|
|
||||||
<module>jnosql-artemis</module>
|
<module>jnosql-artemis</module>
|
||||||
|
<module>jnosql-diana</module>
|
||||||
</modules>
|
</modules>
|
||||||
|
|
||||||
<properties>
|
<properties>
|
||||||
|
|
|
@ -18,28 +18,34 @@
|
||||||
<module>apache-cayenne</module>
|
<module>apache-cayenne</module>
|
||||||
<module>core-java-persistence</module>
|
<module>core-java-persistence</module>
|
||||||
<module>deltaspike</module>
|
<module>deltaspike</module>
|
||||||
|
<module>elasticsearch</module>
|
||||||
<module>flyway</module>
|
<module>flyway</module>
|
||||||
<module>hbase</module>
|
<module>hbase</module>
|
||||||
<module>hibernate5</module>
|
<module>hibernate5</module>
|
||||||
<module>hibernate-ogm</module>
|
|
||||||
<module>hibernate-mapping</module>
|
|
||||||
<module>hibernate5-2</module>
|
<module>hibernate5-2</module>
|
||||||
|
<module>hibernate-mapping</module> <!-- long running -->
|
||||||
|
<module>hibernate-ogm</module>
|
||||||
<module>influxdb</module>
|
<module>influxdb</module>
|
||||||
<module>java-cassandra</module>
|
<module>java-cassandra</module>
|
||||||
<module>java-cockroachdb</module>
|
<module>java-cockroachdb</module>
|
||||||
<module>java-jdbi</module>
|
<module>java-jdbi</module>
|
||||||
<module>java-jpa</module>
|
<module>java-jpa</module> <!-- long running -->
|
||||||
<module>java-jpa-2</module>
|
<module>java-jpa-2</module> <!-- long running -->
|
||||||
<module>java-mongodb</module>
|
<module>java-mongodb</module> <!-- long running -->
|
||||||
<module>persistence-libraries</module>
|
<module>jnosql</module> <!-- long running -->
|
||||||
<module>jnosql</module>
|
<module>jpa-hibernate-cascade-type</module>
|
||||||
<module>liquibase</module>
|
<module>liquibase</module>
|
||||||
<module>orientdb</module>
|
<module>orientdb</module>
|
||||||
|
<module>persistence-libraries</module>
|
||||||
<module>querydsl</module>
|
<module>querydsl</module>
|
||||||
|
<module>r2dbc</module>
|
||||||
<module>redis</module>
|
<module>redis</module>
|
||||||
|
<!-- <module>sirix</module> --> <!-- We haven't upgraded to java 11. Fixing in BAEL-10841 -->
|
||||||
<module>solr</module>
|
<module>solr</module>
|
||||||
<module>spring-boot-persistence-h2</module>
|
<module>spring-boot-jdbi</module>
|
||||||
|
<module>spring-boot-mysql</module>
|
||||||
<module>spring-boot-persistence</module>
|
<module>spring-boot-persistence</module>
|
||||||
|
<module>spring-boot-persistence-h2</module>
|
||||||
<module>spring-boot-persistence-mongodb</module>
|
<module>spring-boot-persistence-mongodb</module>
|
||||||
<module>spring-data-cassandra</module>
|
<module>spring-data-cassandra</module>
|
||||||
<module>spring-data-cassandra-reactive</module>
|
<module>spring-data-cassandra-reactive</module>
|
||||||
|
@ -50,19 +56,20 @@
|
||||||
<module>spring-data-gemfire</module>
|
<module>spring-data-gemfire</module>
|
||||||
<module>spring-data-geode</module>
|
<module>spring-data-geode</module>
|
||||||
<module>spring-data-jpa</module>
|
<module>spring-data-jpa</module>
|
||||||
|
<module>spring-data-jpa-2</module>
|
||||||
<module>spring-data-jpa-3</module>
|
<module>spring-data-jpa-3</module>
|
||||||
|
<module>spring-data-jpa-4</module>
|
||||||
<module>spring-data-keyvalue</module>
|
<module>spring-data-keyvalue</module>
|
||||||
<module>spring-data-mongodb</module> <!-- long -->
|
<module>spring-data-mongodb</module>
|
||||||
<module>spring-data-neo4j</module>
|
<module>spring-data-neo4j</module>
|
||||||
<module>spring-data-redis</module>
|
<module>spring-data-redis</module>
|
||||||
<module>spring-data-solr</module>
|
<module>spring-data-solr</module>
|
||||||
<module>spring-hibernate-3</module>
|
<module>spring-hibernate-3</module>
|
||||||
<module>spring-hibernate-5</module>
|
<module>spring-hibernate-5</module> <!-- long running -->
|
||||||
<module>spring-hibernate4</module>
|
<module>spring-hibernate4</module>
|
||||||
<module>spring-jpa</module>
|
<module>spring-jpa</module>
|
||||||
|
<!-- <module>spring-mybatis</module> --> <!-- needs fixing in BAEL-9021 -->
|
||||||
<module>spring-persistence-simple</module>
|
<module>spring-persistence-simple</module>
|
||||||
<module>jpa-hibernate-cascade-type</module>
|
|
||||||
<module>r2dbc</module>
|
|
||||||
<module>spring-boot-jdbi</module>
|
|
||||||
</modules>
|
</modules>
|
||||||
|
|
||||||
</project>
|
</project>
|
||||||
|
|
|
@ -9,7 +9,3 @@
|
||||||
- [JPA @Embedded And @Embeddable](https://www.baeldung.com/jpa-embedded-embeddable)
|
- [JPA @Embedded And @Embeddable](https://www.baeldung.com/jpa-embedded-embeddable)
|
||||||
- [Spring Data JPA Delete and Relationships](https://www.baeldung.com/spring-data-jpa-delete)
|
- [Spring Data JPA Delete and Relationships](https://www.baeldung.com/spring-data-jpa-delete)
|
||||||
- [Spring Data JPA and Named Entity Graphs](https://www.baeldung.com/spring-data-jpa-named-entity-graphs)
|
- [Spring Data JPA and Named Entity Graphs](https://www.baeldung.com/spring-data-jpa-named-entity-graphs)
|
||||||
- [Batch Insert/Update with Hibernate/JPA](https://www.baeldung.com/jpa-hibernate-batch-insert-update)
|
|
||||||
- [Difference Between save() and saveAndFlush() in Spring Data JPA](https://www.baeldung.com/spring-data-jpa-save-saveandflush)
|
|
||||||
- [Derived Query Methods in Spring Data JPA Repositories](https://www.baeldung.com/spring-data-derived-queries)
|
|
||||||
- [LIKE Queries in Spring JPA Repositories](https://www.baeldung.com/spring-jpa-like-queries)
|
|
||||||
|
|
|
@ -23,5 +23,5 @@ public interface FruitRepository extends JpaRepository<Fruit, Long> {
|
||||||
|
|
||||||
@Modifying
|
@Modifying
|
||||||
@Query("delete from Fruit f where f.name=:name or f.color=:color")
|
@Query("delete from Fruit f where f.name=:name or f.color=:color")
|
||||||
List<Fruit> deleteFruits(@Param("name") String name, @Param("color") String color);
|
int deleteFruits(@Param("name") String name, @Param("color") String color);
|
||||||
}
|
}
|
||||||
|
|
|
@ -14,7 +14,7 @@ import com.baeldung.entity.Fruit;
|
||||||
|
|
||||||
@RunWith(SpringRunner.class)
|
@RunWith(SpringRunner.class)
|
||||||
@SpringBootTest
|
@SpringBootTest
|
||||||
public class FruitPopulatorTest {
|
public class FruitPopulatorIntegrationTest {
|
||||||
|
|
||||||
@Autowired
|
@Autowired
|
||||||
private FruitRepository fruitRepository;
|
private FruitRepository fruitRepository;
|
|
@ -1,7 +1,6 @@
|
||||||
package com.baeldung.repository;
|
package com.baeldung.repository;
|
||||||
|
|
||||||
import static org.junit.Assert.assertEquals;
|
import static org.junit.Assert.assertEquals;
|
||||||
import static org.junit.Assert.assertTrue;
|
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
|
@ -69,9 +68,8 @@ class FruitRepositoryIntegrationTest {
|
||||||
@Sql(scripts = { "/test-fruit-data.sql" })
|
@Sql(scripts = { "/test-fruit-data.sql" })
|
||||||
public void givenFruits_WhenDeletedByColorOrName_ThenDeletedFruitsShouldReturn() {
|
public void givenFruits_WhenDeletedByColorOrName_ThenDeletedFruitsShouldReturn() {
|
||||||
|
|
||||||
List<Fruit> fruits = fruitRepository.deleteFruits("apple", "green");
|
int deletedCount = fruitRepository.deleteFruits("apple", "green");
|
||||||
|
|
||||||
assertEquals("number of fruits are not matching", 3, fruits.size());
|
assertEquals("number of fruits are not matching", 3, deletedCount);
|
||||||
fruits.forEach(fruit -> assertTrue("Its not a green fruit or apple", ("green".equals(fruit.getColor())) || "apple".equals(fruit.getColor())));
|
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -1,7 +1,10 @@
|
||||||
package com.baeldung.repository;
|
package com.baeldung.repository;
|
||||||
|
|
||||||
import com.baeldung.entity.Song;
|
import static org.junit.Assert.assertEquals;
|
||||||
import org.junit.jupiter.api.Test;
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
import org.junit.Test;
|
||||||
import org.junit.runner.RunWith;
|
import org.junit.runner.RunWith;
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
import org.springframework.boot.test.context.SpringBootTest;
|
import org.springframework.boot.test.context.SpringBootTest;
|
||||||
|
@ -9,9 +12,7 @@ import org.springframework.test.context.jdbc.Sql;
|
||||||
import org.springframework.test.context.junit4.SpringRunner;
|
import org.springframework.test.context.junit4.SpringRunner;
|
||||||
import org.springframework.transaction.annotation.Transactional;
|
import org.springframework.transaction.annotation.Transactional;
|
||||||
|
|
||||||
import java.util.List;
|
import com.baeldung.entity.Song;
|
||||||
|
|
||||||
import static org.junit.Assert.assertEquals;
|
|
||||||
|
|
||||||
@RunWith(SpringRunner.class)
|
@RunWith(SpringRunner.class)
|
||||||
@SpringBootTest
|
@SpringBootTest
|
||||||
|
|
|
@ -1,4 +1,6 @@
|
||||||
insert into fruit(id,name,color) values (1,'apple','red');
|
truncate table fruit;
|
||||||
insert into fruit(id,name,color) values (2,'custard apple','green');
|
|
||||||
insert into fruit(id,name,color) values (3,'mango','yellow');
|
insert into fruit(id,name,color) values (1,'apple','red');
|
||||||
|
insert into fruit(id,name,color) values (2,'custard apple','green');
|
||||||
|
insert into fruit(id,name,color) values (3,'mango','yellow');
|
||||||
insert into fruit(id,name,color) values (4,'guava','green');
|
insert into fruit(id,name,color) values (4,'guava','green');
|
|
@ -1,3 +1,21 @@
|
||||||
### Relevant Articles:
|
### Relevant Articles:
|
||||||
|
- [Limiting Query Results with JPA and Spring Data JPA](https://www.baeldung.com/jpa-limit-query-results)
|
||||||
|
- [Sorting Query Results with Spring Data](https://www.baeldung.com/spring-data-sorting)
|
||||||
|
- [INSERT Statement in JPA](https://www.baeldung.com/jpa-insert)
|
||||||
|
- [Pagination and Sorting using Spring Data JPA](https://www.baeldung.com/spring-data-jpa-pagination-sorting)
|
||||||
|
- [Spring Data JPA Query by Example](https://www.baeldung.com/spring-data-query-by-example)
|
||||||
|
- [DB Integration Tests with Spring Boot and Testcontainers](https://www.baeldung.com/spring-boot-testcontainers-integration-test)
|
||||||
|
- [Spring Data JPA @Modifying Annotation](https://www.baeldung.com/spring-data-jpa-modifying-annotation)
|
||||||
|
- [Spring Data JPA Batch Inserts](https://www.baeldung.com/spring-data-jpa-batch-inserts)
|
||||||
|
- [Batch Insert/Update with Hibernate/JPA](https://www.baeldung.com/jpa-hibernate-batch-insert-update)
|
||||||
|
- [Difference Between save() and saveAndFlush() in Spring Data JPA](https://www.baeldung.com/spring-data-jpa-save-saveandflush)
|
||||||
- [Programmatic Transaction Management in Spring](https://www.baeldung.com/spring-programmatic-transaction-management)
|
- [Programmatic Transaction Management in Spring](https://www.baeldung.com/spring-programmatic-transaction-management)
|
||||||
|
|
||||||
|
### Eclipse Config
|
||||||
|
After importing the project into Eclipse, you may see the following error:
|
||||||
|
"No persistence xml file found in project"
|
||||||
|
|
||||||
|
This can be ignored:
|
||||||
|
- Project -> Properties -> Java Persistance -> JPA -> Error/Warnings -> Select Ignore on "No persistence xml file found in project"
|
||||||
|
Or:
|
||||||
|
- Eclipse -> Preferences - Validation - disable the "Build" execution of the JPA Validator
|
||||||
|
|
|
@ -26,6 +26,29 @@
|
||||||
<groupId>org.springframework.boot</groupId>
|
<groupId>org.springframework.boot</groupId>
|
||||||
<artifactId>spring-boot-starter-data-jpa</artifactId>
|
<artifactId>spring-boot-starter-data-jpa</artifactId>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.springframework.boot</groupId>
|
||||||
|
<artifactId>spring-boot-starter-web</artifactId>
|
||||||
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>com.google.guava</groupId>
|
||||||
|
<artifactId>guava</artifactId>
|
||||||
|
<version>${guava.version}</version>
|
||||||
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>com.h2database</groupId>
|
||||||
|
<artifactId>h2</artifactId>
|
||||||
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>net.ttddyy</groupId>
|
||||||
|
<artifactId>datasource-proxy</artifactId>
|
||||||
|
<version>${datasource-proxy.version}</version>
|
||||||
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.postgresql</groupId>
|
||||||
|
<artifactId>postgresql</artifactId>
|
||||||
|
<version>${postgresql.version}</version>
|
||||||
|
</dependency>
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>com.h2database</groupId>
|
<groupId>com.h2database</groupId>
|
||||||
<artifactId>h2</artifactId>
|
<artifactId>h2</artifactId>
|
||||||
|
@ -61,10 +84,23 @@
|
||||||
<version>${junit-platform.version}</version>
|
<version>${junit-platform.version}</version>
|
||||||
<scope>test</scope>
|
<scope>test</scope>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
|
<!-- Test containers only dependencies -->
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.testcontainers</groupId>
|
||||||
|
<artifactId>postgresql</artifactId>
|
||||||
|
<version>${testcontainers.version}</version>
|
||||||
|
<scope>test</scope>
|
||||||
|
</dependency>
|
||||||
|
<!-- Test containers only dependencies -->
|
||||||
</dependencies>
|
</dependencies>
|
||||||
|
|
||||||
<properties>
|
<properties>
|
||||||
|
<datasource-proxy.version>1.4.1</datasource-proxy.version>
|
||||||
|
<guava.version>21.0</guava.version>
|
||||||
|
<testcontainers.version>1.12.2</testcontainers.version>
|
||||||
|
<postgresql.version>42.2.8</postgresql.version>
|
||||||
|
<testcontainers.version>1.12.2</testcontainers.version>
|
||||||
<h2.version>1.4.200</h2.version>
|
<h2.version>1.4.200</h2.version>
|
||||||
</properties>
|
</properties>
|
||||||
|
|
||||||
</project>
|
</project>
|
||||||
|
|
|
@ -0,0 +1,17 @@
|
||||||
|
package com.baeldung.boot;
|
||||||
|
|
||||||
|
import org.springframework.boot.SpringApplication;
|
||||||
|
import org.springframework.boot.autoconfigure.SpringBootApplication;
|
||||||
|
import org.springframework.boot.autoconfigure.domain.EntityScan;
|
||||||
|
import org.springframework.data.jpa.repository.config.EnableJpaRepositories;
|
||||||
|
|
||||||
|
@SpringBootApplication
|
||||||
|
@EnableJpaRepositories("com.baeldung")
|
||||||
|
@EntityScan("com.baeldung")
|
||||||
|
public class Application {
|
||||||
|
|
||||||
|
public static void main(String[] args) {
|
||||||
|
SpringApplication.run(Application.class, args);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,99 @@
|
||||||
|
package com.baeldung.boot.daos.user;
|
||||||
|
|
||||||
|
import org.springframework.data.domain.Page;
|
||||||
|
import org.springframework.data.domain.Pageable;
|
||||||
|
import org.springframework.data.domain.Sort;
|
||||||
|
import org.springframework.data.jpa.repository.JpaRepository;
|
||||||
|
import org.springframework.data.jpa.repository.Modifying;
|
||||||
|
import org.springframework.data.jpa.repository.Query;
|
||||||
|
import org.springframework.data.repository.query.Param;
|
||||||
|
|
||||||
|
import com.baeldung.boot.domain.User;
|
||||||
|
|
||||||
|
import java.time.LocalDate;
|
||||||
|
import java.util.Collection;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.stream.Stream;
|
||||||
|
|
||||||
|
public interface UserRepository extends JpaRepository<User, Integer> , UserRepositoryCustom{
|
||||||
|
|
||||||
|
Stream<User> findAllByName(String name);
|
||||||
|
|
||||||
|
@Query("SELECT u FROM User u WHERE u.status = 1")
|
||||||
|
Collection<User> findAllActiveUsers();
|
||||||
|
|
||||||
|
@Query("select u from User u where u.email like '%@gmail.com'")
|
||||||
|
List<User> findUsersWithGmailAddress();
|
||||||
|
|
||||||
|
@Query(value = "SELECT * FROM Users u WHERE u.status = 1", nativeQuery = true)
|
||||||
|
Collection<User> findAllActiveUsersNative();
|
||||||
|
|
||||||
|
@Query("SELECT u FROM User u WHERE u.status = ?1")
|
||||||
|
User findUserByStatus(Integer status);
|
||||||
|
|
||||||
|
@Query(value = "SELECT * FROM Users u WHERE u.status = ?1", nativeQuery = true)
|
||||||
|
User findUserByStatusNative(Integer status);
|
||||||
|
|
||||||
|
@Query("SELECT u FROM User u WHERE u.status = ?1 and u.name = ?2")
|
||||||
|
User findUserByStatusAndName(Integer status, String name);
|
||||||
|
|
||||||
|
@Query("SELECT u FROM User u WHERE u.status = :status and u.name = :name")
|
||||||
|
User findUserByStatusAndNameNamedParams(@Param("status") Integer status, @Param("name") String name);
|
||||||
|
|
||||||
|
@Query(value = "SELECT * FROM Users u WHERE u.status = :status AND u.name = :name", nativeQuery = true)
|
||||||
|
User findUserByStatusAndNameNamedParamsNative(@Param("status") Integer status, @Param("name") String name);
|
||||||
|
|
||||||
|
@Query("SELECT u FROM User u WHERE u.status = :status and u.name = :name")
|
||||||
|
User findUserByUserStatusAndUserName(@Param("status") Integer userStatus, @Param("name") String userName);
|
||||||
|
|
||||||
|
@Query("SELECT u FROM User u WHERE u.name like ?1%")
|
||||||
|
User findUserByNameLike(String name);
|
||||||
|
|
||||||
|
@Query("SELECT u FROM User u WHERE u.name like :name%")
|
||||||
|
User findUserByNameLikeNamedParam(@Param("name") String name);
|
||||||
|
|
||||||
|
@Query(value = "SELECT * FROM users u WHERE u.name LIKE ?1%", nativeQuery = true)
|
||||||
|
User findUserByNameLikeNative(String name);
|
||||||
|
|
||||||
|
@Query(value = "SELECT u FROM User u")
|
||||||
|
List<User> findAllUsers(Sort sort);
|
||||||
|
|
||||||
|
@Query(value = "SELECT u FROM User u ORDER BY id")
|
||||||
|
Page<User> findAllUsersWithPagination(Pageable pageable);
|
||||||
|
|
||||||
|
@Query(value = "SELECT * FROM Users ORDER BY id", countQuery = "SELECT count(*) FROM Users", nativeQuery = true)
|
||||||
|
Page<User> findAllUsersWithPaginationNative(Pageable pageable);
|
||||||
|
|
||||||
|
@Modifying
|
||||||
|
@Query("update User u set u.status = :status where u.name = :name")
|
||||||
|
int updateUserSetStatusForName(@Param("status") Integer status, @Param("name") String name);
|
||||||
|
|
||||||
|
@Modifying
|
||||||
|
@Query(value = "UPDATE Users u SET u.status = ? WHERE u.name = ?", nativeQuery = true)
|
||||||
|
int updateUserSetStatusForNameNative(Integer status, String name);
|
||||||
|
|
||||||
|
@Query(value = "INSERT INTO Users (name, age, email, status, active) VALUES (:name, :age, :email, :status, :active)", nativeQuery = true)
|
||||||
|
@Modifying
|
||||||
|
void insertUser(@Param("name") String name, @Param("age") Integer age, @Param("email") String email, @Param("status") Integer status, @Param("active") boolean active);
|
||||||
|
|
||||||
|
@Modifying
|
||||||
|
@Query(value = "UPDATE Users u SET status = ? WHERE u.name = ?", nativeQuery = true)
|
||||||
|
int updateUserSetStatusForNameNativePostgres(Integer status, String name);
|
||||||
|
|
||||||
|
@Query(value = "SELECT u FROM User u WHERE u.name IN :names")
|
||||||
|
List<User> findUserByNameList(@Param("names") Collection<String> names);
|
||||||
|
|
||||||
|
void deleteAllByCreationDateAfter(LocalDate date);
|
||||||
|
|
||||||
|
@Modifying(clearAutomatically = true, flushAutomatically = true)
|
||||||
|
@Query("update User u set u.active = false where u.lastLoginDate < :date")
|
||||||
|
void deactivateUsersNotLoggedInSince(@Param("date") LocalDate date);
|
||||||
|
|
||||||
|
@Modifying(clearAutomatically = true, flushAutomatically = true)
|
||||||
|
@Query("delete User u where u.active = false")
|
||||||
|
int deleteDeactivatedUsers();
|
||||||
|
|
||||||
|
@Modifying(clearAutomatically = true, flushAutomatically = true)
|
||||||
|
@Query(value = "alter table USERS add column deleted int(1) not null default 0", nativeQuery = true)
|
||||||
|
void addDeletedColumn();
|
||||||
|
}
|
|
@ -0,0 +1,14 @@
|
||||||
|
package com.baeldung.boot.daos.user;
|
||||||
|
|
||||||
|
import java.util.Collection;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Set;
|
||||||
|
import java.util.function.Predicate;
|
||||||
|
|
||||||
|
import com.baeldung.boot.domain.User;
|
||||||
|
|
||||||
|
public interface UserRepositoryCustom {
|
||||||
|
List<User> findUserByEmails(Set<String> emails);
|
||||||
|
|
||||||
|
List<User> findAllUsersByPredicates(Collection<Predicate<User>> predicates);
|
||||||
|
}
|
|
@ -0,0 +1,57 @@
|
||||||
|
package com.baeldung.boot.daos.user;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Collection;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Set;
|
||||||
|
import java.util.stream.Collectors;
|
||||||
|
import java.util.stream.Stream;
|
||||||
|
|
||||||
|
import javax.persistence.EntityManager;
|
||||||
|
import javax.persistence.PersistenceContext;
|
||||||
|
import javax.persistence.criteria.CriteriaBuilder;
|
||||||
|
import javax.persistence.criteria.CriteriaQuery;
|
||||||
|
import javax.persistence.criteria.Path;
|
||||||
|
import javax.persistence.criteria.Predicate;
|
||||||
|
import javax.persistence.criteria.Root;
|
||||||
|
|
||||||
|
import com.baeldung.boot.domain.User;
|
||||||
|
|
||||||
|
public class UserRepositoryCustomImpl implements UserRepositoryCustom {
|
||||||
|
|
||||||
|
@PersistenceContext
|
||||||
|
private EntityManager entityManager;
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public List<User> findUserByEmails(Set<String> emails) {
|
||||||
|
CriteriaBuilder cb = entityManager.getCriteriaBuilder();
|
||||||
|
CriteriaQuery<User> query = cb.createQuery(User.class);
|
||||||
|
Root<User> user = query.from(User.class);
|
||||||
|
|
||||||
|
Path<String> emailPath = user.get("email");
|
||||||
|
|
||||||
|
List<Predicate> predicates = new ArrayList<>();
|
||||||
|
for (String email : emails) {
|
||||||
|
|
||||||
|
predicates.add(cb.like(emailPath, email));
|
||||||
|
|
||||||
|
}
|
||||||
|
query.select(user)
|
||||||
|
.where(cb.or(predicates.toArray(new Predicate[predicates.size()])));
|
||||||
|
|
||||||
|
return entityManager.createQuery(query)
|
||||||
|
.getResultList();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public List<User> findAllUsersByPredicates(Collection<java.util.function.Predicate<User>> predicates) {
|
||||||
|
List<User> allUsers = entityManager.createQuery("select u from User u", User.class).getResultList();
|
||||||
|
Stream<User> allUsersStream = allUsers.stream();
|
||||||
|
for (java.util.function.Predicate<User> predicate : predicates) {
|
||||||
|
allUsersStream = allUsersStream.filter(predicate);
|
||||||
|
}
|
||||||
|
|
||||||
|
return allUsersStream.collect(Collectors.toList());
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,83 @@
|
||||||
|
package com.baeldung.boot.domain;
|
||||||
|
|
||||||
|
import javax.persistence.*;
|
||||||
|
import com.baeldung.boot.domain.Possession;
|
||||||
|
|
||||||
|
@Entity
|
||||||
|
@Table
|
||||||
|
public class Possession {
|
||||||
|
|
||||||
|
@Id
|
||||||
|
@GeneratedValue(strategy = GenerationType.IDENTITY)
|
||||||
|
private long id;
|
||||||
|
|
||||||
|
private String name;
|
||||||
|
|
||||||
|
public Possession() {
|
||||||
|
super();
|
||||||
|
}
|
||||||
|
|
||||||
|
public Possession(final String name) {
|
||||||
|
super();
|
||||||
|
|
||||||
|
this.name = name;
|
||||||
|
}
|
||||||
|
|
||||||
|
public long getId() {
|
||||||
|
return id;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setId(final int id) {
|
||||||
|
this.id = id;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getName() {
|
||||||
|
return name;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setName(final String name) {
|
||||||
|
this.name = name;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int hashCode() {
|
||||||
|
final int prime = 31;
|
||||||
|
int result = 1;
|
||||||
|
result = (prime * result) + (int) (id ^ (id >>> 32));
|
||||||
|
result = (prime * result) + ((name == null) ? 0 : name.hashCode());
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean equals(Object obj) {
|
||||||
|
if (this == obj) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
if (obj == null) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
if (getClass() != obj.getClass()) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
final Possession other = (Possession) obj;
|
||||||
|
if (id != other.id) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
if (name == null) {
|
||||||
|
if (other.name != null) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
} else if (!name.equals(other.name)) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String toString() {
|
||||||
|
final StringBuilder builder = new StringBuilder();
|
||||||
|
builder.append("Possesion [id=").append(id).append(", name=").append(name).append("]");
|
||||||
|
return builder.toString();
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,132 @@
|
||||||
|
package com.baeldung.boot.domain;
|
||||||
|
|
||||||
|
import javax.persistence.*;
|
||||||
|
|
||||||
|
import java.time.LocalDate;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Objects;
|
||||||
|
|
||||||
|
@Entity
|
||||||
|
@Table(name = "users")
|
||||||
|
public class User {
|
||||||
|
|
||||||
|
@Id
|
||||||
|
@GeneratedValue(strategy = GenerationType.IDENTITY)
|
||||||
|
private int id;
|
||||||
|
private String name;
|
||||||
|
private LocalDate creationDate;
|
||||||
|
private LocalDate lastLoginDate;
|
||||||
|
private boolean active;
|
||||||
|
private int age;
|
||||||
|
@Column(unique = true, nullable = false)
|
||||||
|
private String email;
|
||||||
|
private Integer status;
|
||||||
|
@OneToMany
|
||||||
|
List<Possession> possessionList;
|
||||||
|
|
||||||
|
public User() {
|
||||||
|
super();
|
||||||
|
}
|
||||||
|
|
||||||
|
public User(String name, LocalDate creationDate,String email, Integer status) {
|
||||||
|
this.name = name;
|
||||||
|
this.creationDate = creationDate;
|
||||||
|
this.email = email;
|
||||||
|
this.status = status;
|
||||||
|
this.active = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
public int getId() {
|
||||||
|
return id;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setId(final int id) {
|
||||||
|
this.id = id;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getName() {
|
||||||
|
return name;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setName(final String name) {
|
||||||
|
this.name = name;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getEmail() {
|
||||||
|
return email;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setEmail(final String email) {
|
||||||
|
this.email = email;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Integer getStatus() {
|
||||||
|
return status;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setStatus(Integer status) {
|
||||||
|
this.status = status;
|
||||||
|
}
|
||||||
|
|
||||||
|
public int getAge() {
|
||||||
|
return age;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setAge(final int age) {
|
||||||
|
this.age = age;
|
||||||
|
}
|
||||||
|
|
||||||
|
public LocalDate getCreationDate() {
|
||||||
|
return creationDate;
|
||||||
|
}
|
||||||
|
|
||||||
|
public List<Possession> getPossessionList() {
|
||||||
|
return possessionList;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setPossessionList(List<Possession> possessionList) {
|
||||||
|
this.possessionList = possessionList;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String toString() {
|
||||||
|
final StringBuilder builder = new StringBuilder();
|
||||||
|
builder.append("User [name=").append(name).append(", id=").append(id).append("]");
|
||||||
|
return builder.toString();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean equals(Object o) {
|
||||||
|
if (this == o) return true;
|
||||||
|
if (o == null || getClass() != o.getClass()) return false;
|
||||||
|
User user = (User) o;
|
||||||
|
return id == user.id &&
|
||||||
|
age == user.age &&
|
||||||
|
Objects.equals(name, user.name) &&
|
||||||
|
Objects.equals(creationDate, user.creationDate) &&
|
||||||
|
Objects.equals(email, user.email) &&
|
||||||
|
Objects.equals(status, user.status);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int hashCode() {
|
||||||
|
return Objects.hash(id, name, creationDate, age, email, status);
|
||||||
|
}
|
||||||
|
|
||||||
|
public LocalDate getLastLoginDate() {
|
||||||
|
return lastLoginDate;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setLastLoginDate(LocalDate lastLoginDate) {
|
||||||
|
this.lastLoginDate = lastLoginDate;
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean isActive() {
|
||||||
|
return active;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setActive(boolean active) {
|
||||||
|
this.active = active;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -1,10 +1,10 @@
|
||||||
package com.baeldung.boot.passenger;
|
package com.baeldung.boot.passenger;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
import org.springframework.data.domain.Sort;
|
import org.springframework.data.domain.Sort;
|
||||||
import org.springframework.data.jpa.repository.JpaRepository;
|
import org.springframework.data.jpa.repository.JpaRepository;
|
||||||
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
interface PassengerRepository extends JpaRepository<Passenger, Long>, CustomPassengerRepository {
|
interface PassengerRepository extends JpaRepository<Passenger, Long>, CustomPassengerRepository {
|
||||||
|
|
||||||
Passenger findFirstByOrderBySeatNumberAsc();
|
Passenger findFirstByOrderBySeatNumberAsc();
|
||||||
|
@ -12,11 +12,11 @@ interface PassengerRepository extends JpaRepository<Passenger, Long>, CustomPass
|
||||||
Passenger findTopByOrderBySeatNumberAsc();
|
Passenger findTopByOrderBySeatNumberAsc();
|
||||||
|
|
||||||
List<Passenger> findByOrderBySeatNumberAsc();
|
List<Passenger> findByOrderBySeatNumberAsc();
|
||||||
|
|
||||||
List<Passenger> findByLastNameOrderBySeatNumberAsc(String lastName);
|
|
||||||
|
|
||||||
List<Passenger> findByLastName(String lastName, Sort sort);
|
|
||||||
|
|
||||||
List<Passenger> findByFirstNameIgnoreCase(String firstName);
|
List<Passenger> findByFirstNameIgnoreCase(String firstName);
|
||||||
|
|
||||||
|
List<Passenger> findByLastNameOrderBySeatNumberAsc(String lastName);
|
||||||
|
|
||||||
|
List<Passenger> findByLastName(String lastName, Sort sort);
|
||||||
|
|
||||||
}
|
}
|
|
@ -1,36 +1,36 @@
|
||||||
package com.baeldung.entity;
|
package com.baeldung.entity;
|
||||||
|
|
||||||
import javax.persistence.Entity;
|
import javax.persistence.Entity;
|
||||||
import javax.persistence.Id;
|
import javax.persistence.Id;
|
||||||
|
|
||||||
@Entity
|
@Entity
|
||||||
public class Employee {
|
public class Employee {
|
||||||
|
|
||||||
@Id
|
@Id
|
||||||
private Long id;
|
private Long id;
|
||||||
private String name;
|
private String name;
|
||||||
|
|
||||||
public Employee() {
|
public Employee() {
|
||||||
}
|
}
|
||||||
|
|
||||||
public Employee(Long id, String name) {
|
public Employee(Long id, String name) {
|
||||||
this.id = id;
|
this.id = id;
|
||||||
this.name = name;
|
this.name = name;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Long getId() {
|
public Long getId() {
|
||||||
return id;
|
return id;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setId(Long id) {
|
public void setId(Long id) {
|
||||||
this.id = id;
|
this.id = id;
|
||||||
}
|
}
|
||||||
|
|
||||||
public String getName() {
|
public String getName() {
|
||||||
return name;
|
return name;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setName(String name) {
|
public void setName(String name) {
|
||||||
this.name = name;
|
this.name = name;
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -5,7 +5,7 @@ import java.util.Set;
|
||||||
|
|
||||||
@Entity
|
@Entity
|
||||||
@Table(name = "users")
|
@Table(name = "users")
|
||||||
public class User {
|
public class BasicUser {
|
||||||
|
|
||||||
@Id
|
@Id
|
||||||
@GeneratedValue
|
@GeneratedValue
|
|
@ -0,0 +1,14 @@
|
||||||
|
package com.baeldung.multipledb;
|
||||||
|
|
||||||
|
import org.springframework.boot.SpringApplication;
|
||||||
|
import org.springframework.boot.autoconfigure.SpringBootApplication;
|
||||||
|
|
||||||
|
@SpringBootApplication
|
||||||
|
public class MultipleDbApplication {
|
||||||
|
|
||||||
|
public static void main(String[] args) {
|
||||||
|
SpringApplication.run(MultipleDbApplication.class, args);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
|
@ -0,0 +1,68 @@
|
||||||
|
package com.baeldung.multipledb;
|
||||||
|
|
||||||
|
import com.google.common.base.Preconditions;
|
||||||
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
import org.springframework.context.annotation.Bean;
|
||||||
|
import org.springframework.context.annotation.Configuration;
|
||||||
|
import org.springframework.context.annotation.Profile;
|
||||||
|
import org.springframework.context.annotation.PropertySource;
|
||||||
|
import org.springframework.core.env.Environment;
|
||||||
|
import org.springframework.data.jpa.repository.config.EnableJpaRepositories;
|
||||||
|
import org.springframework.jdbc.datasource.DriverManagerDataSource;
|
||||||
|
import org.springframework.orm.jpa.JpaTransactionManager;
|
||||||
|
import org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean;
|
||||||
|
import org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter;
|
||||||
|
import org.springframework.transaction.PlatformTransactionManager;
|
||||||
|
|
||||||
|
import javax.sql.DataSource;
|
||||||
|
import java.util.HashMap;
|
||||||
|
|
||||||
|
@Configuration
|
||||||
|
@PropertySource({"classpath:persistence-multiple-db.properties"})
|
||||||
|
@EnableJpaRepositories(basePackages = "com.baeldung.multipledb.dao.product", entityManagerFactoryRef = "productEntityManager", transactionManagerRef = "productTransactionManager")
|
||||||
|
@Profile("!tc")
|
||||||
|
public class PersistenceProductConfiguration {
|
||||||
|
@Autowired
|
||||||
|
private Environment env;
|
||||||
|
|
||||||
|
public PersistenceProductConfiguration() {
|
||||||
|
super();
|
||||||
|
}
|
||||||
|
|
||||||
|
//
|
||||||
|
|
||||||
|
@Bean
|
||||||
|
public LocalContainerEntityManagerFactoryBean productEntityManager() {
|
||||||
|
final LocalContainerEntityManagerFactoryBean em = new LocalContainerEntityManagerFactoryBean();
|
||||||
|
em.setDataSource(productDataSource());
|
||||||
|
em.setPackagesToScan("com.baeldung.multipledb.model.product");
|
||||||
|
|
||||||
|
final HibernateJpaVendorAdapter vendorAdapter = new HibernateJpaVendorAdapter();
|
||||||
|
em.setJpaVendorAdapter(vendorAdapter);
|
||||||
|
final HashMap<String, Object> properties = new HashMap<String, Object>();
|
||||||
|
properties.put("hibernate.hbm2ddl.auto", env.getProperty("hibernate.hbm2ddl.auto"));
|
||||||
|
properties.put("hibernate.dialect", env.getProperty("hibernate.dialect"));
|
||||||
|
em.setJpaPropertyMap(properties);
|
||||||
|
|
||||||
|
return em;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Bean
|
||||||
|
public DataSource productDataSource() {
|
||||||
|
final DriverManagerDataSource dataSource = new DriverManagerDataSource();
|
||||||
|
dataSource.setDriverClassName(Preconditions.checkNotNull(env.getProperty("jdbc.driverClassName")));
|
||||||
|
dataSource.setUrl(Preconditions.checkNotNull(env.getProperty("product.jdbc.url")));
|
||||||
|
dataSource.setUsername(Preconditions.checkNotNull(env.getProperty("jdbc.user")));
|
||||||
|
dataSource.setPassword(Preconditions.checkNotNull(env.getProperty("jdbc.pass")));
|
||||||
|
|
||||||
|
return dataSource;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Bean
|
||||||
|
public PlatformTransactionManager productTransactionManager() {
|
||||||
|
final JpaTransactionManager transactionManager = new JpaTransactionManager();
|
||||||
|
transactionManager.setEntityManagerFactory(productEntityManager().getObject());
|
||||||
|
return transactionManager;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,13 @@
|
||||||
|
package com.baeldung.multipledb.dao.product;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
import org.springframework.data.domain.Pageable;
|
||||||
|
import org.springframework.data.repository.PagingAndSortingRepository;
|
||||||
|
|
||||||
|
import com.baeldung.multipledb.model.product.ProductMultipleDB;
|
||||||
|
|
||||||
|
public interface ProductRepository extends PagingAndSortingRepository<ProductMultipleDB, Integer> {
|
||||||
|
|
||||||
|
List<ProductMultipleDB> findAllByPrice(double price, Pageable pageable);
|
||||||
|
}
|
|
@ -0,0 +1,67 @@
|
||||||
|
package com.baeldung.multipledb.model.product;
|
||||||
|
|
||||||
|
import javax.persistence.Entity;
|
||||||
|
import javax.persistence.Id;
|
||||||
|
import javax.persistence.Table;
|
||||||
|
|
||||||
|
@Entity
|
||||||
|
@Table(schema = "products")
|
||||||
|
public class ProductMultipleDB {
|
||||||
|
|
||||||
|
@Id
|
||||||
|
private int id;
|
||||||
|
|
||||||
|
private String name;
|
||||||
|
|
||||||
|
private double price;
|
||||||
|
|
||||||
|
public ProductMultipleDB() {
|
||||||
|
super();
|
||||||
|
}
|
||||||
|
|
||||||
|
private ProductMultipleDB(int id, String name, double price) {
|
||||||
|
super();
|
||||||
|
this.id = id;
|
||||||
|
this.name = name;
|
||||||
|
this.price = price;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static ProductMultipleDB from(int id, String name, double price) {
|
||||||
|
return new ProductMultipleDB(id, name, price);
|
||||||
|
}
|
||||||
|
|
||||||
|
public int getId() {
|
||||||
|
return id;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setId(final int id) {
|
||||||
|
this.id = id;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getName() {
|
||||||
|
return name;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setName(final String name) {
|
||||||
|
this.name = name;
|
||||||
|
}
|
||||||
|
|
||||||
|
public double getPrice() {
|
||||||
|
return price;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setPrice(final double price) {
|
||||||
|
this.price = price;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String toString() {
|
||||||
|
final StringBuilder builder = new StringBuilder();
|
||||||
|
builder.append("Product [name=")
|
||||||
|
.append(name)
|
||||||
|
.append(", id=")
|
||||||
|
.append(id)
|
||||||
|
.append("]");
|
||||||
|
return builder.toString();
|
||||||
|
}
|
||||||
|
}
|
|
@ -1,9 +1,9 @@
|
||||||
package com.baeldung.repository;
|
package com.baeldung.repository;
|
||||||
|
|
||||||
import org.springframework.data.jpa.repository.JpaRepository;
|
import org.springframework.data.jpa.repository.JpaRepository;
|
||||||
|
|
||||||
import com.baeldung.entity.Employee;
|
import com.baeldung.entity.Employee;
|
||||||
|
|
||||||
public interface EmployeeRepository extends JpaRepository<Employee, Long> {
|
public interface EmployeeRepository extends JpaRepository<Employee, Long> {
|
||||||
|
|
||||||
}
|
}
|
|
@ -1,17 +1,17 @@
|
||||||
package com.baeldung.repository;
|
package com.baeldung.repository;
|
||||||
|
|
||||||
import com.baeldung.model.User;
|
import com.baeldung.model.BasicUser;
|
||||||
import org.springframework.data.jpa.repository.EntityGraph;
|
import org.springframework.data.jpa.repository.EntityGraph;
|
||||||
import org.springframework.data.jpa.repository.JpaRepository;
|
import org.springframework.data.jpa.repository.JpaRepository;
|
||||||
|
|
||||||
import java.util.Optional;
|
import java.util.Optional;
|
||||||
|
|
||||||
public interface UserRepository extends JpaRepository<User, Long> {
|
public interface UserRepository extends JpaRepository<BasicUser, Long> {
|
||||||
|
|
||||||
@EntityGraph(attributePaths = "permissions")
|
@EntityGraph(attributePaths = "permissions")
|
||||||
Optional<User> findDetailedByUsername(String username);
|
Optional<BasicUser> findDetailedByUsername(String username);
|
||||||
|
|
||||||
Optional<User> findSummaryByUsername(String username);
|
Optional<BasicUser> findSummaryByUsername(String username);
|
||||||
|
|
||||||
Optional<User> findByUsername(String username);
|
Optional<BasicUser> findByUsername(String username);
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
package com.baeldung.service;
|
package com.baeldung.service;
|
||||||
|
|
||||||
import com.baeldung.model.User;
|
import com.baeldung.model.BasicUser;
|
||||||
import com.baeldung.repository.UserRepository;
|
import com.baeldung.repository.UserRepository;
|
||||||
import org.springframework.stereotype.Service;
|
import org.springframework.stereotype.Service;
|
||||||
import org.springframework.transaction.annotation.Transactional;
|
import org.springframework.transaction.annotation.Transactional;
|
||||||
|
@ -18,7 +18,7 @@ public class SimpleUserService implements UserService {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@Transactional(readOnly = true)
|
@Transactional(readOnly = true)
|
||||||
public Optional<User> findOne(String username) {
|
public Optional<BasicUser> findOne(String username) {
|
||||||
return userRepository.findDetailedByUsername(username);
|
return userRepository.findDetailedByUsername(username);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,9 +1,9 @@
|
||||||
package com.baeldung.service;
|
package com.baeldung.service;
|
||||||
|
|
||||||
import com.baeldung.model.User;
|
import com.baeldung.model.BasicUser;
|
||||||
|
|
||||||
import java.util.Optional;
|
import java.util.Optional;
|
||||||
|
|
||||||
public interface UserService {
|
public interface UserService {
|
||||||
Optional<User> findOne(String username);
|
Optional<BasicUser> findOne(String username);
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
package com.baeldung.web;
|
package com.baeldung.web;
|
||||||
|
|
||||||
import com.baeldung.model.User;
|
import com.baeldung.model.BasicUser;
|
||||||
|
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
|
|
||||||
|
@ -34,7 +34,7 @@ public class DetailedUserDto {
|
||||||
this.permissions = permissions;
|
this.permissions = permissions;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static DetailedUserDto fromEntity(User user) {
|
public static DetailedUserDto fromEntity(BasicUser user) {
|
||||||
DetailedUserDto detailed = new DetailedUserDto();
|
DetailedUserDto detailed = new DetailedUserDto();
|
||||||
detailed.setId(user.getId());
|
detailed.setId(user.getId());
|
||||||
detailed.setUsername(user.getUsername());
|
detailed.setUsername(user.getUsername());
|
||||||
|
|
|
@ -0,0 +1,6 @@
|
||||||
|
spring.main.allow-bean-definition-overriding=true
|
||||||
|
|
||||||
|
spring.jpa.properties.hibernate.jdbc.batch_size=4
|
||||||
|
spring.jpa.properties.hibernate.order_inserts=true
|
||||||
|
spring.jpa.properties.hibernate.order_updates=true
|
||||||
|
spring.jpa.properties.hibernate.generate_statistics=true
|
|
@ -0,0 +1,13 @@
|
||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<configuration>
|
||||||
|
<appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
|
||||||
|
<encoder>
|
||||||
|
<pattern>%d{HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n
|
||||||
|
</pattern>
|
||||||
|
</encoder>
|
||||||
|
</appender>
|
||||||
|
|
||||||
|
<root level="INFO">
|
||||||
|
<appender-ref ref="STDOUT" />
|
||||||
|
</root>
|
||||||
|
</configuration>
|
|
@ -0,0 +1,13 @@
|
||||||
|
# jdbc.X
|
||||||
|
jdbc.driverClassName=org.h2.Driver
|
||||||
|
user.jdbc.url=jdbc:h2:mem:spring_jpa_user;DB_CLOSE_DELAY=-1;INIT=CREATE SCHEMA IF NOT EXISTS USERS
|
||||||
|
product.jdbc.url=jdbc:h2:mem:spring_jpa_product;DB_CLOSE_DELAY=-1;INIT=CREATE SCHEMA IF NOT EXISTS PRODUCTS
|
||||||
|
jdbc.user=sa
|
||||||
|
jdbc.pass=sa
|
||||||
|
|
||||||
|
# hibernate.X
|
||||||
|
hibernate.dialect=org.hibernate.dialect.H2Dialect
|
||||||
|
hibernate.show_sql=false
|
||||||
|
hibernate.hbm2ddl.auto=create-drop
|
||||||
|
hibernate.cache.use_second_level_cache=false
|
||||||
|
hibernate.cache.use_query_cache=false
|
|
@ -0,0 +1,17 @@
|
||||||
|
package com.baeldung;
|
||||||
|
|
||||||
|
import org.junit.Test;
|
||||||
|
import org.junit.runner.RunWith;
|
||||||
|
import org.springframework.boot.test.context.SpringBootTest;
|
||||||
|
import org.springframework.test.context.junit4.SpringRunner;
|
||||||
|
|
||||||
|
import com.baeldung.boot.Application;
|
||||||
|
|
||||||
|
@RunWith(SpringRunner.class)
|
||||||
|
@SpringBootTest(classes = Application.class)
|
||||||
|
public class SpringContextIntegrationTest {
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void whenSpringContextIsBootstrapped_thenNoExceptions() {
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,17 @@
|
||||||
|
package com.baeldung;
|
||||||
|
|
||||||
|
import org.junit.Test;
|
||||||
|
import org.junit.runner.RunWith;
|
||||||
|
import org.springframework.boot.test.context.SpringBootTest;
|
||||||
|
import org.springframework.test.context.junit4.SpringRunner;
|
||||||
|
|
||||||
|
import com.baeldung.boot.Application;
|
||||||
|
|
||||||
|
@RunWith(SpringRunner.class)
|
||||||
|
@SpringBootTest(classes = Application.class)
|
||||||
|
public class SpringContextTest {
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void whenSpringContextIsBootstrapped_thenNoExceptions() {
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,19 @@
|
||||||
|
package com.baeldung;
|
||||||
|
|
||||||
|
import org.junit.Test;
|
||||||
|
import org.junit.runner.RunWith;
|
||||||
|
import org.springframework.boot.test.autoconfigure.orm.jpa.DataJpaTest;
|
||||||
|
import org.springframework.test.context.ContextConfiguration;
|
||||||
|
import org.springframework.test.context.junit4.SpringRunner;
|
||||||
|
|
||||||
|
import com.baeldung.boot.Application;
|
||||||
|
|
||||||
|
@RunWith(SpringRunner.class)
|
||||||
|
@DataJpaTest
|
||||||
|
@ContextConfiguration(classes = Application.class)
|
||||||
|
public class SpringJpaContextIntegrationTest {
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void whenSpringContextIsBootstrapped_thenNoExceptions() {
|
||||||
|
}
|
||||||
|
}
|
|
@ -3,12 +3,12 @@ package com.baeldung.batchinserts;
|
||||||
import static com.baeldung.batchinserts.TestObjectHelper.createSchool;
|
import static com.baeldung.batchinserts.TestObjectHelper.createSchool;
|
||||||
import static com.baeldung.batchinserts.TestObjectHelper.createStudent;
|
import static com.baeldung.batchinserts.TestObjectHelper.createStudent;
|
||||||
|
|
||||||
import com.baeldung.batchinserts.model.School;
|
|
||||||
import com.baeldung.batchinserts.model.Student;
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
import javax.persistence.EntityManager;
|
import javax.persistence.EntityManager;
|
||||||
import javax.persistence.PersistenceContext;
|
import javax.persistence.PersistenceContext;
|
||||||
import javax.persistence.TypedQuery;
|
import javax.persistence.TypedQuery;
|
||||||
|
|
||||||
import org.junit.After;
|
import org.junit.After;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import org.junit.runner.RunWith;
|
import org.junit.runner.RunWith;
|
||||||
|
@ -17,8 +17,12 @@ import org.springframework.test.context.ActiveProfiles;
|
||||||
import org.springframework.test.context.junit4.SpringRunner;
|
import org.springframework.test.context.junit4.SpringRunner;
|
||||||
import org.springframework.transaction.annotation.Transactional;
|
import org.springframework.transaction.annotation.Transactional;
|
||||||
|
|
||||||
|
import com.baeldung.batchinserts.model.School;
|
||||||
|
import com.baeldung.batchinserts.model.Student;
|
||||||
|
import com.baeldung.boot.Application;
|
||||||
|
|
||||||
@RunWith(SpringRunner.class)
|
@RunWith(SpringRunner.class)
|
||||||
@SpringBootTest
|
@SpringBootTest(classes = Application.class)
|
||||||
@Transactional
|
@Transactional
|
||||||
@ActiveProfiles("batchinserts")
|
@ActiveProfiles("batchinserts")
|
||||||
public class JpaBatchInsertsIntegrationTest {
|
public class JpaBatchInsertsIntegrationTest {
|
|
@ -3,6 +3,8 @@ package com.baeldung.batchinserts;
|
||||||
import static com.baeldung.batchinserts.TestObjectHelper.createSchool;
|
import static com.baeldung.batchinserts.TestObjectHelper.createSchool;
|
||||||
|
|
||||||
import com.baeldung.batchinserts.model.School;
|
import com.baeldung.batchinserts.model.School;
|
||||||
|
import com.baeldung.boot.Application;
|
||||||
|
|
||||||
import javax.persistence.EntityManager;
|
import javax.persistence.EntityManager;
|
||||||
import javax.persistence.PersistenceContext;
|
import javax.persistence.PersistenceContext;
|
||||||
import org.junit.After;
|
import org.junit.After;
|
||||||
|
@ -15,7 +17,7 @@ import org.springframework.test.context.junit4.SpringRunner;
|
||||||
import org.springframework.transaction.annotation.Transactional;
|
import org.springframework.transaction.annotation.Transactional;
|
||||||
|
|
||||||
@RunWith(SpringRunner.class)
|
@RunWith(SpringRunner.class)
|
||||||
@SpringBootTest
|
@SpringBootTest(classes = Application.class)
|
||||||
@Transactional
|
@Transactional
|
||||||
@ActiveProfiles("batchinserts")
|
@ActiveProfiles("batchinserts")
|
||||||
@TestPropertySource(properties = "spring.jpa.properties.hibernate.jdbc.batch_size=-1")
|
@TestPropertySource(properties = "spring.jpa.properties.hibernate.jdbc.batch_size=-1")
|
|
@ -0,0 +1,545 @@
|
||||||
|
package com.baeldung.boot.daos;
|
||||||
|
|
||||||
|
import org.junit.After;
|
||||||
|
import org.junit.Test;
|
||||||
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
import org.springframework.data.domain.Page;
|
||||||
|
import org.springframework.data.domain.PageRequest;
|
||||||
|
import org.springframework.data.domain.Sort;
|
||||||
|
import org.springframework.data.jpa.domain.JpaSort;
|
||||||
|
import org.springframework.data.mapping.PropertyReferenceException;
|
||||||
|
import org.springframework.transaction.annotation.Transactional;
|
||||||
|
|
||||||
|
import com.baeldung.boot.daos.user.UserRepository;
|
||||||
|
import com.baeldung.boot.domain.User;
|
||||||
|
|
||||||
|
import javax.persistence.EntityManager;
|
||||||
|
import javax.persistence.Query;
|
||||||
|
import java.time.LocalDate;
|
||||||
|
import java.util.*;
|
||||||
|
import java.util.function.Predicate;
|
||||||
|
import java.util.stream.Stream;
|
||||||
|
|
||||||
|
import static org.assertj.core.api.Assertions.assertThat;
|
||||||
|
import static org.junit.Assert.*;
|
||||||
|
|
||||||
|
public class UserRepositoryCommon {
|
||||||
|
|
||||||
|
final String USER_EMAIL = "email@example.com";
|
||||||
|
final String USER_EMAIL2 = "email2@example.com";
|
||||||
|
final String USER_EMAIL3 = "email3@example.com";
|
||||||
|
final String USER_EMAIL4 = "email4@example.com";
|
||||||
|
final Integer INACTIVE_STATUS = 0;
|
||||||
|
final Integer ACTIVE_STATUS = 1;
|
||||||
|
final String USER_EMAIL5 = "email5@example.com";
|
||||||
|
final String USER_EMAIL6 = "email6@example.com";
|
||||||
|
final String USER_NAME_ADAM = "Adam";
|
||||||
|
final String USER_NAME_PETER = "Peter";
|
||||||
|
|
||||||
|
@Autowired
|
||||||
|
protected UserRepository userRepository;
|
||||||
|
@Autowired
|
||||||
|
private EntityManager entityManager;
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@Transactional
|
||||||
|
public void givenUsersWithSameNameInDB_WhenFindAllByName_ThenReturnStreamOfUsers() {
|
||||||
|
User user1 = new User();
|
||||||
|
user1.setName(USER_NAME_ADAM);
|
||||||
|
user1.setEmail(USER_EMAIL);
|
||||||
|
userRepository.save(user1);
|
||||||
|
|
||||||
|
User user2 = new User();
|
||||||
|
user2.setName(USER_NAME_ADAM);
|
||||||
|
user2.setEmail(USER_EMAIL2);
|
||||||
|
userRepository.save(user2);
|
||||||
|
|
||||||
|
User user3 = new User();
|
||||||
|
user3.setName(USER_NAME_ADAM);
|
||||||
|
user3.setEmail(USER_EMAIL3);
|
||||||
|
userRepository.save(user3);
|
||||||
|
|
||||||
|
User user4 = new User();
|
||||||
|
user4.setName("SAMPLE");
|
||||||
|
user4.setEmail(USER_EMAIL4);
|
||||||
|
userRepository.save(user4);
|
||||||
|
|
||||||
|
try (Stream<User> foundUsersStream = userRepository.findAllByName(USER_NAME_ADAM)) {
|
||||||
|
assertThat(foundUsersStream.count()).isEqualTo(3l);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void givenUsersInDB_WhenFindAllWithQueryAnnotation_ThenReturnCollectionWithActiveUsers() {
|
||||||
|
User user1 = new User();
|
||||||
|
user1.setName(USER_NAME_ADAM);
|
||||||
|
user1.setEmail(USER_EMAIL);
|
||||||
|
user1.setStatus(ACTIVE_STATUS);
|
||||||
|
userRepository.save(user1);
|
||||||
|
|
||||||
|
User user2 = new User();
|
||||||
|
user2.setName(USER_NAME_ADAM);
|
||||||
|
user2.setEmail(USER_EMAIL2);
|
||||||
|
user2.setStatus(ACTIVE_STATUS);
|
||||||
|
userRepository.save(user2);
|
||||||
|
|
||||||
|
User user3 = new User();
|
||||||
|
user3.setName(USER_NAME_ADAM);
|
||||||
|
user3.setEmail(USER_EMAIL3);
|
||||||
|
user3.setStatus(INACTIVE_STATUS);
|
||||||
|
userRepository.save(user3);
|
||||||
|
|
||||||
|
Collection<User> allActiveUsers = userRepository.findAllActiveUsers();
|
||||||
|
|
||||||
|
assertThat(allActiveUsers.size()).isEqualTo(2);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void givenUsersInDB_WhenFindAllWithQueryAnnotationNative_ThenReturnCollectionWithActiveUsers() {
|
||||||
|
User user1 = new User();
|
||||||
|
user1.setName(USER_NAME_ADAM);
|
||||||
|
user1.setEmail(USER_EMAIL);
|
||||||
|
user1.setStatus(ACTIVE_STATUS);
|
||||||
|
userRepository.save(user1);
|
||||||
|
|
||||||
|
User user2 = new User();
|
||||||
|
user2.setName(USER_NAME_ADAM);
|
||||||
|
user2.setEmail(USER_EMAIL2);
|
||||||
|
user2.setStatus(ACTIVE_STATUS);
|
||||||
|
userRepository.save(user2);
|
||||||
|
|
||||||
|
User user3 = new User();
|
||||||
|
user3.setName(USER_NAME_ADAM);
|
||||||
|
user3.setEmail(USER_EMAIL3);
|
||||||
|
user3.setStatus(INACTIVE_STATUS);
|
||||||
|
userRepository.save(user3);
|
||||||
|
|
||||||
|
Collection<User> allActiveUsers = userRepository.findAllActiveUsersNative();
|
||||||
|
|
||||||
|
assertThat(allActiveUsers.size()).isEqualTo(2);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void givenUserInDB_WhenFindUserByStatusWithQueryAnnotation_ThenReturnActiveUser() {
|
||||||
|
User user = new User();
|
||||||
|
user.setName(USER_NAME_ADAM);
|
||||||
|
user.setEmail(USER_EMAIL);
|
||||||
|
user.setStatus(ACTIVE_STATUS);
|
||||||
|
userRepository.save(user);
|
||||||
|
|
||||||
|
User userByStatus = userRepository.findUserByStatus(ACTIVE_STATUS);
|
||||||
|
|
||||||
|
assertThat(userByStatus.getName()).isEqualTo(USER_NAME_ADAM);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void givenUserInDB_WhenFindUserByStatusWithQueryAnnotationNative_ThenReturnActiveUser() {
|
||||||
|
User user = new User();
|
||||||
|
user.setName(USER_NAME_ADAM);
|
||||||
|
user.setEmail(USER_EMAIL);
|
||||||
|
user.setStatus(ACTIVE_STATUS);
|
||||||
|
userRepository.save(user);
|
||||||
|
|
||||||
|
User userByStatus = userRepository.findUserByStatusNative(ACTIVE_STATUS);
|
||||||
|
|
||||||
|
assertThat(userByStatus.getName()).isEqualTo(USER_NAME_ADAM);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void givenUsersInDB_WhenFindUserByStatusAndNameWithQueryAnnotationIndexedParams_ThenReturnOneUser() {
|
||||||
|
User user = new User();
|
||||||
|
user.setName(USER_NAME_ADAM);
|
||||||
|
user.setEmail(USER_EMAIL);
|
||||||
|
user.setStatus(ACTIVE_STATUS);
|
||||||
|
userRepository.save(user);
|
||||||
|
|
||||||
|
User user2 = new User();
|
||||||
|
user2.setName(USER_NAME_PETER);
|
||||||
|
user2.setEmail(USER_EMAIL2);
|
||||||
|
user2.setStatus(ACTIVE_STATUS);
|
||||||
|
userRepository.save(user2);
|
||||||
|
|
||||||
|
User userByStatus = userRepository.findUserByStatusAndName(ACTIVE_STATUS, USER_NAME_ADAM);
|
||||||
|
|
||||||
|
assertThat(userByStatus.getName()).isEqualTo(USER_NAME_ADAM);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void givenUsersInDB_WhenFindUserByStatusAndNameWithQueryAnnotationNamedParams_ThenReturnOneUser() {
|
||||||
|
User user = new User();
|
||||||
|
user.setName(USER_NAME_ADAM);
|
||||||
|
user.setEmail(USER_EMAIL);
|
||||||
|
user.setStatus(ACTIVE_STATUS);
|
||||||
|
userRepository.save(user);
|
||||||
|
|
||||||
|
User user2 = new User();
|
||||||
|
user2.setName(USER_NAME_PETER);
|
||||||
|
user2.setEmail(USER_EMAIL2);
|
||||||
|
user2.setStatus(ACTIVE_STATUS);
|
||||||
|
userRepository.save(user2);
|
||||||
|
|
||||||
|
User userByStatus = userRepository.findUserByStatusAndNameNamedParams(ACTIVE_STATUS, USER_NAME_ADAM);
|
||||||
|
|
||||||
|
assertThat(userByStatus.getName()).isEqualTo(USER_NAME_ADAM);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void givenUsersInDB_WhenFindUserByStatusAndNameWithQueryAnnotationNativeNamedParams_ThenReturnOneUser() {
|
||||||
|
User user = new User();
|
||||||
|
user.setName(USER_NAME_ADAM);
|
||||||
|
user.setEmail(USER_EMAIL);
|
||||||
|
user.setStatus(ACTIVE_STATUS);
|
||||||
|
userRepository.save(user);
|
||||||
|
|
||||||
|
User user2 = new User();
|
||||||
|
user2.setName(USER_NAME_PETER);
|
||||||
|
user2.setEmail(USER_EMAIL2);
|
||||||
|
user2.setStatus(ACTIVE_STATUS);
|
||||||
|
userRepository.save(user2);
|
||||||
|
|
||||||
|
User userByStatus = userRepository.findUserByStatusAndNameNamedParamsNative(ACTIVE_STATUS, USER_NAME_ADAM);
|
||||||
|
|
||||||
|
assertThat(userByStatus.getName()).isEqualTo(USER_NAME_ADAM);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void givenUsersInDB_WhenFindUserByStatusAndNameWithQueryAnnotationNamedParamsCustomNames_ThenReturnOneUser() {
|
||||||
|
User user = new User();
|
||||||
|
user.setName(USER_NAME_ADAM);
|
||||||
|
user.setEmail(USER_EMAIL);
|
||||||
|
user.setStatus(ACTIVE_STATUS);
|
||||||
|
userRepository.save(user);
|
||||||
|
|
||||||
|
User user2 = new User();
|
||||||
|
user2.setName(USER_NAME_PETER);
|
||||||
|
user2.setEmail(USER_EMAIL2);
|
||||||
|
user2.setStatus(ACTIVE_STATUS);
|
||||||
|
userRepository.save(user2);
|
||||||
|
|
||||||
|
User userByStatus = userRepository.findUserByUserStatusAndUserName(ACTIVE_STATUS, USER_NAME_ADAM);
|
||||||
|
|
||||||
|
assertThat(userByStatus.getName()).isEqualTo(USER_NAME_ADAM);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void givenUsersInDB_WhenFindUserByNameLikeWithQueryAnnotationIndexedParams_ThenReturnUser() {
|
||||||
|
User user = new User();
|
||||||
|
user.setName(USER_NAME_ADAM);
|
||||||
|
user.setEmail(USER_EMAIL);
|
||||||
|
user.setStatus(ACTIVE_STATUS);
|
||||||
|
userRepository.save(user);
|
||||||
|
|
||||||
|
User userByStatus = userRepository.findUserByNameLike("Ad");
|
||||||
|
|
||||||
|
assertThat(userByStatus.getName()).isEqualTo(USER_NAME_ADAM);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void givenUsersInDB_WhenFindUserByNameLikeWithQueryAnnotationNamedParams_ThenReturnUser() {
|
||||||
|
User user = new User();
|
||||||
|
user.setName(USER_NAME_ADAM);
|
||||||
|
user.setEmail(USER_EMAIL);
|
||||||
|
user.setStatus(ACTIVE_STATUS);
|
||||||
|
userRepository.save(user);
|
||||||
|
|
||||||
|
User userByStatus = userRepository.findUserByNameLikeNamedParam("Ad");
|
||||||
|
|
||||||
|
assertThat(userByStatus.getName()).isEqualTo(USER_NAME_ADAM);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void givenUsersInDB_WhenFindUserByNameLikeWithQueryAnnotationNative_ThenReturnUser() {
|
||||||
|
User user = new User();
|
||||||
|
user.setName(USER_NAME_ADAM);
|
||||||
|
user.setEmail(USER_EMAIL);
|
||||||
|
user.setStatus(ACTIVE_STATUS);
|
||||||
|
userRepository.save(user);
|
||||||
|
|
||||||
|
User userByStatus = userRepository.findUserByNameLikeNative("Ad");
|
||||||
|
|
||||||
|
assertThat(userByStatus.getName()).isEqualTo(USER_NAME_ADAM);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void givenUsersInDB_WhenFindAllWithSortByName_ThenReturnUsersSorted() {
|
||||||
|
userRepository.save(new User(USER_NAME_ADAM, LocalDate.now(), USER_EMAIL, ACTIVE_STATUS));
|
||||||
|
userRepository.save(new User(USER_NAME_PETER, LocalDate.now(), USER_EMAIL2, ACTIVE_STATUS));
|
||||||
|
userRepository.save(new User("SAMPLE", LocalDate.now(), USER_EMAIL3, INACTIVE_STATUS));
|
||||||
|
|
||||||
|
List<User> usersSortByName = userRepository.findAll(new Sort(Sort.Direction.ASC, "name"));
|
||||||
|
|
||||||
|
assertThat(usersSortByName.get(0)
|
||||||
|
.getName()).isEqualTo(USER_NAME_ADAM);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test(expected = PropertyReferenceException.class)
|
||||||
|
public void givenUsersInDB_WhenFindAllSortWithFunction_ThenThrowException() {
|
||||||
|
userRepository.save(new User(USER_NAME_ADAM, LocalDate.now(), USER_EMAIL, ACTIVE_STATUS));
|
||||||
|
userRepository.save(new User(USER_NAME_PETER, LocalDate.now(), USER_EMAIL2, ACTIVE_STATUS));
|
||||||
|
userRepository.save(new User("SAMPLE", LocalDate.now(), USER_EMAIL3, INACTIVE_STATUS));
|
||||||
|
|
||||||
|
userRepository.findAll(new Sort(Sort.Direction.ASC, "name"));
|
||||||
|
|
||||||
|
List<User> usersSortByNameLength = userRepository.findAll(Sort.by("LENGTH(name)"));
|
||||||
|
|
||||||
|
assertThat(usersSortByNameLength.get(0)
|
||||||
|
.getName()).isEqualTo(USER_NAME_ADAM);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void givenUsersInDB_WhenFindAllSortWithFunctionQueryAnnotationJPQL_ThenReturnUsersSorted() {
|
||||||
|
userRepository.save(new User(USER_NAME_ADAM, LocalDate.now(), USER_EMAIL, ACTIVE_STATUS));
|
||||||
|
userRepository.save(new User(USER_NAME_PETER, LocalDate.now(), USER_EMAIL2, ACTIVE_STATUS));
|
||||||
|
userRepository.save(new User("SAMPLE", LocalDate.now(), USER_EMAIL3, INACTIVE_STATUS));
|
||||||
|
|
||||||
|
userRepository.findAllUsers(Sort.by("name"));
|
||||||
|
|
||||||
|
List<User> usersSortByNameLength = userRepository.findAllUsers(JpaSort.unsafe("LENGTH(name)"));
|
||||||
|
|
||||||
|
assertThat(usersSortByNameLength.get(0)
|
||||||
|
.getName()).isEqualTo(USER_NAME_ADAM);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void givenUsersInDB_WhenFindAllWithPageRequestQueryAnnotationJPQL_ThenReturnPageOfUsers() {
|
||||||
|
userRepository.save(new User(USER_NAME_ADAM, LocalDate.now(), USER_EMAIL, ACTIVE_STATUS));
|
||||||
|
userRepository.save(new User(USER_NAME_PETER, LocalDate.now(), USER_EMAIL2, ACTIVE_STATUS));
|
||||||
|
userRepository.save(new User("SAMPLE", LocalDate.now(), USER_EMAIL3, INACTIVE_STATUS));
|
||||||
|
userRepository.save(new User("SAMPLE1", LocalDate.now(), USER_EMAIL4, INACTIVE_STATUS));
|
||||||
|
userRepository.save(new User("SAMPLE2", LocalDate.now(), USER_EMAIL5, INACTIVE_STATUS));
|
||||||
|
userRepository.save(new User("SAMPLE3", LocalDate.now(), USER_EMAIL6, INACTIVE_STATUS));
|
||||||
|
|
||||||
|
Page<User> usersPage = userRepository.findAllUsersWithPagination(PageRequest.of(1, 3));
|
||||||
|
|
||||||
|
assertThat(usersPage.getContent()
|
||||||
|
.get(0)
|
||||||
|
.getName()).isEqualTo("SAMPLE1");
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void givenUsersInDB_WhenFindAllWithPageRequestQueryAnnotationNative_ThenReturnPageOfUsers() {
|
||||||
|
userRepository.save(new User(USER_NAME_ADAM, LocalDate.now(), USER_EMAIL, ACTIVE_STATUS));
|
||||||
|
userRepository.save(new User(USER_NAME_PETER, LocalDate.now(), USER_EMAIL2, ACTIVE_STATUS));
|
||||||
|
userRepository.save(new User("SAMPLE", LocalDate.now(), USER_EMAIL3, INACTIVE_STATUS));
|
||||||
|
userRepository.save(new User("SAMPLE1", LocalDate.now(), USER_EMAIL4, INACTIVE_STATUS));
|
||||||
|
userRepository.save(new User("SAMPLE2", LocalDate.now(), USER_EMAIL5, INACTIVE_STATUS));
|
||||||
|
userRepository.save(new User("SAMPLE3", LocalDate.now(), USER_EMAIL6, INACTIVE_STATUS));
|
||||||
|
|
||||||
|
Page<User> usersSortByNameLength = userRepository.findAllUsersWithPaginationNative(PageRequest.of(1, 3));
|
||||||
|
|
||||||
|
assertThat(usersSortByNameLength.getContent()
|
||||||
|
.get(0)
|
||||||
|
.getName()).isEqualTo(USER_NAME_PETER);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@Transactional
|
||||||
|
public void givenUsersInDB_WhenUpdateStatusForNameModifyingQueryAnnotationJPQL_ThenModifyMatchingUsers() {
|
||||||
|
userRepository.save(new User("SAMPLE", LocalDate.now(), USER_EMAIL, ACTIVE_STATUS));
|
||||||
|
userRepository.save(new User("SAMPLE1", LocalDate.now(), USER_EMAIL2, ACTIVE_STATUS));
|
||||||
|
userRepository.save(new User("SAMPLE", LocalDate.now(), USER_EMAIL3, ACTIVE_STATUS));
|
||||||
|
userRepository.save(new User("SAMPLE3", LocalDate.now(), USER_EMAIL4, ACTIVE_STATUS));
|
||||||
|
|
||||||
|
int updatedUsersSize = userRepository.updateUserSetStatusForName(INACTIVE_STATUS, "SAMPLE");
|
||||||
|
|
||||||
|
assertThat(updatedUsersSize).isEqualTo(2);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void givenUsersInDB_WhenFindByEmailsWithDynamicQuery_ThenReturnCollection() {
|
||||||
|
|
||||||
|
User user1 = new User();
|
||||||
|
user1.setEmail(USER_EMAIL);
|
||||||
|
userRepository.save(user1);
|
||||||
|
|
||||||
|
User user2 = new User();
|
||||||
|
user2.setEmail(USER_EMAIL2);
|
||||||
|
userRepository.save(user2);
|
||||||
|
|
||||||
|
User user3 = new User();
|
||||||
|
user3.setEmail(USER_EMAIL3);
|
||||||
|
userRepository.save(user3);
|
||||||
|
|
||||||
|
Set<String> emails = new HashSet<>();
|
||||||
|
emails.add(USER_EMAIL2);
|
||||||
|
emails.add(USER_EMAIL3);
|
||||||
|
|
||||||
|
Collection<User> usersWithEmails = userRepository.findUserByEmails(emails);
|
||||||
|
|
||||||
|
assertThat(usersWithEmails.size()).isEqualTo(2);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void givenUsersInDBWhenFindByNameListReturnCollection() {
|
||||||
|
|
||||||
|
User user1 = new User();
|
||||||
|
user1.setName(USER_NAME_ADAM);
|
||||||
|
user1.setEmail(USER_EMAIL);
|
||||||
|
userRepository.save(user1);
|
||||||
|
|
||||||
|
User user2 = new User();
|
||||||
|
user2.setName(USER_NAME_PETER);
|
||||||
|
user2.setEmail(USER_EMAIL2);
|
||||||
|
userRepository.save(user2);
|
||||||
|
|
||||||
|
List<String> names = Arrays.asList(USER_NAME_ADAM, USER_NAME_PETER);
|
||||||
|
|
||||||
|
List<User> usersWithNames = userRepository.findUserByNameList(names);
|
||||||
|
|
||||||
|
assertThat(usersWithNames.size()).isEqualTo(2);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@Transactional
|
||||||
|
public void whenInsertedWithQuery_ThenUserIsPersisted() {
|
||||||
|
userRepository.insertUser(USER_NAME_ADAM, 1, USER_EMAIL, ACTIVE_STATUS, true);
|
||||||
|
userRepository.insertUser(USER_NAME_PETER, 1, USER_EMAIL2, ACTIVE_STATUS, true);
|
||||||
|
|
||||||
|
User userAdam = userRepository.findUserByNameLike(USER_NAME_ADAM);
|
||||||
|
User userPeter = userRepository.findUserByNameLike(USER_NAME_PETER);
|
||||||
|
|
||||||
|
assertThat(userAdam).isNotNull();
|
||||||
|
assertThat(userAdam.getEmail()).isEqualTo(USER_EMAIL);
|
||||||
|
assertThat(userPeter).isNotNull();
|
||||||
|
assertThat(userPeter.getEmail()).isEqualTo(USER_EMAIL2);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@Transactional
|
||||||
|
public void givenTwoUsers_whenFindByNameUsr01_ThenUserUsr01() {
|
||||||
|
User usr01 = new User("usr01", LocalDate.now(), "usr01@baeldung.com", 1);
|
||||||
|
User usr02 = new User("usr02", LocalDate.now(), "usr02@baeldung.com", 1);
|
||||||
|
|
||||||
|
userRepository.save(usr01);
|
||||||
|
userRepository.save(usr02);
|
||||||
|
|
||||||
|
try (Stream<User> users = userRepository.findAllByName("usr01")) {
|
||||||
|
assertTrue(users.allMatch(usr -> usr.equals(usr01)));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@Transactional
|
||||||
|
public void givenTwoUsers_whenFindByNameUsr00_ThenNoUsers() {
|
||||||
|
User usr01 = new User("usr01", LocalDate.now(), "usr01@baeldung.com", 1);
|
||||||
|
User usr02 = new User("usr02", LocalDate.now(), "usr02@baeldung.com", 1);
|
||||||
|
|
||||||
|
userRepository.save(usr01);
|
||||||
|
userRepository.save(usr02);
|
||||||
|
|
||||||
|
try (Stream<User> users = userRepository.findAllByName("usr00")) {
|
||||||
|
assertEquals(0, users.count());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void givenTwoUsers_whenFindUsersWithGmailAddress_ThenUserUsr02() {
|
||||||
|
User usr01 = new User("usr01", LocalDate.now(), "usr01@baeldung.com", 1);
|
||||||
|
User usr02 = new User("usr02", LocalDate.now(), "usr02@gmail.com", 1);
|
||||||
|
|
||||||
|
userRepository.save(usr01);
|
||||||
|
userRepository.save(usr02);
|
||||||
|
|
||||||
|
List<User> users = userRepository.findUsersWithGmailAddress();
|
||||||
|
assertEquals(1, users.size());
|
||||||
|
assertEquals(usr02, users.get(0));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@Transactional
|
||||||
|
public void givenTwoUsers_whenDeleteAllByCreationDateAfter_ThenOneUserRemains() {
|
||||||
|
User usr01 = new User("usr01", LocalDate.of(2018, 1, 1), "usr01@baeldung.com", 1);
|
||||||
|
User usr02 = new User("usr02", LocalDate.of(2018, 6, 1), "usr02@baeldung.com", 1);
|
||||||
|
|
||||||
|
userRepository.save(usr01);
|
||||||
|
userRepository.save(usr02);
|
||||||
|
|
||||||
|
userRepository.deleteAllByCreationDateAfter(LocalDate.of(2018, 5, 1));
|
||||||
|
|
||||||
|
List<User> users = userRepository.findAll();
|
||||||
|
|
||||||
|
assertEquals(1, users.size());
|
||||||
|
assertEquals(usr01, users.get(0));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void givenTwoUsers_whenFindAllUsersByPredicates_ThenUserUsr01() {
|
||||||
|
User usr01 = new User("usr01", LocalDate.of(2018, 1, 1), "usr01@baeldung.com", 1);
|
||||||
|
User usr02 = new User("usr02", LocalDate.of(2018, 6, 1), "usr02@baeldung.org", 1);
|
||||||
|
|
||||||
|
userRepository.save(usr01);
|
||||||
|
userRepository.save(usr02);
|
||||||
|
|
||||||
|
List<Predicate<User>> predicates = new ArrayList<>();
|
||||||
|
predicates.add(usr -> usr.getCreationDate().isAfter(LocalDate.of(2017, 12, 31)));
|
||||||
|
predicates.add(usr -> usr.getEmail().endsWith(".com"));
|
||||||
|
|
||||||
|
List<User> users = userRepository.findAllUsersByPredicates(predicates);
|
||||||
|
|
||||||
|
assertEquals(1, users.size());
|
||||||
|
assertEquals(usr01, users.get(0));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@Transactional
|
||||||
|
public void givenTwoUsers_whenDeactivateUsersNotLoggedInSince_ThenUserUsr02Deactivated() {
|
||||||
|
User usr01 = new User("usr01", LocalDate.of(2018, 1, 1), "usr01@baeldung.com", 1);
|
||||||
|
usr01.setLastLoginDate(LocalDate.now());
|
||||||
|
User usr02 = new User("usr02", LocalDate.of(2018, 6, 1), "usr02@baeldung.org", 1);
|
||||||
|
usr02.setLastLoginDate(LocalDate.of(2018, 7, 20));
|
||||||
|
|
||||||
|
userRepository.save(usr01);
|
||||||
|
userRepository.save(usr02);
|
||||||
|
|
||||||
|
userRepository.deactivateUsersNotLoggedInSince(LocalDate.of(2018, 8, 1));
|
||||||
|
|
||||||
|
List<User> users = userRepository.findAllUsers(Sort.by(Sort.Order.asc("name")));
|
||||||
|
assertTrue(users.get(0).isActive());
|
||||||
|
assertFalse(users.get(1).isActive());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@Transactional
|
||||||
|
public void givenTwoUsers_whenDeleteDeactivatedUsers_ThenUserUsr02Deleted() {
|
||||||
|
User usr01 = new User("usr01", LocalDate.of(2018, 1, 1), "usr01@baeldung.com", 1);
|
||||||
|
usr01.setLastLoginDate(LocalDate.now());
|
||||||
|
User usr02 = new User("usr02", LocalDate.of(2018, 6, 1), "usr02@baeldung.com", 0);
|
||||||
|
usr02.setLastLoginDate(LocalDate.of(2018, 7, 20));
|
||||||
|
usr02.setActive(false);
|
||||||
|
|
||||||
|
userRepository.save(usr01);
|
||||||
|
userRepository.save(usr02);
|
||||||
|
|
||||||
|
int deletedUsersCount = userRepository.deleteDeactivatedUsers();
|
||||||
|
|
||||||
|
List<User> users = userRepository.findAll();
|
||||||
|
assertEquals(1, users.size());
|
||||||
|
assertEquals(usr01, users.get(0));
|
||||||
|
assertEquals(1, deletedUsersCount);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@Transactional
|
||||||
|
public void givenTwoUsers_whenAddDeletedColumn_ThenUsersHaveDeletedColumn() {
|
||||||
|
User usr01 = new User("usr01", LocalDate.of(2018, 1, 1), "usr01@baeldung.com", 1);
|
||||||
|
usr01.setLastLoginDate(LocalDate.now());
|
||||||
|
User usr02 = new User("usr02", LocalDate.of(2018, 6, 1), "usr02@baeldung.org", 1);
|
||||||
|
usr02.setLastLoginDate(LocalDate.of(2018, 7, 20));
|
||||||
|
usr02.setActive(false);
|
||||||
|
|
||||||
|
userRepository.save(usr01);
|
||||||
|
userRepository.save(usr02);
|
||||||
|
|
||||||
|
userRepository.addDeletedColumn();
|
||||||
|
|
||||||
|
Query nativeQuery = entityManager.createNativeQuery("select deleted from USERS where NAME = 'usr01'");
|
||||||
|
assertEquals(0, nativeQuery.getResultList().get(0));
|
||||||
|
}
|
||||||
|
|
||||||
|
@After
|
||||||
|
public void cleanUp() {
|
||||||
|
userRepository.deleteAll();
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,43 @@
|
||||||
|
package com.baeldung.boot.daos;
|
||||||
|
|
||||||
|
import com.baeldung.boot.Application;
|
||||||
|
import com.baeldung.boot.domain.User;
|
||||||
|
import com.baeldung.util.BaeldungPostgresqlContainer;
|
||||||
|
import org.junit.ClassRule;
|
||||||
|
import org.junit.Test;
|
||||||
|
import org.junit.runner.RunWith;
|
||||||
|
import org.springframework.boot.test.context.SpringBootTest;
|
||||||
|
import org.springframework.test.context.ActiveProfiles;
|
||||||
|
import org.springframework.test.context.junit4.SpringRunner;
|
||||||
|
import org.springframework.transaction.annotation.Transactional;
|
||||||
|
import org.testcontainers.containers.PostgreSQLContainer;
|
||||||
|
|
||||||
|
import java.time.LocalDate;
|
||||||
|
|
||||||
|
import static org.assertj.core.api.Assertions.assertThat;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Created by adam.
|
||||||
|
*/
|
||||||
|
@RunWith(SpringRunner.class)
|
||||||
|
@SpringBootTest(classes = Application.class)
|
||||||
|
@ActiveProfiles({"tc", "tc-auto"})
|
||||||
|
public class UserRepositoryTCAutoLiveTest extends UserRepositoryCommon {
|
||||||
|
|
||||||
|
@ClassRule
|
||||||
|
public static PostgreSQLContainer<BaeldungPostgresqlContainer> postgreSQLContainer = BaeldungPostgresqlContainer.getInstance();
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@Transactional
|
||||||
|
public void givenUsersInDB_WhenUpdateStatusForNameModifyingQueryAnnotationNativePostgres_ThenModifyMatchingUsers() {
|
||||||
|
userRepository.save(new User("SAMPLE", LocalDate.now(), USER_EMAIL, ACTIVE_STATUS));
|
||||||
|
userRepository.save(new User("SAMPLE1", LocalDate.now(), USER_EMAIL2, ACTIVE_STATUS));
|
||||||
|
userRepository.save(new User("SAMPLE", LocalDate.now(), USER_EMAIL3, ACTIVE_STATUS));
|
||||||
|
userRepository.save(new User("SAMPLE3", LocalDate.now(), USER_EMAIL4, ACTIVE_STATUS));
|
||||||
|
userRepository.flush();
|
||||||
|
|
||||||
|
int updatedUsersSize = userRepository.updateUserSetStatusForNameNativePostgres(INACTIVE_STATUS, "SAMPLE");
|
||||||
|
|
||||||
|
assertThat(updatedUsersSize).isEqualTo(2);
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,58 @@
|
||||||
|
package com.baeldung.boot.daos;
|
||||||
|
|
||||||
|
import com.baeldung.boot.Application;
|
||||||
|
import com.baeldung.boot.domain.User;
|
||||||
|
import org.junit.ClassRule;
|
||||||
|
import org.junit.Test;
|
||||||
|
import org.junit.runner.RunWith;
|
||||||
|
import org.springframework.boot.test.context.SpringBootTest;
|
||||||
|
import org.springframework.boot.test.util.TestPropertyValues;
|
||||||
|
import org.springframework.context.ApplicationContextInitializer;
|
||||||
|
import org.springframework.context.ConfigurableApplicationContext;
|
||||||
|
import org.springframework.test.context.ActiveProfiles;
|
||||||
|
import org.springframework.test.context.ContextConfiguration;
|
||||||
|
import org.springframework.test.context.junit4.SpringRunner;
|
||||||
|
import org.springframework.transaction.annotation.Transactional;
|
||||||
|
import org.testcontainers.containers.PostgreSQLContainer;
|
||||||
|
|
||||||
|
import java.time.LocalDate;
|
||||||
|
|
||||||
|
import static org.assertj.core.api.Assertions.assertThat;
|
||||||
|
|
||||||
|
@RunWith(SpringRunner.class)
|
||||||
|
@SpringBootTest(classes = Application.class)
|
||||||
|
@ActiveProfiles("tc")
|
||||||
|
@ContextConfiguration(initializers = {UserRepositoryTCLiveTest.Initializer.class})
|
||||||
|
public class UserRepositoryTCLiveTest extends UserRepositoryCommon {
|
||||||
|
|
||||||
|
@ClassRule
|
||||||
|
public static PostgreSQLContainer postgreSQLContainer = new PostgreSQLContainer("postgres:11.1")
|
||||||
|
.withDatabaseName("integration-tests-db")
|
||||||
|
.withUsername("sa")
|
||||||
|
.withPassword("sa");
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@Transactional
|
||||||
|
public void givenUsersInDB_WhenUpdateStatusForNameModifyingQueryAnnotationNative_ThenModifyMatchingUsers() {
|
||||||
|
userRepository.save(new User("SAMPLE", LocalDate.now(), USER_EMAIL, ACTIVE_STATUS));
|
||||||
|
userRepository.save(new User("SAMPLE1", LocalDate.now(), USER_EMAIL2, ACTIVE_STATUS));
|
||||||
|
userRepository.save(new User("SAMPLE", LocalDate.now(), USER_EMAIL3, ACTIVE_STATUS));
|
||||||
|
userRepository.save(new User("SAMPLE3", LocalDate.now(), USER_EMAIL4, ACTIVE_STATUS));
|
||||||
|
userRepository.flush();
|
||||||
|
|
||||||
|
int updatedUsersSize = userRepository.updateUserSetStatusForNameNativePostgres(INACTIVE_STATUS, "SAMPLE");
|
||||||
|
|
||||||
|
assertThat(updatedUsersSize).isEqualTo(2);
|
||||||
|
}
|
||||||
|
|
||||||
|
static class Initializer
|
||||||
|
implements ApplicationContextInitializer<ConfigurableApplicationContext> {
|
||||||
|
public void initialize(ConfigurableApplicationContext configurableApplicationContext) {
|
||||||
|
TestPropertyValues.of(
|
||||||
|
"spring.datasource.url=" + postgreSQLContainer.getJdbcUrl(),
|
||||||
|
"spring.datasource.username=" + postgreSQLContainer.getUsername(),
|
||||||
|
"spring.datasource.password=" + postgreSQLContainer.getPassword()
|
||||||
|
).applyTo(configurableApplicationContext.getEnvironment());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -18,12 +18,10 @@ import org.springframework.data.domain.Page;
|
||||||
import org.springframework.data.domain.PageRequest;
|
import org.springframework.data.domain.PageRequest;
|
||||||
import org.springframework.data.domain.Pageable;
|
import org.springframework.data.domain.Pageable;
|
||||||
import org.springframework.data.domain.Sort;
|
import org.springframework.data.domain.Sort;
|
||||||
import org.springframework.test.context.ContextConfiguration;
|
|
||||||
import org.springframework.test.context.junit4.SpringRunner;
|
import org.springframework.test.context.junit4.SpringRunner;
|
||||||
import org.springframework.transaction.annotation.EnableTransactionManagement;
|
import org.springframework.transaction.annotation.EnableTransactionManagement;
|
||||||
import org.springframework.transaction.annotation.Transactional;
|
import org.springframework.transaction.annotation.Transactional;
|
||||||
|
|
||||||
import com.baeldung.multipledb.PersistenceProductConfiguration;
|
|
||||||
import com.baeldung.multipledb.dao.product.ProductRepository;
|
import com.baeldung.multipledb.dao.product.ProductRepository;
|
||||||
import com.baeldung.multipledb.model.product.ProductMultipleDB;
|
import com.baeldung.multipledb.model.product.ProductMultipleDB;
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
package com.baeldung.osiv;
|
package com.baeldung.osiv;
|
||||||
|
|
||||||
import com.baeldung.model.User;
|
import com.baeldung.model.BasicUser;
|
||||||
import com.baeldung.repository.UserRepository;
|
import com.baeldung.repository.UserRepository;
|
||||||
import org.junit.jupiter.api.AfterEach;
|
import org.junit.jupiter.api.AfterEach;
|
||||||
import org.junit.jupiter.api.BeforeEach;
|
import org.junit.jupiter.api.BeforeEach;
|
||||||
|
@ -32,7 +32,7 @@ class UserControllerIntegrationTest {
|
||||||
|
|
||||||
@BeforeEach
|
@BeforeEach
|
||||||
void setUp() {
|
void setUp() {
|
||||||
User user = new User();
|
BasicUser user = new BasicUser();
|
||||||
user.setUsername("root");
|
user.setUsername("root");
|
||||||
user.setPermissions(new HashSet<>(Arrays.asList("PERM_READ", "PERM_WRITE")));
|
user.setPermissions(new HashSet<>(Arrays.asList("PERM_READ", "PERM_WRITE")));
|
||||||
|
|
||||||
|
|
|
@ -5,13 +5,14 @@ import static org.assertj.core.api.AssertionsForClassTypes.assertThat;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import org.junit.runner.RunWith;
|
import org.junit.runner.RunWith;
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
import org.springframework.boot.test.autoconfigure.orm.jpa.DataJpaTest;
|
import org.springframework.boot.test.context.SpringBootTest;
|
||||||
import org.springframework.test.context.junit4.SpringRunner;
|
import org.springframework.test.context.junit4.SpringRunner;
|
||||||
|
|
||||||
|
import com.baeldung.boot.Application;
|
||||||
import com.baeldung.entity.Employee;
|
import com.baeldung.entity.Employee;
|
||||||
|
|
||||||
@RunWith(SpringRunner.class)
|
@RunWith(SpringRunner.class)
|
||||||
@DataJpaTest
|
@SpringBootTest(classes = Application.class)
|
||||||
public class EmployeeRepositoryIntegrationTest {
|
public class EmployeeRepositoryIntegrationTest {
|
||||||
|
|
||||||
private static final Employee EMPLOYEE1 = new Employee(1L, "John");
|
private static final Employee EMPLOYEE1 = new Employee(1L, "John");
|
||||||
|
@ -25,7 +26,7 @@ public class EmployeeRepositoryIntegrationTest {
|
||||||
employeeRepository.save(EMPLOYEE1);
|
employeeRepository.save(EMPLOYEE1);
|
||||||
assertEmployeePersisted(EMPLOYEE1);
|
assertEmployeePersisted(EMPLOYEE1);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void givenEmployeeEntity_whenInsertWithSaveAndFlush_ThenEmployeeIsPersisted() {
|
public void givenEmployeeEntity_whenInsertWithSaveAndFlush_ThenEmployeeIsPersisted() {
|
||||||
employeeRepository.saveAndFlush(EMPLOYEE2);
|
employeeRepository.saveAndFlush(EMPLOYEE2);
|
|
@ -0,0 +1,35 @@
|
||||||
|
package com.baeldung.util;
|
||||||
|
|
||||||
|
import org.testcontainers.containers.PostgreSQLContainer;
|
||||||
|
|
||||||
|
public class BaeldungPostgresqlContainer extends PostgreSQLContainer<BaeldungPostgresqlContainer> {
|
||||||
|
|
||||||
|
private static final String IMAGE_VERSION = "postgres:11.1";
|
||||||
|
|
||||||
|
private static BaeldungPostgresqlContainer container;
|
||||||
|
|
||||||
|
|
||||||
|
private BaeldungPostgresqlContainer() {
|
||||||
|
super(IMAGE_VERSION);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static BaeldungPostgresqlContainer getInstance() {
|
||||||
|
if (container == null) {
|
||||||
|
container = new BaeldungPostgresqlContainer();
|
||||||
|
}
|
||||||
|
return container;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void start() {
|
||||||
|
super.start();
|
||||||
|
System.setProperty("DB_URL", container.getJdbcUrl());
|
||||||
|
System.setProperty("DB_USERNAME", container.getUsername());
|
||||||
|
System.setProperty("DB_PASSWORD", container.getPassword());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void stop() {
|
||||||
|
//do nothing, JVM handles shut down
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,4 @@
|
||||||
|
# configuration for test containers testing
|
||||||
|
spring.datasource.url=${DB_URL}
|
||||||
|
spring.datasource.username=${DB_USERNAME}
|
||||||
|
spring.datasource.password=${DB_PASSWORD}
|
|
@ -0,0 +1,4 @@
|
||||||
|
# configuration for Test Containers testing
|
||||||
|
spring.datasource.driver-class-name=org.postgresql.Driver
|
||||||
|
spring.jpa.hibernate.ddl-auto=create-drop
|
||||||
|
spring.jpa.properties.hibernate.temp.use_jdbc_metadata_defaults=false
|
|
@ -0,0 +1,12 @@
|
||||||
|
### Relevant Articles:
|
||||||
|
- [Derived Query Methods in Spring Data JPA Repositories](https://www.baeldung.com/spring-data-derived-queries)
|
||||||
|
- [LIKE Queries in Spring JPA Repositories](https://www.baeldung.com/spring-jpa-like-queries)
|
||||||
|
|
||||||
|
### Eclipse Config
|
||||||
|
After importing the project into Eclipse, you may see the following error:
|
||||||
|
"No persistence xml file found in project"
|
||||||
|
|
||||||
|
This can be ignored:
|
||||||
|
- Project -> Properties -> Java Persistance -> JPA -> Error/Warnings -> Select Ignore on "No persistence xml file found in project"
|
||||||
|
Or:
|
||||||
|
- Eclipse -> Preferences - Validation - disable the "Build" execution of the JPA Validator
|
|
@ -0,0 +1,37 @@
|
||||||
|
<?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>
|
||||||
|
|
||||||
|
<groupId>com.baeldung</groupId>
|
||||||
|
<artifactId>spring-data-jpa-4</artifactId>
|
||||||
|
<name>spring-data-jpa-4</name>
|
||||||
|
|
||||||
|
<parent>
|
||||||
|
<artifactId>parent-boot-2</artifactId>
|
||||||
|
<groupId>com.baeldung</groupId>
|
||||||
|
<version>0.0.1-SNAPSHOT</version>
|
||||||
|
<relativePath>../../parent-boot-2</relativePath>
|
||||||
|
</parent>
|
||||||
|
|
||||||
|
<dependencies>
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.springframework.boot</groupId>
|
||||||
|
<artifactId>spring-boot-starter-data-jpa</artifactId>
|
||||||
|
</dependency>
|
||||||
|
|
||||||
|
<dependency>
|
||||||
|
<groupId>com.h2database</groupId>
|
||||||
|
<artifactId>h2</artifactId>
|
||||||
|
</dependency>
|
||||||
|
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.springframework.boot</groupId>
|
||||||
|
<artifactId>spring-boot-starter-test</artifactId>
|
||||||
|
<scope>test</scope>
|
||||||
|
</dependency>
|
||||||
|
</dependencies>
|
||||||
|
|
||||||
|
<properties>
|
||||||
|
</properties>
|
||||||
|
</project>
|
|
@ -0,0 +1,13 @@
|
||||||
|
package com.baeldung;
|
||||||
|
|
||||||
|
import org.springframework.boot.SpringApplication;
|
||||||
|
import org.springframework.boot.autoconfigure.SpringBootApplication;
|
||||||
|
|
||||||
|
@SpringBootApplication
|
||||||
|
public class Application {
|
||||||
|
|
||||||
|
public static void main(String[] args) {
|
||||||
|
SpringApplication.run(Application.class, args);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -1,70 +1,70 @@
|
||||||
package com.baeldung.derivedquery.entity;
|
package com.baeldung.derivedquery.entity;
|
||||||
|
|
||||||
import javax.persistence.Entity;
|
import javax.persistence.Entity;
|
||||||
import javax.persistence.GeneratedValue;
|
import javax.persistence.GeneratedValue;
|
||||||
import javax.persistence.Id;
|
import javax.persistence.Id;
|
||||||
import javax.persistence.Table;
|
import javax.persistence.Table;
|
||||||
import java.time.ZonedDateTime;
|
import java.time.ZonedDateTime;
|
||||||
|
|
||||||
@Table(name = "users")
|
@Table(name = "users")
|
||||||
@Entity
|
@Entity
|
||||||
public class User {
|
public class User {
|
||||||
|
|
||||||
@Id
|
@Id
|
||||||
@GeneratedValue
|
@GeneratedValue
|
||||||
private Integer id;
|
private Integer id;
|
||||||
private String name;
|
private String name;
|
||||||
private Integer age;
|
private Integer age;
|
||||||
private ZonedDateTime birthDate;
|
private ZonedDateTime birthDate;
|
||||||
private Boolean active;
|
private Boolean active;
|
||||||
|
|
||||||
public User() {
|
public User() {
|
||||||
}
|
}
|
||||||
|
|
||||||
public User(String name, Integer age, ZonedDateTime birthDate, Boolean active) {
|
public User(String name, Integer age, ZonedDateTime birthDate, Boolean active) {
|
||||||
this.name = name;
|
this.name = name;
|
||||||
this.age = age;
|
this.age = age;
|
||||||
this.birthDate = birthDate;
|
this.birthDate = birthDate;
|
||||||
this.active = active;
|
this.active = active;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Integer getId() {
|
public Integer getId() {
|
||||||
return id;
|
return id;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setId(Integer id) {
|
public void setId(Integer id) {
|
||||||
this.id = id;
|
this.id = id;
|
||||||
}
|
}
|
||||||
|
|
||||||
public String getName() {
|
public String getName() {
|
||||||
return name;
|
return name;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setName(String name) {
|
public void setName(String name) {
|
||||||
this.name = name;
|
this.name = name;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Integer getAge() {
|
public Integer getAge() {
|
||||||
return age;
|
return age;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setAge(Integer age) {
|
public void setAge(Integer age) {
|
||||||
this.age = age;
|
this.age = age;
|
||||||
}
|
}
|
||||||
|
|
||||||
public ZonedDateTime getBirthDate() {
|
public ZonedDateTime getBirthDate() {
|
||||||
return birthDate;
|
return birthDate;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setBirthDate(ZonedDateTime birthDate) {
|
public void setBirthDate(ZonedDateTime birthDate) {
|
||||||
this.birthDate = birthDate;
|
this.birthDate = birthDate;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Boolean getActive() {
|
public Boolean getActive() {
|
||||||
return active;
|
return active;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setActive(Boolean active) {
|
public void setActive(Boolean active) {
|
||||||
this.active = active;
|
this.active = active;
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -1,60 +1,60 @@
|
||||||
package com.baeldung.derivedquery.repository;
|
package com.baeldung.derivedquery.repository;
|
||||||
|
|
||||||
import com.baeldung.derivedquery.entity.User;
|
import com.baeldung.derivedquery.entity.User;
|
||||||
import org.springframework.data.jpa.repository.JpaRepository;
|
import org.springframework.data.jpa.repository.JpaRepository;
|
||||||
|
|
||||||
import java.time.ZonedDateTime;
|
import java.time.ZonedDateTime;
|
||||||
import java.util.Collection;
|
import java.util.Collection;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
public interface UserRepository extends JpaRepository<User, Integer> {
|
public interface UserRepository extends JpaRepository<User, Integer> {
|
||||||
|
|
||||||
List<User> findByName(String name);
|
List<User> findByName(String name);
|
||||||
|
|
||||||
List<User> findByNameIs(String name);
|
List<User> findByNameIs(String name);
|
||||||
|
|
||||||
List<User> findByNameEquals(String name);
|
List<User> findByNameEquals(String name);
|
||||||
|
|
||||||
List<User> findByNameIsNull();
|
List<User> findByNameIsNull();
|
||||||
|
|
||||||
List<User> findByNameNot(String name);
|
List<User> findByNameNot(String name);
|
||||||
|
|
||||||
List<User> findByNameIsNot(String name);
|
List<User> findByNameIsNot(String name);
|
||||||
|
|
||||||
List<User> findByNameStartingWith(String name);
|
List<User> findByNameStartingWith(String name);
|
||||||
|
|
||||||
List<User> findByNameEndingWith(String name);
|
List<User> findByNameEndingWith(String name);
|
||||||
|
|
||||||
List<User> findByNameContaining(String name);
|
List<User> findByNameContaining(String name);
|
||||||
|
|
||||||
List<User> findByNameLike(String name);
|
List<User> findByNameLike(String name);
|
||||||
|
|
||||||
List<User> findByAgeLessThan(Integer age);
|
List<User> findByAgeLessThan(Integer age);
|
||||||
|
|
||||||
List<User> findByAgeLessThanEqual(Integer age);
|
List<User> findByAgeLessThanEqual(Integer age);
|
||||||
|
|
||||||
List<User> findByAgeGreaterThan(Integer age);
|
List<User> findByAgeGreaterThan(Integer age);
|
||||||
|
|
||||||
List<User> findByAgeGreaterThanEqual(Integer age);
|
List<User> findByAgeGreaterThanEqual(Integer age);
|
||||||
|
|
||||||
List<User> findByAgeBetween(Integer startAge, Integer endAge);
|
List<User> findByAgeBetween(Integer startAge, Integer endAge);
|
||||||
|
|
||||||
List<User> findByBirthDateAfter(ZonedDateTime birthDate);
|
List<User> findByBirthDateAfter(ZonedDateTime birthDate);
|
||||||
|
|
||||||
List<User> findByBirthDateBefore(ZonedDateTime birthDate);
|
List<User> findByBirthDateBefore(ZonedDateTime birthDate);
|
||||||
|
|
||||||
List<User> findByActiveTrue();
|
List<User> findByActiveTrue();
|
||||||
|
|
||||||
List<User> findByActiveFalse();
|
List<User> findByActiveFalse();
|
||||||
|
|
||||||
List<User> findByAgeIn(Collection<Integer> ages);
|
List<User> findByAgeIn(Collection<Integer> ages);
|
||||||
|
|
||||||
List<User> findByNameOrBirthDate(String name, ZonedDateTime birthDate);
|
List<User> findByNameOrBirthDate(String name, ZonedDateTime birthDate);
|
||||||
|
|
||||||
List<User> findByNameOrBirthDateAndActive(String name, ZonedDateTime birthDate, Boolean active);
|
List<User> findByNameOrBirthDateAndActive(String name, ZonedDateTime birthDate, Boolean active);
|
||||||
|
|
||||||
List<User> findByNameOrderByName(String name);
|
List<User> findByNameOrderByName(String name);
|
||||||
|
|
||||||
List<User> findByNameOrderByNameDesc(String name);
|
List<User> findByNameOrderByNameDesc(String name);
|
||||||
|
|
||||||
}
|
}
|
|
@ -0,0 +1 @@
|
||||||
|
spring.jpa.show-sql=true
|
|
@ -1,172 +1,172 @@
|
||||||
package com.baeldung.derivedquery.repository;
|
package com.baeldung.derivedquery.repository;
|
||||||
|
|
||||||
import com.baeldung.Application;
|
import com.baeldung.Application;
|
||||||
import com.baeldung.derivedquery.entity.User;
|
import com.baeldung.derivedquery.entity.User;
|
||||||
import com.baeldung.derivedquery.repository.UserRepository;
|
import com.baeldung.derivedquery.repository.UserRepository;
|
||||||
import java.time.ZonedDateTime;
|
import java.time.ZonedDateTime;
|
||||||
import java.util.Arrays;
|
import java.util.Arrays;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import org.junit.After;
|
import org.junit.After;
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import org.junit.runner.RunWith;
|
import org.junit.runner.RunWith;
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
import org.springframework.boot.test.context.SpringBootTest;
|
import org.springframework.boot.test.context.SpringBootTest;
|
||||||
import org.springframework.test.context.junit4.SpringRunner;
|
import org.springframework.test.context.junit4.SpringRunner;
|
||||||
|
|
||||||
import static org.junit.Assert.assertEquals;
|
import static org.junit.Assert.assertEquals;
|
||||||
|
|
||||||
@RunWith(SpringRunner.class)
|
@RunWith(SpringRunner.class)
|
||||||
@SpringBootTest(classes = Application.class)
|
@SpringBootTest(classes = Application.class)
|
||||||
public class UserRepositoryTest {
|
public class UserRepositoryIntegrationTest {
|
||||||
|
|
||||||
private static final String USER_NAME_ADAM = "Adam";
|
private static final String USER_NAME_ADAM = "Adam";
|
||||||
private static final String USER_NAME_EVE = "Eve";
|
private static final String USER_NAME_EVE = "Eve";
|
||||||
private static final ZonedDateTime BIRTHDATE = ZonedDateTime.now();
|
private static final ZonedDateTime BIRTHDATE = ZonedDateTime.now();
|
||||||
|
|
||||||
@Autowired
|
@Autowired
|
||||||
private UserRepository userRepository;
|
private UserRepository userRepository;
|
||||||
|
|
||||||
@Before
|
@Before
|
||||||
public void setUp() {
|
public void setUp() {
|
||||||
|
|
||||||
User user1 = new User(USER_NAME_ADAM, 25, BIRTHDATE, true);
|
User user1 = new User(USER_NAME_ADAM, 25, BIRTHDATE, true);
|
||||||
User user2 = new User(USER_NAME_ADAM, 20, BIRTHDATE, false);
|
User user2 = new User(USER_NAME_ADAM, 20, BIRTHDATE, false);
|
||||||
User user3 = new User(USER_NAME_EVE, 20, BIRTHDATE, true);
|
User user3 = new User(USER_NAME_EVE, 20, BIRTHDATE, true);
|
||||||
User user4 = new User(null, 30, BIRTHDATE, false);
|
User user4 = new User(null, 30, BIRTHDATE, false);
|
||||||
|
|
||||||
userRepository.saveAll(Arrays.asList(user1, user2, user3, user4));
|
userRepository.saveAll(Arrays.asList(user1, user2, user3, user4));
|
||||||
}
|
}
|
||||||
|
|
||||||
@After
|
@After
|
||||||
public void tearDown() {
|
public void tearDown() {
|
||||||
|
|
||||||
userRepository.deleteAll();
|
userRepository.deleteAll();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void whenFindByName_thenReturnsCorrectResult() {
|
public void whenFindByName_thenReturnsCorrectResult() {
|
||||||
|
|
||||||
assertEquals(2, userRepository.findByName(USER_NAME_ADAM).size());
|
assertEquals(2, userRepository.findByName(USER_NAME_ADAM).size());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void whenFindByNameIsNull_thenReturnsCorrectResult() {
|
public void whenFindByNameIsNull_thenReturnsCorrectResult() {
|
||||||
|
|
||||||
assertEquals(1, userRepository.findByNameIsNull().size());
|
assertEquals(1, userRepository.findByNameIsNull().size());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void whenFindByNameNot_thenReturnsCorrectResult() {
|
public void whenFindByNameNot_thenReturnsCorrectResult() {
|
||||||
|
|
||||||
assertEquals(USER_NAME_EVE, userRepository.findByNameNot(USER_NAME_ADAM).get(0).getName());
|
assertEquals(USER_NAME_EVE, userRepository.findByNameNot(USER_NAME_ADAM).get(0).getName());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void whenFindByNameStartingWith_thenReturnsCorrectResult() {
|
public void whenFindByNameStartingWith_thenReturnsCorrectResult() {
|
||||||
|
|
||||||
assertEquals(2, userRepository.findByNameStartingWith("A").size());
|
assertEquals(2, userRepository.findByNameStartingWith("A").size());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void whenFindByNameEndingWith_thenReturnsCorrectResult() {
|
public void whenFindByNameEndingWith_thenReturnsCorrectResult() {
|
||||||
|
|
||||||
assertEquals(1, userRepository.findByNameEndingWith("e").size());
|
assertEquals(1, userRepository.findByNameEndingWith("e").size());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void whenByNameContaining_thenReturnsCorrectResult() {
|
public void whenByNameContaining_thenReturnsCorrectResult() {
|
||||||
|
|
||||||
assertEquals(1, userRepository.findByNameContaining("v").size());
|
assertEquals(1, userRepository.findByNameContaining("v").size());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void whenByNameLike_thenReturnsCorrectResult() {
|
public void whenByNameLike_thenReturnsCorrectResult() {
|
||||||
|
|
||||||
assertEquals(2, userRepository.findByNameEndingWith("%d%m").size());
|
assertEquals(2, userRepository.findByNameEndingWith("m").size());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void whenByAgeLessThan_thenReturnsCorrectResult() {
|
public void whenByAgeLessThan_thenReturnsCorrectResult() {
|
||||||
|
|
||||||
assertEquals(2, userRepository.findByAgeLessThan(25).size());
|
assertEquals(2, userRepository.findByAgeLessThan(25).size());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void whenByAgeLessThanEqual_thenReturnsCorrectResult() {
|
public void whenByAgeLessThanEqual_thenReturnsCorrectResult() {
|
||||||
|
|
||||||
assertEquals(3, userRepository.findByAgeLessThanEqual(25).size());
|
assertEquals(3, userRepository.findByAgeLessThanEqual(25).size());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void whenByAgeGreaterThan_thenReturnsCorrectResult() {
|
public void whenByAgeGreaterThan_thenReturnsCorrectResult() {
|
||||||
|
|
||||||
assertEquals(1, userRepository.findByAgeGreaterThan(25).size());
|
assertEquals(1, userRepository.findByAgeGreaterThan(25).size());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void whenByAgeGreaterThanEqual_thenReturnsCorrectResult() {
|
public void whenByAgeGreaterThanEqual_thenReturnsCorrectResult() {
|
||||||
|
|
||||||
assertEquals(2, userRepository.findByAgeGreaterThanEqual(25).size());
|
assertEquals(2, userRepository.findByAgeGreaterThanEqual(25).size());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void whenByAgeBetween_thenReturnsCorrectResult() {
|
public void whenByAgeBetween_thenReturnsCorrectResult() {
|
||||||
|
|
||||||
assertEquals(4, userRepository.findByAgeBetween(20, 30).size());
|
assertEquals(4, userRepository.findByAgeBetween(20, 30).size());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void whenByBirthDateAfter_thenReturnsCorrectResult() {
|
public void whenByBirthDateAfter_thenReturnsCorrectResult() {
|
||||||
|
|
||||||
final ZonedDateTime yesterday = BIRTHDATE.minusDays(1);
|
final ZonedDateTime yesterday = BIRTHDATE.minusDays(1);
|
||||||
assertEquals(4, userRepository.findByBirthDateAfter(yesterday).size());
|
assertEquals(4, userRepository.findByBirthDateAfter(yesterday).size());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void whenByBirthDateBefore_thenReturnsCorrectResult() {
|
public void whenByBirthDateBefore_thenReturnsCorrectResult() {
|
||||||
|
|
||||||
final ZonedDateTime yesterday = BIRTHDATE.minusDays(1);
|
final ZonedDateTime yesterday = BIRTHDATE.minusDays(1);
|
||||||
assertEquals(0, userRepository.findByBirthDateBefore(yesterday).size());
|
assertEquals(0, userRepository.findByBirthDateBefore(yesterday).size());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void whenByActiveTrue_thenReturnsCorrectResult() {
|
public void whenByActiveTrue_thenReturnsCorrectResult() {
|
||||||
|
|
||||||
assertEquals(2, userRepository.findByActiveTrue().size());
|
assertEquals(2, userRepository.findByActiveTrue().size());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void whenByActiveFalse_thenReturnsCorrectResult() {
|
public void whenByActiveFalse_thenReturnsCorrectResult() {
|
||||||
|
|
||||||
assertEquals(2, userRepository.findByActiveFalse().size());
|
assertEquals(2, userRepository.findByActiveFalse().size());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void whenByAgeIn_thenReturnsCorrectResult() {
|
public void whenByAgeIn_thenReturnsCorrectResult() {
|
||||||
|
|
||||||
final List<Integer> ages = Arrays.asList(20, 25);
|
final List<Integer> ages = Arrays.asList(20, 25);
|
||||||
assertEquals(3, userRepository.findByAgeIn(ages).size());
|
assertEquals(3, userRepository.findByAgeIn(ages).size());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void whenByNameOrBirthDate() {
|
public void whenByNameOrBirthDate() {
|
||||||
|
|
||||||
assertEquals(4, userRepository.findByNameOrBirthDate(USER_NAME_ADAM, BIRTHDATE).size());
|
assertEquals(4, userRepository.findByNameOrBirthDate(USER_NAME_ADAM, BIRTHDATE).size());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void whenByNameOrBirthDateAndActive() {
|
public void whenByNameOrBirthDateAndActive() {
|
||||||
|
|
||||||
assertEquals(3, userRepository.findByNameOrBirthDateAndActive(USER_NAME_ADAM, BIRTHDATE, false).size());
|
assertEquals(3, userRepository.findByNameOrBirthDateAndActive(USER_NAME_ADAM, BIRTHDATE, false).size());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void whenByNameOrderByName() {
|
public void whenByNameOrderByName() {
|
||||||
|
|
||||||
assertEquals(2, userRepository.findByNameOrderByName(USER_NAME_ADAM).size());
|
assertEquals(2, userRepository.findByNameOrderByName(USER_NAME_ADAM).size());
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -3,24 +3,16 @@
|
||||||
## Spring Data JPA Example Project
|
## Spring Data JPA Example Project
|
||||||
|
|
||||||
### Relevant Articles:
|
### Relevant Articles:
|
||||||
- [Spring JPA – Multiple Databases](http://www.baeldung.com/spring-data-jpa-multiple-databases)
|
- [Spring JPA – Multiple Databases](https://www.baeldung.com/spring-data-jpa-multiple-databases)
|
||||||
- [Spring Data JPA – Adding a Method in All Repositories](http://www.baeldung.com/spring-data-jpa-method-in-all-repositories)
|
- [Spring Data JPA – Adding a Method in All Repositories](https://www.baeldung.com/spring-data-jpa-method-in-all-repositories)
|
||||||
- [An Advanced Tagging Implementation with JPA](http://www.baeldung.com/jpa-tagging-advanced)
|
- [An Advanced Tagging Implementation with JPA](https://www.baeldung.com/jpa-tagging-advanced)
|
||||||
- [Spring Data Annotations](http://www.baeldung.com/spring-data-annotations)
|
- [Spring Data Annotations](https://www.baeldung.com/spring-data-annotations)
|
||||||
- [Spring Data Java 8 Support](http://www.baeldung.com/spring-data-java-8)
|
- [Spring Data Java 8 Support](https://www.baeldung.com/spring-data-java-8)
|
||||||
- [A Simple Tagging Implementation with JPA](http://www.baeldung.com/jpa-tagging)
|
- [A Simple Tagging Implementation with JPA](https://www.baeldung.com/jpa-tagging)
|
||||||
- [Spring Data Composable Repositories](https://www.baeldung.com/spring-data-composable-repositories)
|
- [Spring Data Composable Repositories](https://www.baeldung.com/spring-data-composable-repositories)
|
||||||
- [Query Entities by Dates and Times with Spring Data JPA](https://www.baeldung.com/spring-data-jpa-query-by-date)
|
- [Query Entities by Dates and Times with Spring Data JPA](https://www.baeldung.com/spring-data-jpa-query-by-date)
|
||||||
- [DDD Aggregates and @DomainEvents](https://www.baeldung.com/spring-data-ddd)
|
- [DDD Aggregates and @DomainEvents](https://www.baeldung.com/spring-data-ddd)
|
||||||
- [Spring Data – CrudRepository save() Method](https://www.baeldung.com/spring-data-crud-repository-save)
|
- [Spring Data – CrudRepository save() Method](https://www.baeldung.com/spring-data-crud-repository-save)
|
||||||
- [Limiting Query Results with JPA and Spring Data JPA](https://www.baeldung.com/jpa-limit-query-results)
|
|
||||||
- [Sorting Query Results with Spring Data](https://www.baeldung.com/spring-data-sorting)
|
|
||||||
- [INSERT Statement in JPA](https://www.baeldung.com/jpa-insert)
|
|
||||||
- [Pagination and Sorting using Spring Data JPA](https://www.baeldung.com/spring-data-jpa-pagination-sorting)
|
|
||||||
- [Spring Data JPA Query by Example](https://www.baeldung.com/spring-data-query-by-example)
|
|
||||||
- [DB Integration Tests with Spring Boot and Testcontainers](https://www.baeldung.com/spring-boot-testcontainers-integration-test)
|
|
||||||
- [Spring Data JPA @Modifying Annotation](https://www.baeldung.com/spring-data-jpa-modifying-annotation)
|
|
||||||
- [Spring Data JPA Batch Inserts](https://www.baeldung.com/spring-data-jpa-batch-inserts)
|
|
||||||
|
|
||||||
### Eclipse Config
|
### Eclipse Config
|
||||||
After importing the project into Eclipse, you may see the following error:
|
After importing the project into Eclipse, you may see the following error:
|
||||||
|
|
|
@ -5,7 +5,6 @@ import org.springframework.boot.autoconfigure.SpringBootApplication;
|
||||||
import org.springframework.data.jpa.repository.config.EnableJpaRepositories;
|
import org.springframework.data.jpa.repository.config.EnableJpaRepositories;
|
||||||
|
|
||||||
import com.baeldung.boot.daos.impl.ExtendedRepositoryImpl;
|
import com.baeldung.boot.daos.impl.ExtendedRepositoryImpl;
|
||||||
import com.baeldung.multipledb.MultipleDbApplication;
|
|
||||||
|
|
||||||
@SpringBootApplication
|
@SpringBootApplication
|
||||||
@EnableJpaRepositories(repositoryBaseClass = ExtendedRepositoryImpl.class)
|
@EnableJpaRepositories(repositoryBaseClass = ExtendedRepositoryImpl.class)
|
||||||
|
|
|
@ -1,11 +1,13 @@
|
||||||
package com.baeldung.boot.config;
|
package com.baeldung.boot.config;
|
||||||
|
|
||||||
|
import org.springframework.context.annotation.Bean;
|
||||||
|
import org.springframework.context.annotation.Configuration;
|
||||||
|
import org.springframework.context.annotation.Profile;
|
||||||
|
import org.springframework.data.jpa.repository.config.EnableJpaAuditing;
|
||||||
|
import org.springframework.transaction.annotation.EnableTransactionManagement;
|
||||||
|
|
||||||
import com.baeldung.boot.services.IBarService;
|
import com.baeldung.boot.services.IBarService;
|
||||||
import com.baeldung.boot.services.impl.BarSpringDataJpaService;
|
import com.baeldung.boot.services.impl.BarSpringDataJpaService;
|
||||||
import org.springframework.context.annotation.*;
|
|
||||||
import org.springframework.data.jpa.repository.config.EnableJpaAuditing;
|
|
||||||
import org.springframework.data.jpa.repository.config.EnableJpaRepositories;
|
|
||||||
import org.springframework.transaction.annotation.EnableTransactionManagement;
|
|
||||||
|
|
||||||
@Configuration
|
@Configuration
|
||||||
@Profile("!tc")
|
@Profile("!tc")
|
||||||
|
|
|
@ -2,8 +2,6 @@ package com.baeldung.boot.daos.impl;
|
||||||
|
|
||||||
import javax.persistence.EntityManager;
|
import javax.persistence.EntityManager;
|
||||||
|
|
||||||
import org.slf4j.Logger;
|
|
||||||
import org.slf4j.LoggerFactory;
|
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
import org.springframework.stereotype.Repository;
|
import org.springframework.stereotype.Repository;
|
||||||
|
|
||||||
|
@ -13,8 +11,6 @@ import com.baeldung.boot.domain.ItemType;
|
||||||
@Repository
|
@Repository
|
||||||
public class CustomItemTypeRepositoryImpl implements CustomItemTypeRepository {
|
public class CustomItemTypeRepositoryImpl implements CustomItemTypeRepository {
|
||||||
|
|
||||||
private static final Logger LOGGER = LoggerFactory.getLogger(CustomItemTypeRepositoryImpl.class);
|
|
||||||
|
|
||||||
@Autowired
|
@Autowired
|
||||||
private EntityManager entityManager;
|
private EntityManager entityManager;
|
||||||
|
|
||||||
|
|
|
@ -31,7 +31,7 @@ public abstract class AbstractService<T extends Serializable> implements IOperat
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Page<T> findPaginated(final int page, final int size) {
|
public Page<T> findPaginated(final int page, final int size) {
|
||||||
return getDao().findAll(new PageRequest(page, size));
|
return getDao().findAll(PageRequest.of(page, size));
|
||||||
}
|
}
|
||||||
|
|
||||||
// write
|
// write
|
||||||
|
|
|
@ -1,13 +1,9 @@
|
||||||
package com.baeldung.multipledb.dao.product;
|
package com.baeldung.multipledb.dao.product;
|
||||||
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
import org.springframework.data.domain.Pageable;
|
|
||||||
import org.springframework.data.repository.PagingAndSortingRepository;
|
import org.springframework.data.repository.PagingAndSortingRepository;
|
||||||
|
|
||||||
import com.baeldung.multipledb.model.product.ProductMultipleDB;
|
import com.baeldung.multipledb.model.product.ProductMultipleDB;
|
||||||
|
|
||||||
public interface ProductRepository extends PagingAndSortingRepository<ProductMultipleDB, Integer> {
|
public interface ProductRepository extends PagingAndSortingRepository<ProductMultipleDB, Integer> {
|
||||||
|
|
||||||
List<ProductMultipleDB> findAllByPrice(double price, Pageable pageable);
|
}
|
||||||
}
|
|
|
@ -1,24 +1,19 @@
|
||||||
package com.baeldung.boot.daos;
|
package com.baeldung.boot.daos;
|
||||||
|
|
||||||
import com.baeldung.boot.Application;
|
import static org.junit.Assert.assertEquals;
|
||||||
import com.baeldung.boot.config.PersistenceConfiguration;
|
import static org.junit.Assert.assertTrue;
|
||||||
import com.baeldung.boot.daos.ArticleRepository;
|
|
||||||
import com.baeldung.boot.domain.Article;
|
|
||||||
|
|
||||||
import org.junit.Test;
|
|
||||||
import org.junit.runner.RunWith;
|
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
|
||||||
import org.springframework.boot.test.autoconfigure.orm.jpa.DataJpaTest;
|
|
||||||
import org.springframework.boot.test.context.SpringBootTest;
|
|
||||||
import org.springframework.context.annotation.Import;
|
|
||||||
import org.springframework.test.context.junit4.SpringRunner;
|
|
||||||
|
|
||||||
import java.text.SimpleDateFormat;
|
import java.text.SimpleDateFormat;
|
||||||
import java.util.Arrays;
|
import java.util.Arrays;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
import static org.junit.Assert.assertEquals;
|
import org.junit.Test;
|
||||||
import static org.junit.Assert.assertTrue;
|
import org.junit.runner.RunWith;
|
||||||
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
import org.springframework.boot.test.autoconfigure.orm.jpa.DataJpaTest;
|
||||||
|
import org.springframework.test.context.junit4.SpringRunner;
|
||||||
|
|
||||||
|
import com.baeldung.boot.domain.Article;
|
||||||
|
|
||||||
@RunWith(SpringRunner.class)
|
@RunWith(SpringRunner.class)
|
||||||
@DataJpaTest(properties="spring.datasource.data=classpath:import_entities.sql")
|
@DataJpaTest(properties="spring.datasource.data=classpath:import_entities.sql")
|
||||||
|
|
|
@ -1,9 +1,10 @@
|
||||||
package com.baeldung.boot.daos;
|
package com.baeldung.boot.daos;
|
||||||
|
|
||||||
import com.baeldung.boot.Application;
|
import static org.assertj.core.api.Assertions.assertThat;
|
||||||
import com.baeldung.boot.config.PersistenceConfiguration;
|
|
||||||
import com.baeldung.boot.daos.ExtendedStudentRepository;
|
import java.util.List;
|
||||||
import com.baeldung.boot.domain.Student;
|
|
||||||
|
import javax.annotation.Resource;
|
||||||
|
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
@ -12,10 +13,8 @@ import org.springframework.test.annotation.DirtiesContext;
|
||||||
import org.springframework.test.context.ContextConfiguration;
|
import org.springframework.test.context.ContextConfiguration;
|
||||||
import org.springframework.test.context.junit4.SpringRunner;
|
import org.springframework.test.context.junit4.SpringRunner;
|
||||||
|
|
||||||
import javax.annotation.Resource;
|
import com.baeldung.boot.Application;
|
||||||
import java.util.List;
|
import com.baeldung.boot.domain.Student;
|
||||||
|
|
||||||
import static org.assertj.core.api.Assertions.assertThat;
|
|
||||||
|
|
||||||
@RunWith(SpringRunner.class)
|
@RunWith(SpringRunner.class)
|
||||||
@ContextConfiguration(classes = {Application.class})
|
@ContextConfiguration(classes = {Application.class})
|
||||||
|
|
|
@ -1,23 +1,20 @@
|
||||||
package com.baeldung.boot.daos;
|
package com.baeldung.boot.daos;
|
||||||
|
|
||||||
import com.baeldung.boot.Application;
|
|
||||||
import com.baeldung.boot.config.PersistenceConfiguration;
|
|
||||||
import com.baeldung.boot.daos.InventoryRepository;
|
|
||||||
import com.baeldung.boot.domain.MerchandiseEntity;
|
|
||||||
|
|
||||||
import org.junit.Test;
|
|
||||||
import org.junit.runner.RunWith;
|
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
|
||||||
import org.springframework.boot.test.autoconfigure.orm.jpa.DataJpaTest;
|
|
||||||
import org.springframework.boot.test.context.SpringBootTest;
|
|
||||||
import org.springframework.test.context.junit4.SpringRunner;
|
|
||||||
|
|
||||||
import java.math.BigDecimal;
|
|
||||||
|
|
||||||
import static org.junit.Assert.assertEquals;
|
import static org.junit.Assert.assertEquals;
|
||||||
import static org.junit.Assert.assertNotEquals;
|
import static org.junit.Assert.assertNotEquals;
|
||||||
import static org.junit.Assert.assertNotNull;
|
import static org.junit.Assert.assertNotNull;
|
||||||
|
|
||||||
|
import java.math.BigDecimal;
|
||||||
|
|
||||||
|
import org.junit.Test;
|
||||||
|
import org.junit.runner.RunWith;
|
||||||
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
import org.springframework.boot.test.context.SpringBootTest;
|
||||||
|
import org.springframework.test.context.junit4.SpringRunner;
|
||||||
|
|
||||||
|
import com.baeldung.boot.Application;
|
||||||
|
import com.baeldung.boot.domain.MerchandiseEntity;
|
||||||
|
|
||||||
@RunWith(SpringRunner.class)
|
@RunWith(SpringRunner.class)
|
||||||
@SpringBootTest(classes=Application.class)
|
@SpringBootTest(classes=Application.class)
|
||||||
public class InventoryRepositoryIntegrationTest {
|
public class InventoryRepositoryIntegrationTest {
|
||||||
|
|
|
@ -13,21 +13,12 @@ import org.junit.Test;
|
||||||
import org.junit.runner.RunWith;
|
import org.junit.runner.RunWith;
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
import org.springframework.boot.test.autoconfigure.orm.jpa.DataJpaTest;
|
import org.springframework.boot.test.autoconfigure.orm.jpa.DataJpaTest;
|
||||||
import org.springframework.boot.test.context.SpringBootTest;
|
|
||||||
import org.springframework.test.context.junit4.SpringRunner;
|
import org.springframework.test.context.junit4.SpringRunner;
|
||||||
|
|
||||||
import com.baeldung.boot.Application;
|
|
||||||
import com.baeldung.boot.config.PersistenceConfiguration;
|
|
||||||
import com.baeldung.boot.daos.ItemTypeRepository;
|
|
||||||
import com.baeldung.boot.daos.LocationRepository;
|
|
||||||
import com.baeldung.boot.daos.ReadOnlyLocationRepository;
|
|
||||||
import com.baeldung.boot.daos.StoreRepository;
|
|
||||||
import com.baeldung.boot.domain.Item;
|
import com.baeldung.boot.domain.Item;
|
||||||
import com.baeldung.boot.domain.ItemType;
|
import com.baeldung.boot.domain.ItemType;
|
||||||
import com.baeldung.boot.domain.Location;
|
import com.baeldung.boot.domain.Location;
|
||||||
import com.baeldung.boot.domain.Store;
|
import com.baeldung.boot.domain.Store;
|
||||||
import com.baeldung.multipledb.PersistenceProductConfiguration;
|
|
||||||
import com.baeldung.multipledb.PersistenceUserConfiguration;
|
|
||||||
|
|
||||||
@RunWith(SpringRunner.class)
|
@RunWith(SpringRunner.class)
|
||||||
@DataJpaTest(properties="spring.datasource.data=classpath:import_entities.sql")
|
@DataJpaTest(properties="spring.datasource.data=classpath:import_entities.sql")
|
||||||
|
|
|
@ -25,7 +25,7 @@ import static org.assertj.core.api.Assertions.assertThat;
|
||||||
public class UserRepositoryTCAutoLiveTest extends UserRepositoryCommon {
|
public class UserRepositoryTCAutoLiveTest extends UserRepositoryCommon {
|
||||||
|
|
||||||
@ClassRule
|
@ClassRule
|
||||||
public static PostgreSQLContainer postgreSQLContainer = BaeldungPostgresqlContainer.getInstance();
|
public static PostgreSQLContainer<BaeldungPostgresqlContainer> postgreSQLContainer = BaeldungPostgresqlContainer.getInstance();
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
@Transactional
|
@Transactional
|
||||||
|
|
|
@ -1,10 +1,7 @@
|
||||||
package com.baeldung.boot.services;
|
package com.baeldung.boot.services;
|
||||||
|
|
||||||
import com.baeldung.boot.Application;
|
import static org.apache.commons.lang3.RandomStringUtils.randomAlphabetic;
|
||||||
import com.baeldung.boot.config.PersistenceConfiguration;
|
import static org.junit.Assert.assertNotNull;
|
||||||
import com.baeldung.boot.domain.Foo;
|
|
||||||
import com.baeldung.boot.services.IFooService;
|
|
||||||
import com.baeldung.boot.services.IOperations;
|
|
||||||
|
|
||||||
import org.junit.Ignore;
|
import org.junit.Ignore;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
@ -13,12 +10,10 @@ import org.springframework.beans.factory.annotation.Autowired;
|
||||||
import org.springframework.boot.test.context.SpringBootTest;
|
import org.springframework.boot.test.context.SpringBootTest;
|
||||||
import org.springframework.dao.DataIntegrityViolationException;
|
import org.springframework.dao.DataIntegrityViolationException;
|
||||||
import org.springframework.dao.InvalidDataAccessApiUsageException;
|
import org.springframework.dao.InvalidDataAccessApiUsageException;
|
||||||
import org.springframework.test.context.ContextConfiguration;
|
|
||||||
import org.springframework.test.context.junit4.SpringRunner;
|
import org.springframework.test.context.junit4.SpringRunner;
|
||||||
import org.springframework.test.context.support.AnnotationConfigContextLoader;
|
|
||||||
|
|
||||||
import static org.apache.commons.lang3.RandomStringUtils.randomAlphabetic;
|
import com.baeldung.boot.Application;
|
||||||
import static org.junit.Assert.assertNotNull;
|
import com.baeldung.boot.domain.Foo;
|
||||||
|
|
||||||
@RunWith(SpringRunner.class)
|
@RunWith(SpringRunner.class)
|
||||||
@SpringBootTest(classes=Application.class)
|
@SpringBootTest(classes=Application.class)
|
||||||
|
|
|
@ -18,14 +18,10 @@ import org.springframework.beans.factory.annotation.Autowired;
|
||||||
import org.springframework.beans.factory.annotation.Qualifier;
|
import org.springframework.beans.factory.annotation.Qualifier;
|
||||||
import org.springframework.boot.test.context.SpringBootTest;
|
import org.springframework.boot.test.context.SpringBootTest;
|
||||||
import org.springframework.security.test.context.support.WithMockUser;
|
import org.springframework.security.test.context.support.WithMockUser;
|
||||||
import org.springframework.test.context.ContextConfiguration;
|
|
||||||
import org.springframework.test.context.junit4.SpringRunner;
|
import org.springframework.test.context.junit4.SpringRunner;
|
||||||
import org.springframework.test.context.support.AnnotationConfigContextLoader;
|
|
||||||
|
|
||||||
import com.baeldung.boot.Application;
|
import com.baeldung.boot.Application;
|
||||||
import com.baeldung.boot.config.PersistenceConfiguration;
|
|
||||||
import com.baeldung.boot.domain.Bar;
|
import com.baeldung.boot.domain.Bar;
|
||||||
import com.baeldung.boot.services.IBarService;
|
|
||||||
|
|
||||||
@RunWith(SpringRunner.class)
|
@RunWith(SpringRunner.class)
|
||||||
@SpringBootTest(classes=Application.class)
|
@SpringBootTest(classes=Application.class)
|
||||||
|
|
|
@ -9,7 +9,7 @@
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>com.baeldung</groupId>
|
<groupId>com.baeldung</groupId>
|
||||||
<artifactId>parent-boot-2</artifactId>
|
<artifactId>parent-boot-2</artifactId>
|
||||||
<version>1.0.0-SNAPSHOT</version>
|
<version>0.0.1-SNAPSHOT</version>
|
||||||
<relativePath>../../parent-boot-2</relativePath>
|
<relativePath>../../parent-boot-2</relativePath>
|
||||||
</parent>
|
</parent>
|
||||||
|
|
||||||
|
@ -34,6 +34,7 @@
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>org.mybatis.spring.boot</groupId>
|
<groupId>org.mybatis.spring.boot</groupId>
|
||||||
<artifactId>mybatis-spring-boot-starter</artifactId>
|
<artifactId>mybatis-spring-boot-starter</artifactId>
|
||||||
|
<version>${mybatis-spring-boot-starter.version}</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
<!-- Persistence -->
|
<!-- Persistence -->
|
||||||
|
|
13
pom.xml
13
pom.xml
|
@ -923,7 +923,6 @@
|
||||||
<module>spring-boot-di</module>
|
<module>spring-boot-di</module>
|
||||||
<module>greeter-spring-boot-autoconfigure</module>
|
<module>greeter-spring-boot-autoconfigure</module>
|
||||||
<module>greeter-spring-boot-sample-app</module>
|
<module>greeter-spring-boot-sample-app</module>
|
||||||
<module>persistence-modules/spring-boot-h2/spring-boot-h2-database</module>
|
|
||||||
<module>spring-boot-jasypt</module>
|
<module>spring-boot-jasypt</module>
|
||||||
<module>spring-boot-keycloak</module>
|
<module>spring-boot-keycloak</module>
|
||||||
<module>spring-boot-mvc</module>
|
<module>spring-boot-mvc</module>
|
||||||
|
@ -948,16 +947,12 @@
|
||||||
<module>spring-cloud/spring-cloud-data-flow/time-processor</module>
|
<module>spring-cloud/spring-cloud-data-flow/time-processor</module>
|
||||||
<module>spring-cloud/spring-cloud-data-flow/time-source</module>
|
<module>spring-cloud/spring-cloud-data-flow/time-source</module>
|
||||||
<module>spring-cucumber</module>
|
<module>spring-cucumber</module>
|
||||||
<module>persistence-modules/spring-data-keyvalue</module>
|
|
||||||
<module>spring-data-rest</module>
|
<module>spring-data-rest</module>
|
||||||
<module>spring-dispatcher-servlet</module>
|
<module>spring-dispatcher-servlet</module>
|
||||||
<module>spring-drools</module>
|
<module>spring-drools</module>
|
||||||
<module>spring-di</module>
|
<module>spring-di</module>
|
||||||
<module>spring-ehcache</module>
|
<module>spring-ehcache</module>
|
||||||
<module>spring-freemarker</module>
|
<module>spring-freemarker</module>
|
||||||
<module>persistence-modules/spring-hibernate-3</module>
|
|
||||||
<module>persistence-modules/spring-hibernate4</module>
|
|
||||||
<module>persistence-modules/spring-mybatis</module>
|
|
||||||
<module>spring-integration</module>
|
<module>spring-integration</module>
|
||||||
<module>spring-jenkins-pipeline</module>
|
<module>spring-jenkins-pipeline</module>
|
||||||
<module>spring-jersey</module>
|
<module>spring-jersey</module>
|
||||||
|
@ -1014,11 +1009,6 @@
|
||||||
<module>spring-vault</module>
|
<module>spring-vault</module>
|
||||||
<module>spring-vertx</module>
|
<module>spring-vertx</module>
|
||||||
<module>spring-zuul/spring-zuul-foos-resource</module>
|
<module>spring-zuul/spring-zuul-foos-resource</module>
|
||||||
<module>persistence-modules/hibernate-mapping</module>
|
|
||||||
<module>persistence-modules/spring-data-dynamodb</module>
|
|
||||||
<module>persistence-modules/spring-data-eclipselink</module>
|
|
||||||
<module>persistence-modules/spring-data-solr</module>
|
|
||||||
<module>persistence-modules/spring-hibernate-5</module>
|
|
||||||
|
|
||||||
<module>spring-boot-flowable</module>
|
<module>spring-boot-flowable</module>
|
||||||
<module>spring-security-kerberos</module>
|
<module>spring-security-kerberos</module>
|
||||||
|
@ -1651,7 +1641,7 @@
|
||||||
<module>core-java-modules/core-java-concurrency-advanced</module> <!-- very long running? -->
|
<module>core-java-modules/core-java-concurrency-advanced</module> <!-- very long running? -->
|
||||||
<module>core-java-modules/core-java-concurrency-advanced-2</module>
|
<module>core-java-modules/core-java-concurrency-advanced-2</module>
|
||||||
<module>core-java-modules/core-java-concurrency-advanced-3</module>
|
<module>core-java-modules/core-java-concurrency-advanced-3</module>
|
||||||
<module>core-kotlin</module> <!-- long running? -->
|
<module>core-kotlin</module> <!-- long running? -->
|
||||||
<module>core-kotlin-2</module>
|
<module>core-kotlin-2</module>
|
||||||
|
|
||||||
<module>jenkins/plugins</module>
|
<module>jenkins/plugins</module>
|
||||||
|
@ -1661,6 +1651,7 @@
|
||||||
<module>libraries</module> <!-- very long running -->
|
<module>libraries</module> <!-- very long running -->
|
||||||
|
|
||||||
<module>persistence-modules/hibernate5</module>
|
<module>persistence-modules/hibernate5</module>
|
||||||
|
<module>persistence-modules/hibernate-mapping</module>
|
||||||
<module>persistence-modules/java-jpa</module>
|
<module>persistence-modules/java-jpa</module>
|
||||||
<module>persistence-modules/java-jpa-2</module>
|
<module>persistence-modules/java-jpa-2</module>
|
||||||
<module>persistence-modules/java-mongodb</module>
|
<module>persistence-modules/java-mongodb</module>
|
||||||
|
|
Loading…
Reference in New Issue