- Spring Boot JPA 教程
- Spring Boot JPA - 首頁
- Spring Boot JPA - 概述
- Spring Boot JPA - 環境設定
- Spring Boot JPA - 架構
- Spring Boot JPA 與 Hibernate
- Spring Boot JPA - 應用程式設定
- Spring Boot JPA - 單元測試儲存庫
- Spring Boot JPA - 方法
- Spring Boot JPA - 自定義方法
- Spring Boot JPA - 命名查詢
- Spring Boot JPA - 自定義查詢
- Spring Boot JPA - 原生查詢
- Spring Boot JPA 實用資源
- Spring Boot JPA - 快速指南
- Spring Boot JPA - 實用資源
- Spring Boot JPA - 討論
Spring Boot JPA - 自定義查詢
有時會出現這種情況,我們需要一個自定義查詢來滿足一個測試用例。我們可以使用 @Query 註釋在儲存庫中指定查詢。下面是一個示例。在此示例中,我們正在使用 JPQL(Java 永續性查詢語言)。
我們在 JPA 命名查詢 章節的儲存庫中添加了名稱查詢自定義方法。現在,讓我們使用 @Query 新增另一個方法並對其進行測試。
儲存庫 - EmployeeRepository.java
新增一個方法來按名稱獲取員工列表。
package com.tutorialspoint.repository;
import org.springframework.data.jpa.repository.Query;
import org.springframework.data.repository.CrudRepository;
import org.springframework.stereotype.Repository;
import com.tutorialspoint.entity.Employee;
@Repository
public interface EmployeeRepository extends CrudRepository<Employee, Integer> {
public List<Employee> findByName(String name);
public List<Employee> findByAge(int age);
public Employee findByEmail(String email);
@Query(value = "SELECT e FROM Employee e ORDER BY name")
public List<Employee> findAllSortedByName();
}
讓我們在測試檔案中新增他們的測試用例來測試新增的方法。下方檔案中的最後兩個方法會測試新增的自定義查詢方法。
以下是 EmployeeRepositoryTest 的完整程式碼。
package com.tutorialspoint.repository;
import static org.junit.jupiter.api.Assertions.assertEquals;
import java.util.ArrayList;
import java.util.List;
import javax.transaction.Transactional;
import org.junit.jupiter.api.Test;
import org.junit.jupiter.api.extension.ExtendWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.test.context.junit.jupiter.SpringExtension;
import com.tutorialspoint.entity.Employee;
import com.tutorialspoint.sprintbooth2.SprintBootH2Application;
@ExtendWith(SpringExtension.class)
@Transactional
@SpringBootTest(classes = SprintBootH2Application.class)
public class EmployeeRepositoryTest {
@Autowired
private EmployeeRepository employeeRepository;
@Test
public void testFindById() {
Employee employee = getEmployee();
employeeRepository.save(employee);
Employee result = employeeRepository.findById(employee.getId()).get();
assertEquals(employee.getId(), result.getId());
}
@Test
public void testFindAll() {
Employee employee = getEmployee();
employeeRepository.save(employee);
List<Employee> result = new ArrayList<>();
employeeRepository.findAll().forEach(e -> result.add(e));
assertEquals(result.size(), 1);
}
@Test
public void testSave() {
Employee employee = getEmployee();
employeeRepository.save(employee);
Employee found = employeeRepository.findById(employee.getId()).get();
assertEquals(employee.getId(), found.getId());
}
@Test
public void testDeleteById() {
Employee employee = getEmployee();
employeeRepository.save(employee);
employeeRepository.deleteById(employee.getId());
List<Employee> result = new ArrayList<>();
employeeRepository.findAll().forEach(e -> result.add(e));
assertEquals(result.size(), 0);
}
private Employee getEmployee() {
Employee employee = new Employee();
employee.setId(1);
employee.setName("Mahesh");
employee.setAge(30);
employee.setEmail("mahesh@test.com");
return employee;
}
@Test
public void testFindByName() {
Employee employee = getEmployee();
employeeRepository.save(employee);
List<Employee> result = new ArrayList<>();
employeeRepository.findByName(employee.getName()).forEach(e -> result.add(e));
assertEquals(result.size(), 1);
}
@Test
public void testFindByAge() {
Employee employee = getEmployee();
employeeRepository.save(employee);
List<Employee> result = new ArrayList<>();
employeeRepository.findByAge(employee.getAge()).forEach(e -> result.add(e));
assertEquals(result.size(), 1);
}
@Test
public void testFindByEmail() {
Employee employee = getEmployee();
employeeRepository.save(employee);
Employee result = employeeRepository.findByEmail(employee.getEmail());
assertNotNull(result);
}
@Test
public void testFindAllSortedByName() {
Employee employee = getEmployee();
Employee employee1 = new Employee();
employee1.setId(2);
employee1.setName("Aarav");
employee1.setAge(20);
employee1.setEmail("aarav@test.com");
employeeRepository.save(employee);
employeeRepository.save(employee1);
List<Employee> result = employeeRepository.findAllSortedByName();
assertEquals(employee1.getName(), result.get(0).getName());
}
}
執行測試用例
右鍵單擊 Eclipse 中的檔案,然後選擇執行 JUnit 測試並驗證結果。
廣告