/**
* Copyright 2010-2017 the original author or authors.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.mybatis.spring.batch;
import java.util.ArrayList;
import java.util.List;
import static org.assertj.core.api.Assertions.*;
import org.apache.ibatis.session.SqlSession;
import org.junit.jupiter.api.Test;
import org.mybatis.spring.batch.domain.Employee;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.test.context.junit.jupiter.SpringJUnitConfig;
import org.springframework.transaction.annotation.Transactional;
@SpringJUnitConfig(locations = {"classpath:org/mybatis/spring/batch/applicationContext.xml"})
public class SpringBatchTest {
@Autowired
@Qualifier("pagingNoNestedItemReader")
private MyBatisPagingItemReader<Employee> pagingNoNestedItemReader;
@Autowired
@Qualifier("pagingNestedItemReader")
private MyBatisPagingItemReader<Employee> pagingNestedItemReader;
@Autowired
@Qualifier("cursorNoNestedItemReader")
private MyBatisCursorItemReader<Employee> cursorNoNestedItemReader;
@Autowired
@Qualifier("cursorNestedItemReader")
private MyBatisCursorItemReader<Employee> cursorNestedItemReader;
@Autowired
private MyBatisBatchItemWriter<Employee> writer;
@Autowired
private SqlSession session;
@Test
@Transactional
public void shouldDuplicateSalaryOfAllEmployees() throws Exception {
List<Employee> employees = new ArrayList<>();
Employee employee = pagingNoNestedItemReader.read();
while (employee != null) {
employee.setSalary(employee.getSalary() * 2);
employees.add(employee);
employee = pagingNoNestedItemReader.read();
}
writer.write(employees);
assertThat((Integer) session.selectOne("checkSalarySum")).isEqualTo(20000);
assertThat((Integer) session.selectOne("checkEmployeeCount")).isEqualTo(employees.size());
}
@Test
@Transactional
public void checkPagingReadingWithNestedInResultMap() throws Exception {
// This test is here to show that PagingReader can return wrong result in case of nested result maps
List<Employee> employees = new ArrayList<>();
Employee employee = pagingNestedItemReader.read();
while (employee != null) {
employee.setSalary(employee.getSalary() * 2);
employees.add(employee);
employee = pagingNestedItemReader.read();
}
writer.write(employees);
// Assert that we have a WRONG employee count
assertThat((Integer) session.selectOne("checkEmployeeCount")).isNotEqualTo(employees.size());
}
@Test
@Transactional
public void checkCursorReadingWithoutNestedInResultMap() throws Exception {
cursorNoNestedItemReader.doOpen();
try {
List<Employee> employees = new ArrayList<>();
Employee employee = cursorNoNestedItemReader.read();
while (employee != null) {
employee.setSalary(employee.getSalary() * 2);
employees.add(employee);
employee = cursorNoNestedItemReader.read();
}
writer.write(employees);
assertThat((Integer) session.selectOne("checkSalarySum")).isEqualTo(20000);
assertThat((Integer) session.selectOne("checkEmployeeCount")).isEqualTo(employees.size());
} finally {
cursorNoNestedItemReader.doClose();
}
}
@Test
@Transactional
public void checkCursorReadingWithNestedInResultMap() throws Exception {
cursorNestedItemReader.doOpen();
try {
List<Employee> employees = new ArrayList<>();
Employee employee = cursorNestedItemReader.read();
while (employee != null) {
employee.setSalary(employee.getSalary() * 2);
employees.add(employee);
employee = cursorNestedItemReader.read();
}
writer.write(employees);
assertThat((Integer) session.selectOne("checkSalarySum")).isEqualTo(20000);
assertThat((Integer) session.selectOne("checkEmployeeCount")).isEqualTo(employees.size());
} finally {
cursorNestedItemReader.doClose();
}
}
}