|
22 | 22 | import java.sql.ResultSet;
|
23 | 23 | import java.util.List;
|
24 | 24 | import java.util.Properties;
|
| 25 | +import java.util.stream.Stream; |
25 | 26 |
|
26 | 27 | import org.assertj.core.api.Assertions;
|
27 | 28 | import org.junit.jupiter.api.BeforeEach;
|
28 | 29 | import org.junit.jupiter.api.Test;
|
29 |
| - |
| 30 | +import org.mockito.ArgumentCaptor; |
30 | 31 | import org.springframework.dao.DataAccessException;
|
31 | 32 | import org.springframework.data.domain.Page;
|
32 | 33 | import org.springframework.data.domain.Pageable;
|
|
39 | 40 | import org.springframework.data.repository.Repository;
|
40 | 41 | import org.springframework.data.repository.core.support.DefaultRepositoryMetadata;
|
41 | 42 | import org.springframework.data.repository.core.support.PropertiesBasedNamedQueries;
|
| 43 | +import org.springframework.data.repository.query.DefaultParameters; |
42 | 44 | import org.springframework.jdbc.core.ResultSetExtractor;
|
43 | 45 | import org.springframework.jdbc.core.RowMapper;
|
44 | 46 | import org.springframework.jdbc.core.namedparam.NamedParameterJdbcOperations;
|
| 47 | +import org.springframework.jdbc.core.namedparam.SqlParameterSource; |
45 | 48 | import org.springframework.util.ReflectionUtils;
|
46 | 49 |
|
47 | 50 | /**
|
|
52 | 55 | * @author Maciej Walkowiak
|
53 | 56 | * @author Evgeni Dimitrov
|
54 | 57 | * @author Mark Paluch
|
| 58 | + * @author Dennis Effing |
55 | 59 | */
|
56 | 60 | public class StringBasedJdbcQueryUnitTests {
|
57 | 61 |
|
@@ -127,6 +131,28 @@ public void customResultSetExtractorAndRowMapperGetCombined() {
|
127 | 131 | "RowMapper is not expected to be custom");
|
128 | 132 | }
|
129 | 133 |
|
| 134 | + @Test // DATAJDBC-356 |
| 135 | + public void streamQueryCallsQueryForStreamOnOperations() { |
| 136 | + JdbcQueryMethod queryMethod = createMethod("findAllWithStreamReturnType"); |
| 137 | + StringBasedJdbcQuery query = createQuery(queryMethod); |
| 138 | + |
| 139 | + query.execute(new Object[] {}); |
| 140 | + |
| 141 | + verify(operations).queryForStream(eq("some sql statement"), any(SqlParameterSource.class), any(RowMapper.class)); |
| 142 | + } |
| 143 | + |
| 144 | + @Test // DATAJDBC-356 |
| 145 | + void streamQueryFallsBackToCollectionQueryWhenCustomResultSetExtractorIsSpecified() { |
| 146 | + JdbcQueryMethod queryMethod = createMethod("findAllWithStreamReturnTypeAndResultSetExtractor"); |
| 147 | + StringBasedJdbcQuery query = createQuery(queryMethod); |
| 148 | + |
| 149 | + query.execute(new Object[] {}); |
| 150 | + |
| 151 | + ArgumentCaptor<ResultSetExtractor> captor = ArgumentCaptor.forClass(ResultSetExtractor.class); |
| 152 | + verify(operations).query(eq("some sql statement"), any(SqlParameterSource.class), captor.capture()); |
| 153 | + assertThat(captor.getValue()).isInstanceOf(CustomResultSetExtractor.class); |
| 154 | + } |
| 155 | + |
130 | 156 | @Test // GH-774
|
131 | 157 | public void sliceQueryNotSupported() {
|
132 | 158 |
|
@@ -173,6 +199,12 @@ interface MyRepository extends Repository<Object, Long> {
|
173 | 199 | resultSetExtractorClass = CustomResultSetExtractor.class)
|
174 | 200 | List<Object> findAllWithCustomRowMapperAndResultSetExtractor();
|
175 | 201 |
|
| 202 | + @Query(value = "some sql statement") |
| 203 | + Stream<Object> findAllWithStreamReturnType(); |
| 204 | + |
| 205 | + @Query(value = "some sql statement", resultSetExtractorClass = CustomResultSetExtractor.class) |
| 206 | + Stream<Object> findAllWithStreamReturnTypeAndResultSetExtractor(); |
| 207 | + |
176 | 208 | List<Object> noAnnotation();
|
177 | 209 |
|
178 | 210 | @Query(value = "some sql statement")
|
|
0 commit comments