aboutsummaryrefslogtreecommitdiffstats
path: root/test/eu/equalparts/cardbase
diff options
context:
space:
mode:
authorEduardo Pedroni <e.pedroni91@gmail.com>2016-08-07 22:18:55 +0200
committerEduardo Pedroni <e.pedroni91@gmail.com>2016-08-07 22:18:55 +0200
commitf7fe057b745d3f0e19b5dd6bd1819b11fc89c551 (patch)
tree1d19673aa4170f91248682a21db9fbc7c3945f4e /test/eu/equalparts/cardbase
parent64c8e926d167a17865a6c3d86e48b383d413b569 (diff)
Added filtering, still not working fully
Diffstat (limited to 'test/eu/equalparts/cardbase')
-rw-r--r--test/eu/equalparts/cardbase/containers/ReferenceCardContainerTest.java (renamed from test/eu/equalparts/cardbase/cardstorage/ReferenceCardContainerTest.java)5
-rw-r--r--test/eu/equalparts/cardbase/containers/StandaloneCardContainerTest.java (renamed from test/eu/equalparts/cardbase/cardstorage/StandaloneCardContainerTest.java)5
-rw-r--r--test/eu/equalparts/cardbase/decks/ReferenceDeckTest.java2
-rw-r--r--test/eu/equalparts/cardbase/filtering/CardFilteringTest.java252
-rw-r--r--test/eu/equalparts/cardbase/sorting/CardSortingTest.java88
5 files changed, 308 insertions, 44 deletions
diff --git a/test/eu/equalparts/cardbase/cardstorage/ReferenceCardContainerTest.java b/test/eu/equalparts/cardbase/containers/ReferenceCardContainerTest.java
index bf49e2f..849d84c 100644
--- a/test/eu/equalparts/cardbase/cardstorage/ReferenceCardContainerTest.java
+++ b/test/eu/equalparts/cardbase/containers/ReferenceCardContainerTest.java
@@ -1,4 +1,4 @@
-package eu.equalparts.cardbase.cardstorage;
+package eu.equalparts.cardbase.containers;
import static org.junit.Assert.assertEquals;
@@ -11,7 +11,6 @@ import org.junit.rules.TemporaryFolder;
import com.fasterxml.jackson.databind.ObjectMapper;
-import eu.equalparts.cardbase.CardbaseTest;
import eu.equalparts.cardbase.cards.Card;
public class ReferenceCardContainerTest {
@@ -28,7 +27,7 @@ public class ReferenceCardContainerTest {
@BeforeClass
public static void setUpBeforeClass() throws Exception {
ObjectMapper mapper = new ObjectMapper();
- testCard = mapper.readValue(CardbaseTest.class.getResourceAsStream("/shivandragon.json"), Card.class);
+ testCard = mapper.readValue(ReferenceCardContainerTest.class.getResourceAsStream("/shivandragon.json"), Card.class);
}
@Before
diff --git a/test/eu/equalparts/cardbase/cardstorage/StandaloneCardContainerTest.java b/test/eu/equalparts/cardbase/containers/StandaloneCardContainerTest.java
index 6071e09..6e9b31a 100644
--- a/test/eu/equalparts/cardbase/cardstorage/StandaloneCardContainerTest.java
+++ b/test/eu/equalparts/cardbase/containers/StandaloneCardContainerTest.java
@@ -1,4 +1,4 @@
-package eu.equalparts.cardbase.cardstorage;
+package eu.equalparts.cardbase.containers;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertNotNull;
@@ -16,7 +16,6 @@ import org.junit.rules.TemporaryFolder;
import com.fasterxml.jackson.databind.ObjectMapper;
-import eu.equalparts.cardbase.CardbaseTest;
import eu.equalparts.cardbase.cards.Card;
public class StandaloneCardContainerTest {
@@ -32,7 +31,7 @@ public class StandaloneCardContainerTest {
@BeforeClass
public static void setUpBeforeClass() throws Exception {
ObjectMapper mapper = new ObjectMapper();
- testCard = mapper.readValue(CardbaseTest.class.getResourceAsStream("/shivandragon.json"), Card.class);
+ testCard = mapper.readValue(StandaloneCardContainerTest.class.getResourceAsStream("/shivandragon.json"), Card.class);
}
@Before
diff --git a/test/eu/equalparts/cardbase/decks/ReferenceDeckTest.java b/test/eu/equalparts/cardbase/decks/ReferenceDeckTest.java
index 928c167..2a6f482 100644
--- a/test/eu/equalparts/cardbase/decks/ReferenceDeckTest.java
+++ b/test/eu/equalparts/cardbase/decks/ReferenceDeckTest.java
@@ -6,7 +6,7 @@ import static org.junit.Assert.assertTrue;
import org.junit.Before;
import org.junit.Test;
-import eu.equalparts.cardbase.cardstorage.ReferenceCardContainer;
+import eu.equalparts.cardbase.containers.ReferenceCardContainer;
public class ReferenceDeckTest {
private ReferenceDeck uut;
diff --git a/test/eu/equalparts/cardbase/filtering/CardFilteringTest.java b/test/eu/equalparts/cardbase/filtering/CardFilteringTest.java
new file mode 100644
index 0000000..4f5579d
--- /dev/null
+++ b/test/eu/equalparts/cardbase/filtering/CardFilteringTest.java
@@ -0,0 +1,252 @@
+package eu.equalparts.cardbase.filtering;
+
+import static org.junit.Assert.assertEquals;
+import static org.junit.Assert.assertTrue;
+
+import java.util.LinkedList;
+import java.util.List;
+
+import org.junit.Before;
+import org.junit.BeforeClass;
+import org.junit.Rule;
+import org.junit.Test;
+import org.junit.rules.ExpectedException;
+
+import com.fasterxml.jackson.core.type.TypeReference;
+import com.fasterxml.jackson.databind.ObjectMapper;
+
+import eu.equalparts.cardbase.cards.Card;
+import eu.equalparts.cardbase.filtering.CardFiltering.FilterType;
+
+public class CardFilteringTest {
+ private static List<Card> allTestCards, testCards;
+
+ @Rule
+ public final ExpectedException exception = ExpectedException.none();
+
+ @BeforeClass
+ public static void setUpBeforeClass() throws Exception {
+ ObjectMapper mapper = new ObjectMapper();
+ allTestCards = mapper.readValue(CardFilteringTest.class.getResourceAsStream("/testcards.json"), new TypeReference<List<Card>>() {});
+ }
+
+ @Before
+ public void setUp() {
+ testCards = new LinkedList<>(allTestCards);
+ }
+
+ @Test
+ public void filterByNameEquals() throws Exception {
+ CardFiltering.filterByField(testCards, "name", FilterType.EQUALS, "Callow jushi");
+
+ assertEquals("Wrong list size.", 1, testCards.size());
+ assertEquals("Callow Jushi", testCards.get(0).name);
+ }
+
+ @Test
+ public void filterByNameContains() throws Exception {
+ CardFiltering.filterByField(testCards, "name", FilterType.CONTAINS, "sh");
+
+ assertEquals("Wrong list size.", 3, testCards.size());
+ int i = 0;
+ String[] names = {
+ "Callow Jushi",
+ "Shivan Dragon",
+ "Disrupting Shoal",
+ };
+ for (Card card : testCards) {
+ assertTrue(card.name + " should have been " + names[i] + ", i = " + i, card.name.equals(names[i]));
+ i++;
+ }
+ }
+
+ @Test
+ public void filterByNameRegex() throws Exception {
+ CardFiltering.filterByField(testCards, "name", FilterType.REGEX, ".+?n");
+
+ assertEquals("Wrong list size.", 2, testCards.size());
+ int i = 0;
+ String[] names = {
+ "Coerced Confession",
+ "Shivan Dragon",
+ };
+ for (Card card : testCards) {
+ assertTrue(card.name + " should have been " + names[i] + ", i = " + i, card.name.equals(names[i]));
+ i++;
+ }
+ }
+
+ @Test
+ public void filterByLayoutEquals() throws Exception {
+ CardFiltering.filterByField(testCards, "layout", FilterType.EQUALS, "flip");
+
+ assertEquals("Wrong list size.", 1, testCards.size());
+ assertEquals("Callow Jushi", testCards.get(0).name);
+ }
+
+ @Test
+ public void filterByLayoutContains() throws Exception {
+ CardFiltering.filterByField(testCards, "layout", FilterType.CONTAINS, "l");
+
+ assertEquals("Wrong list size.", 8, testCards.size());
+ int i = 0;
+ String[] names = {
+ "Callow Jushi",
+ "Coerced Confession",
+ "Khalni Hydra",
+ "Nightmare",
+ "Shivan Dragon",
+ "Disrupting Shoal",
+ "Sorin Markov",
+ "Ugin's Construct",
+ };
+ for (Card card : testCards) {
+ assertTrue(card.name + " should have been " + names[i] + ", i = " + i, card.name.equals(names[i]));
+ i++;
+ }
+ }
+
+ @Test
+ public void filterByLayoutRegex() throws Exception {
+ CardFiltering.filterByField(testCards, "layout", FilterType.REGEX, "fl[a-z]p");
+
+ assertEquals("Wrong list size.", 1, testCards.size());
+ assertEquals("Callow Jushi", testCards.get(0).name);
+ }
+
+ @Test
+ public void filterByManaCostEquals() throws Exception {
+ CardFiltering.filterByField(testCards, "manaCost", FilterType.EQUALS, "{X}{U}{U}");
+
+ assertEquals("Wrong list size.", 1, testCards.size());
+ assertEquals("Disrupting Shoal", testCards.get(0).name);
+ }
+
+ @Test
+ public void filterByManaCostContains() throws Exception {
+ CardFiltering.filterByField(testCards, "manaCost", FilterType.CONTAINS, "B");
+
+ assertEquals("Wrong list size.", 3, testCards.size());
+ int i = 0;
+ String[] names = {
+ "Coerced Confession",
+ "Nightmare",
+ "Sorin Markov",
+ };
+ for (Card card : testCards) {
+ assertTrue(card.name + " should have been " + names[i] + ", i = " + i, card.name.equals(names[i]));
+ i++;
+ }
+ }
+
+ @Test
+ public void filterByManaCostRegex() throws Exception {
+ CardFiltering.filterByField(testCards, "manaCost", FilterType.REGEX, "(\\{G\\}){8}");
+
+ assertEquals("Wrong list size.", 1, testCards.size());
+ assertEquals("Khalni Hydra", testCards.get(0).name);
+ }
+
+ @Test
+ public void filterByCMCEquals() throws Exception {
+ CardFiltering.filterByField(testCards, "cmc", FilterType.EQUALS, "5");
+
+ assertEquals("Wrong list size.", 1, testCards.size());
+ assertEquals("Coerced Confession", testCards.get(0).name);
+ }
+
+ @Test
+ public void filterByCMCContains() throws Exception {
+ CardFiltering.filterByField(testCards, "cmc", FilterType.CONTAINS, "B");
+
+ assertEquals("Wrong list size.", 3, testCards.size());
+ int i = 0;
+ String[] names = {
+ "Coerced Confession",
+ "Nightmare",
+ "Sorin Markov",
+ };
+ for (Card card : testCards) {
+ assertTrue(card.name + " should have been " + names[i] + ", i = " + i, card.name.equals(names[i]));
+ i++;
+ }
+ }
+
+ @Test
+ public void filterByCMCRegex() throws Exception {
+ CardFiltering.filterByField(testCards, "cmc", FilterType.REGEX, "(\\{G\\}){8}");
+
+ assertEquals("Wrong list size.", 1, testCards.size());
+ assertEquals("Khalni Hydra", testCards.get(0).name);
+ }
+
+ @Test
+ public void filterByType() throws Exception {
+
+ }
+
+ @Test
+ public void filterByRarity() throws Exception {
+
+ }
+
+ @Test
+ public void filterByText() throws Exception {
+
+ }
+
+ @Test
+ public void filterByFlavor() throws Exception {
+
+ }
+
+ @Test
+ public void filterByArtist() throws Exception {
+
+ }
+
+ @Test
+ public void filterByNumber() throws Exception {
+
+ }
+
+ @Test
+ public void filterByPower() throws Exception {
+
+ }
+
+ @Test
+ public void filterByToughness() throws Exception {
+
+ }
+
+ @Test
+ public void filterByLoyalty() throws Exception {
+
+ }
+
+ @Test
+ public void filterByMultiverseID() throws Exception {
+
+ }
+
+ @Test
+ public void filterByImageName() throws Exception {
+
+ }
+
+ @Test
+ public void filterByWatermark() throws Exception {
+
+ }
+
+ @Test
+ public void filterBySetCode() throws Exception {
+
+ }
+
+ @Test
+ public void filterByImageCode() throws Exception {
+
+ }
+}
diff --git a/test/eu/equalparts/cardbase/sorting/CardSortingTest.java b/test/eu/equalparts/cardbase/sorting/CardSortingTest.java
index 64a33b5..4ec0f5e 100644
--- a/test/eu/equalparts/cardbase/sorting/CardSortingTest.java
+++ b/test/eu/equalparts/cardbase/sorting/CardSortingTest.java
@@ -2,11 +2,12 @@ package eu.equalparts.cardbase.sorting;
import static org.junit.Assert.assertTrue;
-import java.util.Collection;
import java.util.List;
import org.junit.BeforeClass;
+import org.junit.Rule;
import org.junit.Test;
+import org.junit.rules.ExpectedException;
import com.fasterxml.jackson.core.type.TypeReference;
import com.fasterxml.jackson.databind.ObjectMapper;
@@ -21,6 +22,9 @@ import eu.equalparts.cardbase.cards.Card;
*/
public class CardSortingTest {
private static List<Card> testCards;
+
+ @Rule
+ public final ExpectedException exception = ExpectedException.none();
@BeforeClass
public static void setUpBeforeClass() throws Exception {
@@ -30,7 +34,7 @@ public class CardSortingTest {
@Test
public void sortByName() throws Exception {
- Collection<Card> sortedCards = CardSorting.sortByField(testCards, "name");
+ CardSorting.sortByField(testCards, "name");
int i = 0;
String[] names = {
"Callow Jushi",
@@ -42,7 +46,7 @@ public class CardSortingTest {
"Sorin Markov",
"Ugin's Construct",
};
- for (Card card : sortedCards) {
+ for (Card card : testCards) {
assertTrue(card.name + " should have been " + names[i] + ", i = " + i, card.name.equals(names[i]));
i++;
}
@@ -50,7 +54,7 @@ public class CardSortingTest {
@Test
public void sortByLayout() throws Exception {
- Collection<Card> sortedCards = CardSorting.sortByField(testCards, "layout");
+ CardSorting.sortByField(testCards, "layout");
int i = 0;
String[] layouts = {
"flip",
@@ -62,7 +66,7 @@ public class CardSortingTest {
"normal",
"normal",
};
- for (Card card : sortedCards) {
+ for (Card card : testCards) {
assertTrue(card.layout + " should have been " + layouts[i] + ", i = " + i, card.layout.equals(layouts[i]));
i++;
}
@@ -70,7 +74,7 @@ public class CardSortingTest {
@Test
public void sortByManaCost() throws Exception {
- Collection<Card> sortedCards = CardSorting.sortByField(testCards, "manaCost");
+ CardSorting.sortByField(testCards, "manaCost");
int i = 0;
String[] costs = {
"{1}{U}{U}",
@@ -82,7 +86,7 @@ public class CardSortingTest {
"{G}{G}{G}{G}{G}{G}{G}{G}",
"{X}{U}{U}",
};
- for (Card card : sortedCards) {
+ for (Card card : testCards) {
assertTrue(card.manaCost + " should have been " + costs[i] + ", i = " + i, card.manaCost.equals(costs[i]));
i++;
}
@@ -90,10 +94,10 @@ public class CardSortingTest {
@Test
public void sortByCMC() throws Exception {
- Collection<Card> sortedCards = CardSorting.sortByField(testCards, "cmc");
+ CardSorting.sortByField(testCards, "cmc");
int i = 0;
Integer[] cmcs = {2, 3, 4, 5, 6, 6, 6, 8};
- for (Card card : sortedCards) {
+ for (Card card : testCards) {
assertTrue(card.cmc + " should have been " + cmcs[i] + ", i = " + i, card.cmc.equals(cmcs[i]));
i++;
}
@@ -101,7 +105,7 @@ public class CardSortingTest {
@Test
public void sortByType() throws Exception {
- Collection<Card> sortedCards = CardSorting.sortByField(testCards, "type");
+ CardSorting.sortByField(testCards, "type");
int i = 0;
String[] types = {
"Artifact Creature ā€” Construct",
@@ -113,7 +117,7 @@ public class CardSortingTest {
"Planeswalker ā€” Sorin",
"Sorcery",
};
- for (Card card : sortedCards) {
+ for (Card card : testCards) {
assertTrue(card.type + " should have been " + types[i] + ", i = " + i, card.type.equals(types[i]));
i++;
}
@@ -121,7 +125,7 @@ public class CardSortingTest {
@Test
public void sortByRarity() throws Exception {
- Collection<Card> sortedCards = CardSorting.sortByField(testCards, "rarity");
+ CardSorting.sortByField(testCards, "rarity");
int i = 0;
String[] rarities = {
"Uncommon",
@@ -133,7 +137,7 @@ public class CardSortingTest {
"Mythic Rare",
"Mythic Rare",
};
- for (Card card : sortedCards) {
+ for (Card card : testCards) {
assertTrue(card.rarity + " should have been " + rarities[i] + ", i = " + i, card.rarity.equals(rarities[i]));
i++;
}
@@ -141,7 +145,7 @@ public class CardSortingTest {
@Test
public void sortByText() throws Exception {
- Collection<Card> sortedCards = CardSorting.sortByField(testCards, "text");
+ CardSorting.sortByField(testCards, "text");
int i = 0;
String[] texts = {
"+2: Sorin Markov deals 2 damage to target creature or player and you gain 2 life.\nāˆ’3: Target opponent's life total becomes 10.\nāˆ’7: You control target player during that player's next turn.",
@@ -153,7 +157,7 @@ public class CardSortingTest {
"Whenever you cast a Spirit or Arcane spell, you may put a ki counter on Callow Jushi.\nAt the beginning of the end step, if there are two or more ki counters on Callow Jushi, you may flip it.",
"You may exile a blue card with converted mana cost X from your hand rather than pay Disrupting Shoal's mana cost.\nCounter target spell if its converted mana cost is X.",
};
- for (Card card : sortedCards) {
+ for (Card card : testCards) {
assertTrue(card.text + " should have been " + texts[i] + ", i = " + i, card.text.equals(texts[i]));
i++;
}
@@ -161,7 +165,7 @@ public class CardSortingTest {
@Test
public void sortByFlavor() throws Exception {
- Collection<Card> sortedCards = CardSorting.sortByField(testCards, "flavor");
+ CardSorting.sortByField(testCards, "flavor");
int i = 0;
String[] flavors = {
"",
@@ -173,7 +177,7 @@ public class CardSortingTest {
"The undisputed master of the mountains of Shiv.",
"While trapping the Eldrazi on Zendikar, Ugin learned little from Sorin, but he gleaned the rudiments of lithomancy from Nahiri.",
};
- for (Card card : sortedCards) {
+ for (Card card : testCards) {
String flavor = card.flavor != null ? card.flavor : "";
assertTrue(flavor + " should have been " + flavors[i] + ", i = " + i, flavor.equals(flavors[i]));
i++;
@@ -182,7 +186,7 @@ public class CardSortingTest {
@Test
public void sortByArtist() throws Exception {
- Collection<Card> sortedCards = CardSorting.sortByField(testCards, "artist");
+ CardSorting.sortByField(testCards, "artist");
int i = 0;
String[] artists = {
"Donato Giancola",
@@ -194,7 +198,7 @@ public class CardSortingTest {
"Tsutomu Kawade",
"Vance Kovacs",
};
- for (Card card : sortedCards) {
+ for (Card card : testCards) {
assertTrue(card.artist + " should have been " + artists[i] + ", i = " + i, card.artist.equals(artists[i]));
i++;
}
@@ -202,7 +206,7 @@ public class CardSortingTest {
@Test
public void sortByNumber() throws Exception {
- Collection<Card> sortedCards = CardSorting.sortByField(testCards, "number");
+ CardSorting.sortByField(testCards, "number");
int i = 0;
String[] numbers = {
"31a",
@@ -214,7 +218,7 @@ public class CardSortingTest {
"276",
"281",
};
- for (Card card : sortedCards) {
+ for (Card card : testCards) {
assertTrue(card.number + " should have been " + numbers[i] + ", i = " + i, card.number.equals(numbers[i]));
i++;
}
@@ -222,7 +226,7 @@ public class CardSortingTest {
@Test
public void sortByPower() throws Exception {
- Collection<Card> sortedCards = CardSorting.sortByField(testCards, "power");
+ CardSorting.sortByField(testCards, "power");
int i = 0;
String[] powers = {
"",
@@ -234,7 +238,7 @@ public class CardSortingTest {
"5",
"8",
};
- for (Card card : sortedCards) {
+ for (Card card : testCards) {
String power = card.power != null ? card.power : "";
assertTrue(power + " should have been " + powers[i] + ", i = " + i, power.equals(powers[i]));
i++;
@@ -243,7 +247,7 @@ public class CardSortingTest {
@Test
public void sortByToughness() throws Exception {
- Collection<Card> sortedCards = CardSorting.sortByField(testCards, "power");
+ CardSorting.sortByField(testCards, "power");
int i = 0;
String[] toughnesses = {
"",
@@ -255,7 +259,7 @@ public class CardSortingTest {
"5",
"8",
};
- for (Card card : sortedCards) {
+ for (Card card : testCards) {
String toughness = card.toughness != null ? card.toughness : "";
assertTrue(toughness + " should have been " + toughnesses[i] + ", i = " + i, toughness.equals(toughnesses[i]));
i++;
@@ -264,10 +268,10 @@ public class CardSortingTest {
@Test
public void sortByLoyalty() throws Exception {
- Collection<Card> sortedCards = CardSorting.sortByField(testCards, "loyalty");
+ CardSorting.sortByField(testCards, "loyalty");
int i = 0;
Integer[] loyalties = {0, 0, 0, 0, 0, 0, 0, 4};
- for (Card card : sortedCards) {
+ for (Card card : testCards) {
Integer loyalty = card.loyalty != null ? card.loyalty : 0;
assertTrue(loyalty + " should have been " + loyalties[i] + ", i = " + i, loyalty.equals(loyalties[i]));
i++;
@@ -276,10 +280,10 @@ public class CardSortingTest {
@Test
public void sortByMultiverseID() throws Exception {
- Collection<Card> sortedCards = CardSorting.sortByField(testCards, "multiverseid");
+ CardSorting.sortByField(testCards, "multiverseid");
int i = 0;
Integer[] ids = {74128, 74489, 193551, 238330, 366408, 383168, 383172, 391949 };
- for (Card card : sortedCards) {
+ for (Card card : testCards) {
Integer id = card.multiverseid != null ? card.multiverseid : 0;
assertTrue(id + " should have been " + ids[i] + ", i = " + i, id.equals(ids[i]));
i++;
@@ -288,7 +292,7 @@ public class CardSortingTest {
@Test
public void sortByImageName() throws Exception {
- Collection<Card> sortedCards = CardSorting.sortByField(testCards, "imageName");
+ CardSorting.sortByField(testCards, "imageName");
int i = 0;
String[] names = {
"callow jushi",
@@ -300,7 +304,7 @@ public class CardSortingTest {
"sorin markov",
"ugin's construct",
};
- for (Card card : sortedCards) {
+ for (Card card : testCards) {
assertTrue(card.imageName + " should have been " + names[i] + ", i = " + i, card.imageName.equals(names[i]));
i++;
}
@@ -308,7 +312,7 @@ public class CardSortingTest {
@Test
public void sortByWatermark() throws Exception {
- Collection<Card> sortedCards = CardSorting.sortByField(testCards, "watermark");
+ CardSorting.sortByField(testCards, "watermark");
int i = 0;
String[] watermarks = {
"",
@@ -320,7 +324,7 @@ public class CardSortingTest {
"",
"Dimir",
};
- for (Card card : sortedCards) {
+ for (Card card : testCards) {
String watermark = card.watermark != null ? card.watermark : "";
assertTrue(watermark + " should have been " + watermarks[i] + ", i = " + i, watermark.equals(watermarks[i]));
i++;
@@ -329,7 +333,7 @@ public class CardSortingTest {
@Test
public void sortBySetCode() throws Exception {
- Collection<Card> sortedCards = CardSorting.sortByField(testCards, "setCode");
+ CardSorting.sortByField(testCards, "setCode");
int i = 0;
String[] sets = {
"BOK",
@@ -341,14 +345,15 @@ public class CardSortingTest {
"M15",
"ROE",
};
- for (Card card : sortedCards) {
+ for (Card card : testCards) {
assertTrue(card.setCode + " should have been " + sets[i] + ", i = " + i, card.setCode.equals(sets[i]));
i++;
}
}
+ @Test
public void sortByImageCode() throws Exception {
- Collection<Card> sortedCards = CardSorting.sortByField(testCards, "imageCode");
+ CardSorting.sortByField(testCards, "imageCode");
int i = 0;
String[] codes = {
"bok",
@@ -360,9 +365,18 @@ public class CardSortingTest {
"m15",
"roe",
};
- for (Card card : sortedCards) {
+ for (Card card : testCards) {
assertTrue(card.imageCode + " should have been " + codes[i] + ", i = " + i, card.imageCode.equals(codes[i]));
i++;
}
}
+
+ /*
+ * Edge cases
+ */
+ @Test
+ public void sortFieldDoesNotExist() throws Exception {
+ exception.expect(NoSuchFieldException.class);
+ CardSorting.sortByField(testCards, "not a field name");
+ }
}