123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328 |
- using Terminal.Gui.Graphs;
- using Xunit;
- using Xunit.Abstractions;
- namespace Terminal.Gui.CoreTests {
- public class LineCanvasTests {
- readonly ITestOutputHelper output;
- public LineCanvasTests (ITestOutputHelper output)
- {
- this.output = output;
- }
- [Fact, AutoInitShutdown]
- public void TestLineCanvas_Dot ()
- {
- var v = GetCanvas (out var canvas);
- canvas.AddLine (new Point (0, 0), 0, Orientation.Horizontal, BorderStyle.Single);
- v.Redraw (v.Bounds);
- string looksLike =
- @"
- .";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- }
- [InlineData (BorderStyle.Single)]
- [InlineData (BorderStyle.Rounded)]
- [Theory, AutoInitShutdown]
- public void TestLineCanvas_Horizontal (BorderStyle style)
- {
- var v = GetCanvas (out var canvas);
- canvas.AddLine (new Point (0, 0), 1, Orientation.Horizontal, style);
- v.Redraw (v.Bounds);
- string looksLike =
- @"
- ──";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- }
- [Fact, AutoInitShutdown]
- public void TestLineCanvas_Horizontal_Double ()
- {
- var v = GetCanvas (out var canvas);
- canvas.AddLine (new Point (0, 0), 1, Orientation.Horizontal, BorderStyle.Double);
- v.Redraw (v.Bounds);
- string looksLike =
- @"
- ══";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- }
- [InlineData (BorderStyle.Single)]
- [InlineData (BorderStyle.Rounded)]
- [Theory, AutoInitShutdown]
- public void TestLineCanvas_Vertical (BorderStyle style)
- {
- var v = GetCanvas (out var canvas);
- canvas.AddLine (new Point (0, 0), 1, Orientation.Vertical, style);
- v.Redraw (v.Bounds);
- string looksLike =
- @"
- │
- │";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- }
- [Fact, AutoInitShutdown]
- public void TestLineCanvas_Vertical_Double ()
- {
- var v = GetCanvas (out var canvas);
- canvas.AddLine (new Point (0, 0), 1, Orientation.Vertical, BorderStyle.Double);
- v.Redraw (v.Bounds);
- string looksLike =
- @"
- ║
- ║";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- }
- /// <summary>
- /// This test demonstrates that corners are only drawn when lines overlap.
- /// Not when they terminate adjacent to one another.
- /// </summary>
- [Fact, AutoInitShutdown]
- public void TestLineCanvas_Corner_NoOverlap ()
- {
- var v = GetCanvas (out var canvas);
- canvas.AddLine (new Point (0, 0), 1, Orientation.Horizontal, BorderStyle.Single);
- canvas.AddLine (new Point (0, 1), 1, Orientation.Vertical, BorderStyle.Single);
- v.Redraw (v.Bounds);
- string looksLike =
- @"
- ──
- │
- │";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- }
- /// <summary>
- /// This test demonstrates how to correctly trigger a corner. By
- /// overlapping the lines in the same cell
- /// </summary>
- [Fact, AutoInitShutdown]
- public void TestLineCanvas_Corner_Correct ()
- {
- var v = GetCanvas (out var canvas);
- canvas.AddLine (new Point (0, 0), 1, Orientation.Horizontal, BorderStyle.Single);
- canvas.AddLine (new Point (0, 0), 2, Orientation.Vertical, BorderStyle.Single);
- v.Redraw (v.Bounds);
- string looksLike =
- @"
- ┌─
- │
- │";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- }
- [Fact, AutoInitShutdown]
- public void TestLineCanvas_Window ()
- {
- var v = GetCanvas (out var canvas);
- // outer box
- canvas.AddLine (new Point (0, 0), 9, Orientation.Horizontal, BorderStyle.Single);
- canvas.AddLine (new Point (9, 0), 4, Orientation.Vertical, BorderStyle.Single);
- canvas.AddLine (new Point (9, 4), -9, Orientation.Horizontal, BorderStyle.Single);
- canvas.AddLine (new Point (0, 4), -4, Orientation.Vertical, BorderStyle.Single);
- canvas.AddLine (new Point (5, 0), 4, Orientation.Vertical, BorderStyle.Single);
- canvas.AddLine (new Point (0, 2), 9, Orientation.Horizontal, BorderStyle.Single);
- v.Redraw (v.Bounds);
- string looksLike =
- @"
- ┌────┬───┐
- │ │ │
- ├────┼───┤
- │ │ │
- └────┴───┘";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- }
- [Fact, AutoInitShutdown]
- public void TestLineCanvas_PositiveLocation ()
- {
- var x = 1;
- var y = 1;
- var v = GetCanvas (out var canvas, x, y);
- // outer box
- canvas.AddLine (new Point (x, y), 9, Orientation.Horizontal, BorderStyle.Single);
- canvas.AddLine (new Point (x + 9, y + 0), 4, Orientation.Vertical, BorderStyle.Single);
- canvas.AddLine (new Point (x + 9, y + 4), -9, Orientation.Horizontal, BorderStyle.Single);
- canvas.AddLine (new Point (x + 0, y + 4), -4, Orientation.Vertical, BorderStyle.Single);
- canvas.AddLine (new Point (x + 5, y + 0), 4, Orientation.Vertical, BorderStyle.Single);
- canvas.AddLine (new Point (x + 0, y + 2), 9, Orientation.Horizontal, BorderStyle.Single);
- v.Redraw (v.Bounds);
- string looksLike =
- @"
- ┌────┬───┐
- │ │ │
- ├────┼───┤
- │ │ │
- └────┴───┘";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- }
- /// <summary>
- /// Demonstrates when <see cref="BorderStyle.Rounded"/> corners are used. Notice how
- /// not all lines declare rounded. If there are 1+ lines intersecting and a corner is
- /// to be used then if any of them are rounded a rounded corner is used.
- /// </summary>
- [Fact, AutoInitShutdown]
- public void TestLineCanvas_Window_Rounded ()
- {
- var v = GetCanvas (out var canvas);
- // outer box
- canvas.AddLine (new Point (0, 0), 9, Orientation.Horizontal, BorderStyle.Rounded);
- // BorderStyle.Single is ignored because corner overlaps with the above line which is Rounded
- // this results in a rounded corner being used.
- canvas.AddLine (new Point (9, 0), 4, Orientation.Vertical, BorderStyle.Single);
- canvas.AddLine (new Point (9, 4), -9, Orientation.Horizontal, BorderStyle.Rounded);
- canvas.AddLine (new Point (0, 4), -4, Orientation.Vertical, BorderStyle.Single);
- // These lines say rounded but they will result in the T sections which are never rounded.
- canvas.AddLine (new Point (5, 0), 4, Orientation.Vertical, BorderStyle.Rounded);
- canvas.AddLine (new Point (0, 2), 9, Orientation.Horizontal, BorderStyle.Rounded);
- v.Redraw (v.Bounds);
- string looksLike =
- @"
- ╭────┬───╮
- │ │ │
- ├────┼───┤
- │ │ │
- ╰────┴───╯";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- }
- [Fact, AutoInitShutdown]
- public void TestLineCanvas_Window_Double ()
- {
- var v = GetCanvas (out var canvas);
- // outer box
- canvas.AddLine (new Point (0, 0), 9, Orientation.Horizontal, BorderStyle.Double);
- canvas.AddLine (new Point (9, 0), 4, Orientation.Vertical, BorderStyle.Double);
- canvas.AddLine (new Point (9, 4), -9, Orientation.Horizontal, BorderStyle.Double);
- canvas.AddLine (new Point (0, 4), -4, Orientation.Vertical, BorderStyle.Double);
- canvas.AddLine (new Point (5, 0), 4, Orientation.Vertical, BorderStyle.Double);
- canvas.AddLine (new Point (0, 2), 9, Orientation.Horizontal, BorderStyle.Double);
- v.Redraw (v.Bounds);
- string looksLike =
- @"
- ╔════╦═══╗
- ║ ║ ║
- ╠════╬═══╣
- ║ ║ ║
- ╚════╩═══╝";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- }
- [Theory, AutoInitShutdown]
- [InlineData (BorderStyle.Single)]
- [InlineData (BorderStyle.Rounded)]
- public void TestLineCanvas_Window_DoubleTop_SingleSides (BorderStyle thinStyle)
- {
- var v = GetCanvas (out var canvas);
- // outer box
- canvas.AddLine (new Point (0, 0), 9, Orientation.Horizontal, BorderStyle.Double);
- canvas.AddLine (new Point (9, 0), 4, Orientation.Vertical, thinStyle);
- canvas.AddLine (new Point (9, 4), -9, Orientation.Horizontal, BorderStyle.Double);
- canvas.AddLine (new Point (0, 4), -4, Orientation.Vertical, thinStyle);
- canvas.AddLine (new Point (5, 0), 4, Orientation.Vertical, thinStyle);
- canvas.AddLine (new Point (0, 2), 9, Orientation.Horizontal, BorderStyle.Double);
- v.Redraw (v.Bounds);
- string looksLike =
- @"
- ╒════╤═══╕
- │ │ │
- ╞════╪═══╡
- │ │ │
- ╘════╧═══╛
- ";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- }
- [Theory, AutoInitShutdown]
- [InlineData (BorderStyle.Single)]
- [InlineData (BorderStyle.Rounded)]
- public void TestLineCanvas_Window_SingleTop_DoubleSides (BorderStyle thinStyle)
- {
- var v = GetCanvas (out var canvas);
- // outer box
- canvas.AddLine (new Point (0, 0), 9, Orientation.Horizontal, thinStyle);
- canvas.AddLine (new Point (9, 0), 4, Orientation.Vertical, BorderStyle.Double);
- canvas.AddLine (new Point (9, 4), -9, Orientation.Horizontal, thinStyle);
- canvas.AddLine (new Point (0, 4), -4, Orientation.Vertical, BorderStyle.Double);
- canvas.AddLine (new Point (5, 0), 4, Orientation.Vertical, BorderStyle.Double);
- canvas.AddLine (new Point (0, 2), 9, Orientation.Horizontal, thinStyle);
- v.Redraw (v.Bounds);
- string looksLike =
- @"
- ╓────╥───╖
- ║ ║ ║
- ╟────╫───╢
- ║ ║ ║
- ╙────╨───╜
- ";
- TestHelpers.AssertDriverContentsAre (looksLike, output);
- }
- private View GetCanvas (out LineCanvas canvas, int x = 0, int y = 0)
- {
- var v = new View {
- Width = 10,
- Height = 5,
- Bounds = new Rect (x, y, 10, 5)
- };
- var canvasCopy = canvas = new LineCanvas ();
- v.DrawContentComplete += (r) => canvasCopy.Draw (v, v.Bounds);
- return v;
- }
- }
- }
|