|
2 | 2 |
|
3 | 3 | import static org.junit.jupiter.api.Assertions.assertEquals;
|
4 | 4 | import static org.junit.jupiter.api.Assertions.assertFalse;
|
5 |
| -import static org.junit.jupiter.api.Assertions.assertThrows; |
6 | 5 | import static org.junit.jupiter.api.Assertions.assertTrue;
|
7 | 6 |
|
8 | 7 | import java.util.ArrayList;
|
9 | 8 | import java.util.Arrays;
|
10 |
| -import java.util.HashMap; |
11 |
| -import org.junit.jupiter.api.Test; |
| 9 | +import java.util.List; |
| 10 | +import java.util.stream.Stream; |
| 11 | +import org.junit.jupiter.params.ParameterizedTest; |
| 12 | +import org.junit.jupiter.params.provider.Arguments; |
| 13 | +import org.junit.jupiter.params.provider.MethodSource; |
12 | 14 |
|
13 | 15 | public class LowestBasePalindromeTest {
|
14 |
| - @Test |
15 |
| - public void testIsPalindromicPositive() { |
16 |
| - assertTrue(LowestBasePalindrome.isPalindromic(new ArrayList<Integer>())); |
17 |
| - assertTrue(LowestBasePalindrome.isPalindromic(new ArrayList<Integer>(Arrays.asList(1)))); |
18 |
| - assertTrue(LowestBasePalindrome.isPalindromic(new ArrayList<Integer>(Arrays.asList(1, 1)))); |
19 |
| - assertTrue(LowestBasePalindrome.isPalindromic(new ArrayList<Integer>(Arrays.asList(1, 2, 1)))); |
20 |
| - assertTrue(LowestBasePalindrome.isPalindromic(new ArrayList<Integer>(Arrays.asList(1, 2, 2, 1)))); |
| 16 | + |
| 17 | + @ParameterizedTest |
| 18 | + @MethodSource("provideListsForIsPalindromicPositive") |
| 19 | + public void testIsPalindromicPositive(List<Integer> list) { |
| 20 | + assertTrue(LowestBasePalindrome.isPalindromic(list)); |
| 21 | + } |
| 22 | + |
| 23 | + @ParameterizedTest |
| 24 | + @MethodSource("provideListsForIsPalindromicNegative") |
| 25 | + public void testIsPalindromicNegative(List<Integer> list) { |
| 26 | + assertFalse(LowestBasePalindrome.isPalindromic(list)); |
| 27 | + } |
| 28 | + |
| 29 | + @ParameterizedTest |
| 30 | + @MethodSource("provideNumbersAndBasesForIsPalindromicInBasePositive") |
| 31 | + public void testIsPalindromicInBasePositive(int number, int base) { |
| 32 | + assertTrue(LowestBasePalindrome.isPalindromicInBase(number, base)); |
21 | 33 | }
|
22 | 34 |
|
23 |
| - @Test |
24 |
| - public void testIsPalindromicNegative() { |
25 |
| - assertFalse(LowestBasePalindrome.isPalindromic(new ArrayList<Integer>(Arrays.asList(1, 2)))); |
26 |
| - assertFalse(LowestBasePalindrome.isPalindromic(new ArrayList<Integer>(Arrays.asList(1, 2, 1, 1)))); |
| 35 | + @ParameterizedTest |
| 36 | + @MethodSource("provideNumbersAndBasesForIsPalindromicInBaseNegative") |
| 37 | + public void testIsPalindromicInBaseNegative(int number, int base) { |
| 38 | + assertFalse(LowestBasePalindrome.isPalindromicInBase(number, base)); |
27 | 39 | }
|
28 | 40 |
|
29 |
| - @Test |
30 |
| - public void testIsPalindromicInBasePositive() { |
31 |
| - assertTrue(LowestBasePalindrome.isPalindromicInBase(101, 10)); |
32 |
| - assertTrue(LowestBasePalindrome.isPalindromicInBase(1, 190)); |
33 |
| - assertTrue(LowestBasePalindrome.isPalindromicInBase(0, 11)); |
34 |
| - assertTrue(LowestBasePalindrome.isPalindromicInBase(10101, 10)); |
35 |
| - assertTrue(LowestBasePalindrome.isPalindromicInBase(23, 22)); |
| 41 | + @ParameterizedTest |
| 42 | + @MethodSource("provideNumbersAndBasesForExceptions") |
| 43 | + public void testIsPalindromicInBaseThrowsException(int number, int base) { |
| 44 | + org.junit.jupiter.api.Assertions.assertThrows(IllegalArgumentException.class, () -> LowestBasePalindrome.isPalindromicInBase(number, base)); |
36 | 45 | }
|
37 | 46 |
|
38 |
| - @Test |
39 |
| - public void testIsPalindromicInBaseNegative() { |
40 |
| - assertFalse(LowestBasePalindrome.isPalindromicInBase(1010, 10)); |
41 |
| - assertFalse(LowestBasePalindrome.isPalindromicInBase(123, 10)); |
| 47 | + @ParameterizedTest |
| 48 | + @MethodSource("provideNumbersForLowestBasePalindrome") |
| 49 | + public void testLowestBasePalindrome(int number, int expectedBase) { |
| 50 | + assertEquals(expectedBase, LowestBasePalindrome.lowestBasePalindrome(number)); |
42 | 51 | }
|
43 | 52 |
|
44 |
| - @Test |
45 |
| - public void testIsPalindromicInBaseThrowsExceptionForNegativeNumbers() { |
46 |
| - assertThrows(IllegalArgumentException.class, () -> LowestBasePalindrome.isPalindromicInBase(-1, 5)); |
| 53 | + private static Stream<Arguments> provideListsForIsPalindromicPositive() { |
| 54 | + return Stream.of(Arguments.of(new ArrayList<>()), Arguments.of(new ArrayList<>(List.of(1))), Arguments.of(new ArrayList<>(Arrays.asList(1, 1))), Arguments.of(new ArrayList<>(Arrays.asList(1, 2, 1))), Arguments.of(new ArrayList<>(Arrays.asList(1, 2, 2, 1)))); |
47 | 55 | }
|
48 | 56 |
|
49 |
| - @Test |
50 |
| - public void testIsPalindromicInBaseThrowsExceptionForWrongBases() { |
51 |
| - assertThrows(IllegalArgumentException.class, () -> LowestBasePalindrome.isPalindromicInBase(10, 1)); |
| 57 | + private static Stream<Arguments> provideListsForIsPalindromicNegative() { |
| 58 | + return Stream.of(Arguments.of(new ArrayList<>(Arrays.asList(1, 2))), Arguments.of(new ArrayList<>(Arrays.asList(1, 2, 1, 1)))); |
52 | 59 | }
|
53 | 60 |
|
54 |
| - @Test |
55 |
| - public void testLowestBasePalindrome() { |
56 |
| - HashMap<Integer, Integer> testCases = new HashMap<>(); |
57 |
| - testCases.put(0, 2); |
58 |
| - testCases.put(1, 2); |
59 |
| - testCases.put(2, 3); |
60 |
| - testCases.put(3, 2); |
61 |
| - testCases.put(10, 3); |
62 |
| - testCases.put(11, 10); |
63 |
| - testCases.put(15, 2); |
64 |
| - testCases.put(39, 12); |
65 |
| - testCases.put(44, 10); |
66 |
| - testCases.put(58, 28); |
67 |
| - testCases.put(69, 22); |
68 |
| - testCases.put(79, 78); |
69 |
| - testCases.put(87, 28); |
70 |
| - testCases.put(90, 14); |
71 |
| - testCases.put(5591, 37); |
72 |
| - testCases.put(5895, 130); |
73 |
| - testCases.put(9950, 198); |
74 |
| - testCases.put(9974, 4986); |
| 61 | + private static Stream<Arguments> provideNumbersAndBasesForIsPalindromicInBasePositive() { |
| 62 | + return Stream.of(Arguments.of(101, 10), Arguments.of(1, 190), Arguments.of(0, 11), Arguments.of(10101, 10), Arguments.of(23, 22)); |
| 63 | + } |
| 64 | + |
| 65 | + private static Stream<Arguments> provideNumbersAndBasesForIsPalindromicInBaseNegative() { |
| 66 | + return Stream.of(Arguments.of(1010, 10), Arguments.of(123, 10)); |
| 67 | + } |
| 68 | + |
| 69 | + private static Stream<Arguments> provideNumbersAndBasesForExceptions() { |
| 70 | + return Stream.of(Arguments.of(-1, 5), Arguments.of(10, 1)); |
| 71 | + } |
75 | 72 |
|
76 |
| - for (final var tc : testCases.entrySet()) { |
77 |
| - assertEquals(LowestBasePalindrome.lowestBasePalindrome(tc.getKey()), tc.getValue()); |
78 |
| - } |
| 73 | + private static Stream<Arguments> provideNumbersForLowestBasePalindrome() { |
| 74 | + return Stream.of(Arguments.of(0, 2), Arguments.of(1, 2), Arguments.of(2, 3), Arguments.of(3, 2), Arguments.of(10, 3), Arguments.of(11, 10), Arguments.of(15, 2), Arguments.of(39, 12), Arguments.of(44, 10), |
| 75 | + Arguments.of(58, 28), Arguments.of(69, 22), Arguments.of(79, 78), Arguments.of(87, 28), Arguments.of(90, 14), Arguments.of(5591, 37), Arguments.of(5895, 130), Arguments.of(9950, 198), Arguments.of(9974, 4986)); |
79 | 76 | }
|
80 | 77 | }
|
0 commit comments