From 2d58712047d19f5b18c283fa6a339c1b4c91df96 Mon Sep 17 00:00:00 2001 From: Paul Campbell Date: Fri, 22 May 2020 19:56:21 +0100 Subject: [PATCH] BoxFit: when using box list API behaves the same when suppling a single box --- .../net/kemitix/text/fit/BoxFitterTest.java | 57 +++++++++++++------ 1 file changed, 40 insertions(+), 17 deletions(-) diff --git a/src/test/java/net/kemitix/text/fit/BoxFitterTest.java b/src/test/java/net/kemitix/text/fit/BoxFitterTest.java index a0ea8e7..b209b12 100644 --- a/src/test/java/net/kemitix/text/fit/BoxFitterTest.java +++ b/src/test/java/net/kemitix/text/fit/BoxFitterTest.java @@ -34,14 +34,23 @@ public class BoxFitterTest fontFactory = size -> font.deriveFont(Font.PLAIN, size); } + interface FitTests { + int fit(String text); + } + @Nested - @DisplayName("Single Box") - public class SingleBox { + @DisplayName("Single Box API") + public class SingleBoxAPI implements FitTests { private final int imageSize = 300; private final Graphics2D graphics2D = graphics(imageSize, imageSize); private Rectangle2D box = new Rectangle(imageSize, imageSize); + @Override + public int fit(String longText) { + return boxFitter.fit(longText, fontFactory, graphics2D, box); + } + @Test @DisplayName("Fit single words") public void fitSingleWord() { @@ -95,32 +104,46 @@ public class BoxFitterTest assertThatCode(() -> fit(longText)) .doesNotThrowAnyException(); } - - private int fit(String longText) { - return boxFitter.fit(longText, fontFactory, graphics2D, box); - } } @Nested - @DisplayName("Overflow boxes") - public class OverflowBoxes { + @DisplayName("List of Boxes API") + public class BoxListAPI { private final int imageSize = 300; private final Graphics2D graphics2D = graphics(imageSize, imageSize); private Rectangle2D box = new Rectangle(imageSize, imageSize); private List boxes = Arrays.asList(box, box); - private int fit(String longText) { - return boxFitter.fit(longText, fontFactory, graphics2D, boxes); + @Nested + @DisplayName("Single Box") + // different API, but should have same behaviour as using single box API + public class SingleBox extends SingleBoxAPI { + + @Override + public int fit(String longText) { + return boxFitter.fit(longText, fontFactory, graphics2D, boxes); + } + } - @Test - @DisplayName("Text too long to fit single box - fits into two") - public void tooLongThrows() { - String longText = longStringGenerator(197); - //TODO: should overflow into second box - assertThatExceptionOfType(IllegalArgumentException.class) - .isThrownBy(() -> fit(longText)); + @Nested + @DisplayName("Two Boxes") + public class TwoBoxes implements FitTests{ + @Override + public int fit(String longText) { + return boxFitter.fit(longText, fontFactory, graphics2D, boxes); + } + + @Test + @DisplayName("Text too long to fit single box - fits into two") + public void tooLongThrows() { + String longText = longStringGenerator(197); + //TODO: should overflow into second box + assertThatExceptionOfType(IllegalArgumentException.class) + .isThrownBy(() -> fit(longText)); + } + } }