|
31 | 31 | import org.apache.cayenne.testdo.meaningful_pk.MeaningfulPKDep; |
32 | 32 | import org.apache.cayenne.testdo.meaningful_pk.MeaningfulPKTest1; |
33 | 33 | import org.apache.cayenne.testdo.meaningful_pk.MeaningfulPk; |
| 34 | +import org.apache.cayenne.testdo.meaningful_pk.MeaningfulPkBigint; |
34 | 35 | import org.apache.cayenne.testdo.meaningful_pk.MeaningfulPkDep2; |
35 | 36 | import org.apache.cayenne.testdo.meaningful_pk.MeaningfulPkTest2; |
36 | 37 | import org.apache.cayenne.unit.di.server.CayenneProjects; |
|
39 | 40 | import org.junit.Ignore; |
40 | 41 | import org.junit.Test; |
41 | 42 |
|
| 43 | +import java.math.BigInteger; |
42 | 44 | import java.util.List; |
43 | 45 | import java.util.Map; |
44 | 46 |
|
@@ -270,4 +272,62 @@ public void test_MeaningfulPkWithFkUpdate() { |
270 | 272 | obj.setPkAttribute(1002); |
271 | 273 | context.commitChanges(); |
272 | 274 | } |
| 275 | + |
| 276 | + @Test |
| 277 | + public void testPaginatedQuery() { |
| 278 | + MeaningfulPk pkObj = context.newObject(MeaningfulPk.class); |
| 279 | + pkObj.setPk("123"); |
| 280 | + context.commitChanges(); |
| 281 | + |
| 282 | + MeaningfulPk pkObj2 = context.newObject(MeaningfulPk.class); |
| 283 | + pkObj2.setPk("124"); |
| 284 | + context.commitChanges(); |
| 285 | + |
| 286 | + MeaningfulPk pkObj3 = context.newObject(MeaningfulPk.class); |
| 287 | + pkObj3.setPk("125"); |
| 288 | + context.commitChanges(); |
| 289 | + |
| 290 | + ObjectContext cleanContext = runtime.newContext(); |
| 291 | + |
| 292 | + List<MeaningfulPk> select = ObjectSelect.query(MeaningfulPk.class) |
| 293 | + .orderBy(MeaningfulPk.PK.asc()) |
| 294 | + .pageSize(1) |
| 295 | + .select(cleanContext); |
| 296 | + |
| 297 | + assertEquals(3, select.size()); |
| 298 | + for(MeaningfulPk pk : select) { |
| 299 | + assertNotNull(pk.getPk()); |
| 300 | + assertTrue(pk.getPk().startsWith("12")); |
| 301 | + } |
| 302 | + } |
| 303 | + |
| 304 | + |
| 305 | + @Test |
| 306 | + public void testPaginatedQueryBigInteger() { |
| 307 | + MeaningfulPkBigint pkObj = context.newObject(MeaningfulPkBigint.class); |
| 308 | + pkObj.setPk(BigInteger.valueOf(123)); |
| 309 | + context.commitChanges(); |
| 310 | + |
| 311 | + MeaningfulPkBigint pkObj2 = context.newObject(MeaningfulPkBigint.class); |
| 312 | + pkObj2.setPk(BigInteger.valueOf(124)); |
| 313 | + context.commitChanges(); |
| 314 | + |
| 315 | + MeaningfulPkBigint pkObj3 = context.newObject(MeaningfulPkBigint.class); |
| 316 | + pkObj3.setPk(BigInteger.valueOf(125)); |
| 317 | + context.commitChanges(); |
| 318 | + |
| 319 | + ObjectContext cleanContext = runtime.newContext(); |
| 320 | + |
| 321 | + List<MeaningfulPkBigint> select = ObjectSelect.query(MeaningfulPkBigint.class) |
| 322 | + .orderBy(MeaningfulPk.PK.asc()) |
| 323 | + .pageSize(1) |
| 324 | + .select(cleanContext); |
| 325 | + |
| 326 | + assertEquals(3, select.size()); |
| 327 | + for(MeaningfulPkBigint pk : select) { |
| 328 | + assertNotNull(pk.getPk()); |
| 329 | + assertTrue(pk.getPk().compareTo(BigInteger.valueOf(120)) > 0); |
| 330 | + } |
| 331 | + } |
| 332 | + |
273 | 333 | } |
0 commit comments