|
2 | 2 | private class CursorTest { |
3 | 3 | @IsTest |
4 | 4 | static void itCapsAdvanceByArgument() { |
5 | | - String query = 'SELECT Id FROM User WHERE Id = :bindVar0'; |
6 | | - Map<String, Object> bindVars = new Map<String, Object>{ 'bindVar0' => UserInfo.getUserId() }; |
| 5 | + String accountName = 'helloWorld!'; |
| 6 | + insert new Account(Name = accountName); |
| 7 | + String query = 'SELECT Name FROM Account WHERE Name = :bindVar0'; |
| 8 | + Map<String, Object> bindVars = new Map<String, Object>{ 'bindVar0' => accountName }; |
7 | 9 |
|
8 | | - Cursor cursor = new Cursor(query, bindVars, System.AccessLevel.SYSTEM_MODE); |
| 10 | + Cursor instance = new Cursor(query, bindVars, System.AccessLevel.SYSTEM_MODE); |
9 | 11 |
|
10 | | - Assert.areEqual(1, cursor.getNumRecords()); |
11 | | - Assert.areEqual(UserInfo.getUserId(), cursor.fetch(0, 1000).get(0).Id); |
| 12 | + Assert.areEqual(1, instance.getNumRecords()); |
| 13 | + Assert.areEqual(accountName, instance.fetch(0, 1000).get(0).get('Name')); |
12 | 14 | Assert.areEqual(1, System.Limits.getApexCursorRows()); |
13 | 15 | } |
14 | 16 |
|
15 | 17 | @IsTest |
16 | 18 | static void itCapsMaxFetchSize() { |
| 19 | + Cursor.maxFetchSize = 20; |
17 | 20 | List<Account> accounts = new List<Account>(); |
18 | | - for (Integer i = 0; i < 2001; i++) { |
| 21 | + for (Integer i = 0; i < Cursor.maxFetchSize + 1; i++) { |
19 | 22 | accounts.add(new Account(Name = 'Fetch ' + i)); |
20 | 23 | } |
21 | 24 | insert accounts; |
22 | 25 |
|
23 | | - Integer oneMoreThanMaxFetch = 2001; |
| 26 | + Integer oneMoreThanMaxFetch = Cursor.maxFetchSize + 1; |
24 | 27 | Exception ex; |
| 28 | + List<SObject> results; |
| 29 | + Cursor instance = new Cursor('SELECT Id FROM Account', new Map<String, Object>(), System.AccessLevel.SYSTEM_MODE); |
25 | 30 | try { |
26 | | - new Cursor('SELECT Id FROM Account', new Map<String, Object>(), System.AccessLevel.SYSTEM_MODE) |
27 | | - .fetch(0, oneMoreThanMaxFetch); |
| 31 | + results = instance.fetch(0, oneMoreThanMaxFetch); |
28 | 32 | } catch (System.InvalidParameterValueException e) { |
29 | 33 | ex = e; |
30 | 34 | } |
31 | 35 |
|
32 | 36 | Assert.areEqual(null, ex?.getMessage()); |
| 37 | + Assert.areEqual(Cursor.maxFetchSize, results.size()); |
| 38 | + Assert.areEqual(1, Cursor.localFetchesMade); |
| 39 | + } |
| 40 | + |
| 41 | + @IsTest |
| 42 | + static void itFetchesMultipleTimesPerTransactionWhenMoreThanMaxFetch() { |
| 43 | + Cursor.maxFetchSize = 20; |
| 44 | + List<Account> accounts = new List<Account>(); |
| 45 | + Set<String> expectedFetchNames = new Set<String>(); |
| 46 | + for (Integer i = 0; i < Cursor.maxFetchSize + 1; i++) { |
| 47 | + String accountName = 'Fetch' + i; |
| 48 | + expectedFetchNames.add(accountName); |
| 49 | + accounts.add(new Account(Name = accountName)); |
| 50 | + } |
| 51 | + insert accounts; |
| 52 | + |
| 53 | + Integer oneMoreThanMaxFetch = Cursor.maxFetchSize + 1; |
| 54 | + Cursor instance = new Cursor('SELECT Name FROM Account', new Map<String, Object>(), System.AccessLevel.SYSTEM_MODE); |
| 55 | + List<SObject> results = instance.setFetchesPerTransaction(2).fetch(0, oneMoreThanMaxFetch); |
| 56 | + |
| 57 | + Assert.areEqual(Cursor.maxFetchSize + 1, results.size()); |
| 58 | + Assert.areEqual(2, Cursor.localFetchesMade); |
| 59 | + Set<String> actuallyFetchedNames = new Set<String>(); |
| 60 | + for (Account account : (List<Account>) results) { |
| 61 | + actuallyFetchedNames.add(account.Name); |
| 62 | + } |
| 63 | + Assert.areEqual(expectedFetchNames, actuallyFetchedNames); |
33 | 64 | } |
34 | 65 |
|
35 | 66 | @IsTest |
36 | 67 | static void itFetchesMultipleTimesPerTransaction() { |
| 68 | + Cursor.maxFetchSize = 1; |
37 | 69 | insert new List<Account>{ new Account(Name = 'One'), new Account(Name = 'Two') }; |
38 | 70 |
|
39 | | - Cursor cursor = new Cursor('SELECT Id FROM Account', new Map<String, Object>(), System.AccessLevel.SYSTEM_MODE) |
| 71 | + Cursor instance = new Cursor('SELECT Id FROM Account', new Map<String, Object>(), System.AccessLevel.SYSTEM_MODE) |
40 | 72 | .setFetchesPerTransaction(2); |
41 | | - List<SObject> results = cursor.fetch(0, 1); |
| 73 | + List<SObject> results = instance.fetch(0, 2); |
42 | 74 |
|
| 75 | + Assert.areEqual(2, instance.getNumRecords()); |
43 | 76 | Assert.areEqual(2, results.size()); |
44 | | - results = cursor.fetch(2, 1); |
| 77 | + results = instance.fetch(2, 1); |
45 | 78 | Assert.areEqual(0, results.size()); |
46 | | - Assert.areEqual(2, cursor.getNumRecords()); |
| 79 | + } |
| 80 | + |
| 81 | + @IsTest |
| 82 | + static void fetchesCorrectAmountOfRecords() { |
| 83 | + List<Account> accounts = new List<Account>(); |
| 84 | + for (Integer i = 0; i < 10; i++) { |
| 85 | + accounts.add(new Account(Name = 'Fetch ' + i)); |
| 86 | + } |
| 87 | + insert accounts; |
| 88 | + |
| 89 | + Cursor instance = new Cursor('SELECT Id FROM Account', new Map<String, Object>(), System.AccessLevel.SYSTEM_MODE) |
| 90 | + .setFetchesPerTransaction(10); |
| 91 | + List<SObject> results = instance.fetch(0, 2); |
| 92 | + |
| 93 | + Assert.areEqual(2, results.size(), '' + results); |
| 94 | + Assert.areEqual(1, Cursor.localFetchesMade); |
47 | 95 | } |
48 | 96 | } |
0 commit comments