|
1 | 1 | -- Setup test table and read in student solution:
|
2 | 2 | .read ./test_setup.sql
|
3 |
| - |
4 | 3 | -- Test cases:
|
5 | 4 | -- Note: the strings below may contain literal tab, newline, carriage returns.
|
6 |
| - |
7 |
| -INSERT INTO tests (name, uuid, |
8 |
| - task, square, expected) |
9 |
| - VALUES |
10 |
| - ('grains on square 1', '9fbde8de-36b2-49de-baf2-cd42d6f28405', |
11 |
| - 'single-square', 1, 1), |
12 |
| - ('grains on square 2', 'ee1f30c2-01d8-4298-b25d-c677331b5e6d', |
13 |
| - 'single-square', 2, 2), |
14 |
| - ('grains on square 3', '10f45584-2fc3-4875-8ec6-666065d1163b', |
15 |
| - 'single-square', 3, 4), |
16 |
| - ('grains on square 4', 'a7cbe01b-36f4-4601-b053-c5f6ae055170', |
17 |
| - 'single-square', 4, 8), |
18 |
| - ('grains on square 16', 'c50acc89-8535-44e4-918f-b848ad2817d4', |
19 |
| - 'single-square', 16, 32768), |
20 |
| - ('grains on square 32', 'acd81b46-c2ad-4951-b848-80d15ed5a04f', |
21 |
| - 'single-square', 32, 2147483648), |
22 |
| - ('grains on square 64', 'c73b470a-5efb-4d53-9ac6-c5f6487f227b', |
23 |
| - 'single-square', 64, 9223372036854775808), |
24 |
| - ('returns the total number of grains on the board', '6eb07385-3659-4b45-a6be-9dc474222750', |
25 |
| - 'total', 0, 18446744073709551615); |
26 |
| - |
| 5 | +INSERT INTO |
| 6 | + tests (name, uuid, task, square, expected) |
| 7 | +VALUES |
| 8 | + ( |
| 9 | + 'grains on square 1', |
| 10 | + '9fbde8de-36b2-49de-baf2-cd42d6f28405', |
| 11 | + 'single-square', |
| 12 | + 1, |
| 13 | + 1 |
| 14 | + ), |
| 15 | + ( |
| 16 | + 'grains on square 2', |
| 17 | + 'ee1f30c2-01d8-4298-b25d-c677331b5e6d', |
| 18 | + 'single-square', |
| 19 | + 2, |
| 20 | + 2 |
| 21 | + ), |
| 22 | + ( |
| 23 | + 'grains on square 3', |
| 24 | + '10f45584-2fc3-4875-8ec6-666065d1163b', |
| 25 | + 'single-square', |
| 26 | + 3, |
| 27 | + 4 |
| 28 | + ), |
| 29 | + ( |
| 30 | + 'grains on square 4', |
| 31 | + 'a7cbe01b-36f4-4601-b053-c5f6ae055170', |
| 32 | + 'single-square', |
| 33 | + 4, |
| 34 | + 8 |
| 35 | + ), |
| 36 | + ( |
| 37 | + 'grains on square 16', |
| 38 | + 'c50acc89-8535-44e4-918f-b848ad2817d4', |
| 39 | + 'single-square', |
| 40 | + 16, |
| 41 | + 32768 |
| 42 | + ), |
| 43 | + ( |
| 44 | + 'grains on square 32', |
| 45 | + 'acd81b46-c2ad-4951-b848-80d15ed5a04f', |
| 46 | + 'single-square', |
| 47 | + 32, |
| 48 | + 2147483648 |
| 49 | + ), |
| 50 | + ( |
| 51 | + 'grains on square 64', |
| 52 | + 'c73b470a-5efb-4d53-9ac6-c5f6487f227b', |
| 53 | + 'single-square', |
| 54 | + 64, |
| 55 | + 9223372036854775808 |
| 56 | + ), |
| 57 | + ( |
| 58 | + 'returns the total number of grains on the board', |
| 59 | + '6eb07385-3659-4b45-a6be-9dc474222750', |
| 60 | + 'total', |
| 61 | + 0, |
| 62 | + 18446744073709551615 |
| 63 | + ); |
27 | 64 |
|
28 | 65 | -- Comparison of user input and the tests updates the status for each test:
|
29 | 66 | UPDATE tests
|
30 |
| -SET status = 'pass' |
31 |
| -FROM (SELECT task, square, result FROM grains) AS actual |
32 |
| -WHERE (actual.task, actual.square, actual.result) = (tests.task, tests.square, tests.expected); |
| 67 | +SET |
| 68 | + status = 'pass' |
| 69 | +FROM |
| 70 | + ( |
| 71 | + SELECT |
| 72 | + task, |
| 73 | + square, |
| 74 | + result |
| 75 | + FROM |
| 76 | + grains |
| 77 | + ) AS actual |
| 78 | +WHERE |
| 79 | + (actual.task, actual.square, actual.result) = (tests.task, tests.square, tests.expected); |
33 | 80 |
|
34 | 81 | -- Write results and debug info:
|
35 | 82 | .read ./test_reporter.sql
|
0 commit comments