X-Git-Url: http://git.nikiroo.be/?p=nikiroo-utils.git;a=blobdiff_plain;f=src%2Fbe%2Fnikiroo%2Futils%2Ftest%2FStringUtilsTest.java;h=4be75040b9966106beb932b825f60d2e53a8adeb;hp=452b9061185f9838b2145fb74c7e533bb99d0c11;hb=771c4ba4a1c17a95acbfdcbdb489094b04947713;hpb=6a493e0518e4b88cc68f6d4aae1faea08aa3afce diff --git a/src/be/nikiroo/utils/test/StringUtilsTest.java b/src/be/nikiroo/utils/test/StringUtilsTest.java index 452b906..4be7504 100644 --- a/src/be/nikiroo/utils/test/StringUtilsTest.java +++ b/src/be/nikiroo/utils/test/StringUtilsTest.java @@ -1,5 +1,6 @@ package be.nikiroo.utils.test; +import java.util.Arrays; import java.util.Date; import java.util.HashMap; import java.util.List; @@ -142,32 +143,59 @@ class StringUtilsTest extends TestLauncher { addTest(new TestCase("Justifying") { @Override public void test() throws Exception { - for (String data : new String[] { "test", - "let's test some words", "" }) { - int total = 0; - for (String word : data.split((" "))) { - total += word.replace("-", "").replace(" ", "") - .length(); - } - List result = StringUtils.justifyText(data, 5, - StringUtils.Alignment.LEFT); - - System.out.println("["+data+"] -> ["); - - int totalResult = 0; - for (String resultLine : result) { - System.out.println(resultLine); - for (String word : resultLine.split((" "))) { - totalResult += word.replace("-", "") - .replace(" ", "").length(); + Map>>> source = new HashMap>>>(); + addValue(source, Alignment.LEFT, "testy", 5, "testy"); + addValue(source, Alignment.LEFT, "testy", 3, "te-", "sty"); + addValue(source, Alignment.LEFT, + "Un petit texte qui se mettra sur plusieurs lignes", + 10, "Un petit", "texte qui", "se mettra", "sur", + "plusieurs", "lignes"); + addValue(source, Alignment.LEFT, + "Un petit texte qui se mettra sur plusieurs lignes", 7, + "Un", "petit", "texte", "qui se", "mettra", "sur", + "plusie-", "urs", "lignes"); + addValue(source, Alignment.RIGHT, + "Un petit texte qui se mettra sur plusieurs lignes", 7, + " Un", " petit", " texte", " qui se", " mettra", + " sur", "plusie-", " urs", " lignes"); + addValue(source, Alignment.CENTER, + "Un petit texte qui se mettra sur plusieurs lignes", 7, + " Un ", " petit ", " texte ", "qui se ", "mettra ", + " sur ", "plusie-", " urs ", "lignes "); + addValue(source, Alignment.JUSTIFY, + "Un petit texte qui se mettra sur plusieurs lignes", 7, + "Un", "petit", "texte", "qui se", "mettra", "sur", + "plusie-", "urs", "lignes"); + addValue(source, Alignment.JUSTIFY, + "Un petit texte qui se mettra sur plusieurs lignes", + 14, "Un petit", "texte qui se", + "mettra sur", "plusieurs lig-", "nes"); + + System.out.println(); + for (String data : source.keySet()) { + for (int size : source.get(data).keySet()) { + Alignment align = source.get(data).get(size).getKey(); + List values = source.get(data).get(size) + .getValue(); + + List result = StringUtils.justifyText(data, + size, align); + + System.out.println("[" + data + " (" + size + ")" + + "] -> ["); + for (int i = 0; i < result.size(); i++) { + String resultLine = result.get(i); + System.out.println(i + ": " + resultLine); } - } - System.out.println("]"); + System.out.println("]"); - assertEquals( - "The number of letters ('-' not included) should be identical before and after", - total, totalResult); + for (int i = 0; i < result.size() && i < values.size(); i++) { + assertEquals("The line " + i + " is not correct", + values.get(i), result.get(i)); + } + } } + System.out.println(); } }); @@ -200,4 +228,31 @@ class StringUtilsTest extends TestLauncher { } }); } + + static private void addValue( + Map>>> source, + final Alignment align, String input, int size, + final String... result) { + if (!source.containsKey(input)) { + source.put(input, + new HashMap>>()); + } + + source.get(input).put(size, new Entry>() { + @Override + public Alignment getKey() { + return align; + } + + @Override + public List getValue() { + return Arrays.asList(result); + } + + @Override + public List setValue(List value) { + return null; + } + }); + } }