|
27 | 27 | import org.assertj.core.api.Assertions;
|
28 | 28 | import org.junit.jupiter.api.BeforeEach;
|
29 | 29 | import org.junit.jupiter.api.Test;
|
| 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;
|
@@ -140,6 +141,18 @@ public void streamQueryCallsQueryForStreamOnOperations() {
|
140 | 141 | verify(operations).queryForStream(eq("some sql statement"), any(SqlParameterSource.class), any(RowMapper.class));
|
141 | 142 | }
|
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 | + |
143 | 156 | @Test // GH-774
|
144 | 157 | public void sliceQueryNotSupported() {
|
145 | 158 |
|
@@ -189,6 +202,9 @@ interface MyRepository extends Repository<Object, Long> {
|
189 | 202 | @Query(value = "some sql statement")
|
190 | 203 | Stream<Object> findAllWithStreamReturnType();
|
191 | 204 |
|
| 205 | + @Query(value = "some sql statement", resultSetExtractorClass = CustomResultSetExtractor.class) |
| 206 | + Stream<Object> findAllWithStreamReturnTypeAndResultSetExtractor(); |
| 207 | + |
192 | 208 | List<Object> noAnnotation();
|
193 | 209 |
|
194 | 210 | @Query(value = "some sql statement")
|
|
0 commit comments