1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036 |
- using System;
- using System.Collections.Generic;
- using System.ComponentModel;
- using System.Data;
- using System.IO;
- using System.Linq;
- using Terminal.Gui;
- using Terminal.Gui.Views;
- using Xunit;
- using Xunit.Abstractions;
- // Alias Console to MockConsole so we don't accidentally use Console
- using Console = Terminal.Gui.FakeConsole;
- namespace Terminal.Gui.Core {
- public class PosTests {
- readonly ITestOutputHelper output;
- public PosTests (ITestOutputHelper output)
- {
- this.output = output;
- }
- [Fact]
- public void New_Works ()
- {
- var pos = new Pos ();
- Assert.Equal ("Terminal.Gui.Pos", pos.ToString ());
- }
- [Fact]
- public void AnchorEnd_SetsValue ()
- {
- var n = 0;
- var pos = Pos.AnchorEnd ();
- Assert.Equal ($"Pos.AnchorEnd(margin={n})", pos.ToString ());
- n = 5;
- pos = Pos.AnchorEnd (n);
- Assert.Equal ($"Pos.AnchorEnd(margin={n})", pos.ToString ());
- }
- [Fact]
- public void AnchorEnd_Equal ()
- {
- var n1 = 0;
- var n2 = 0;
- var pos1 = Pos.AnchorEnd (n1);
- var pos2 = Pos.AnchorEnd (n2);
- Assert.Equal (pos1, pos2);
- // Test inequality
- n2 = 5;
- pos2 = Pos.AnchorEnd (n2);
- Assert.NotEqual (pos1, pos2);
- }
- [Fact]
- [AutoInitShutdown]
- public void AnchorEnd_Equal_Inside_Window ()
- {
- var viewWidth = 10;
- var viewHeight = 1;
- var tv = new TextView () {
- X = Pos.AnchorEnd (viewWidth),
- Y = Pos.AnchorEnd (viewHeight),
- Width = viewWidth,
- Height = viewHeight
- };
- var win = new Window ();
- win.Add (tv);
- var top = Application.Top;
- top.Add (win);
- Application.Begin (top);
- Assert.Equal (new Rect (0, 0, 80, 25), top.Frame);
- Assert.Equal (new Rect (0, 0, 80, 25), win.Frame);
- Assert.Equal (new Rect (1, 1, 78, 23), win.Subviews [0].Frame);
- Assert.Equal ("ContentView()({X=1,Y=1,Width=78,Height=23})", win.Subviews [0].ToString ());
- Assert.Equal (new Rect (1, 1, 79, 24), new Rect (
- win.Subviews [0].Frame.Left, win.Subviews [0].Frame.Top,
- win.Subviews [0].Frame.Right, win.Subviews [0].Frame.Bottom));
- Assert.Equal (new Rect (68, 22, 10, 1), tv.Frame);
- }
- [Fact]
- [AutoInitShutdown]
- public void AnchorEnd_Equal_Inside_Window_With_MenuBar_And_StatusBar_On_Toplevel ()
- {
- var viewWidth = 10;
- var viewHeight = 1;
- var tv = new TextView () {
- X = Pos.AnchorEnd (viewWidth),
- Y = Pos.AnchorEnd (viewHeight),
- Width = viewWidth,
- Height = viewHeight
- };
- var win = new Window ();
- win.Add (tv);
- var menu = new MenuBar ();
- var status = new StatusBar ();
- var top = Application.Top;
- top.Add (win, menu, status);
- Application.Begin (top);
- Assert.Equal (new Rect (0, 0, 80, 25), top.Frame);
- Assert.Equal (new Rect (0, 0, 80, 1), menu.Frame);
- Assert.Equal (new Rect (0, 24, 80, 1), status.Frame);
- Assert.Equal (new Rect (0, 1, 80, 23), win.Frame);
- Assert.Equal (new Rect (1, 1, 78, 21), win.Subviews [0].Frame);
- Assert.Equal (new Rect (1, 1, 79, 22), new Rect (
- win.Subviews [0].Frame.Left, win.Subviews [0].Frame.Top,
- win.Subviews [0].Frame.Right, win.Subviews [0].Frame.Bottom));
- Assert.Equal (new Rect (68, 20, 10, 1), tv.Frame);
- }
- [Fact]
- [AutoInitShutdown]
- public void Bottom_Equal_Inside_Window ()
- {
- var win = new Window ();
- var label = new Label ("This should be the last line.") {
- TextAlignment = Terminal.Gui.TextAlignment.Centered,
- ColorScheme = Colors.Menu,
- Width = Dim.Fill (),
- X = Pos.Center (),
- Y = Pos.Bottom (win) - 3 // two lines top and bottom borders more one line above the bottom border
- };
- win.Add (label);
- var top = Application.Top;
- top.Add (win);
- Application.Begin (top);
- ((FakeDriver)Application.Driver).SetBufferSize (40, 10);
- Assert.True (label.AutoSize);
- Assert.Equal (new Rect (0, 0, 40, 10), top.Frame);
- Assert.Equal (new Rect (0, 0, 40, 10), win.Frame);
- Assert.Equal (new Rect (1, 1, 38, 8), win.Subviews [0].Frame);
- Assert.Equal ("ContentView()({X=1,Y=1,Width=38,Height=8})", win.Subviews [0].ToString ());
- Assert.Equal (new Rect (0, 0, 40, 10), new Rect (
- win.Frame.Left, win.Frame.Top,
- win.Frame.Right, win.Frame.Bottom));
- Assert.Equal (new Rect (0, 7, 38, 1), label.Frame);
- var expected = @"
- ┌──────────────────────────────────────┐
- │ │
- │ │
- │ │
- │ │
- │ │
- │ │
- │ │
- │ This should be the last line. │
- └──────────────────────────────────────┘
- ";
- GraphViewTests.AssertDriverContentsWithFrameAre (expected, output);
- }
- [Fact]
- [AutoInitShutdown]
- public void AnchorEnd_Better_Than_Bottom_Equal_Inside_Window ()
- {
- var win = new Window ();
- var label = new Label ("This should be the last line.") {
- TextAlignment = Terminal.Gui.TextAlignment.Centered,
- ColorScheme = Colors.Menu,
- Width = Dim.Fill (),
- X = Pos.Center (),
- Y = Pos.AnchorEnd (1)
- };
- win.Add (label);
- var top = Application.Top;
- top.Add (win);
- Application.Begin (top);
- ((FakeDriver)Application.Driver).SetBufferSize (40, 10);
- Assert.True (label.AutoSize);
- Assert.Equal (29, label.Text.Length);
- Assert.Equal (new Rect (0, 0, 40, 10), top.Frame);
- Assert.Equal (new Rect (0, 0, 40, 10), win.Frame);
- Assert.Equal (new Rect (1, 1, 38, 8), win.Subviews [0].Frame);
- Assert.Equal ("ContentView()({X=1,Y=1,Width=38,Height=8})", win.Subviews [0].ToString ());
- Assert.Equal (new Rect (0, 0, 40, 10), new Rect (
- win.Frame.Left, win.Frame.Top,
- win.Frame.Right, win.Frame.Bottom));
- Assert.Equal (new Rect (0, 7, 38, 1), label.Frame);
- var expected = @"
- ┌──────────────────────────────────────┐
- │ │
- │ │
- │ │
- │ │
- │ │
- │ │
- │ │
- │ This should be the last line. │
- └──────────────────────────────────────┘
- ";
- GraphViewTests.AssertDriverContentsWithFrameAre (expected, output);
- }
- [Fact]
- [AutoInitShutdown]
- public void Bottom_Equal_Inside_Window_With_MenuBar_And_StatusBar_On_Toplevel ()
- {
- var win = new Window ();
- var label = new Label ("This should be the last line.") {
- TextAlignment = Terminal.Gui.TextAlignment.Centered,
- ColorScheme = Colors.Menu,
- Width = Dim.Fill (),
- X = Pos.Center (),
- Y = Pos.Bottom (win) - 4 // two lines top and bottom borders more two lines above border
- };
- win.Add (label);
- var menu = new MenuBar (new MenuBarItem [] { new ("Menu", "", null) });
- var status = new StatusBar (new StatusItem [] { new (Key.F1, "~F1~ Help", null) });
- var top = Application.Top;
- top.Add (win, menu, status);
- Application.Begin (top);
- Assert.True (label.AutoSize);
- Assert.Equal (new Rect (0, 0, 80, 25), top.Frame);
- Assert.Equal (new Rect (0, 0, 80, 1), menu.Frame);
- Assert.Equal (new Rect (0, 24, 80, 1), status.Frame);
- Assert.Equal (new Rect (0, 1, 80, 23), win.Frame);
- Assert.Equal (new Rect (1, 1, 78, 21), win.Subviews [0].Frame);
- Assert.Equal (new Rect (0, 1, 80, 24), new Rect (
- win.Frame.Left, win.Frame.Top,
- win.Frame.Right, win.Frame.Bottom));
- Assert.Equal (new Rect (0, 20, 78, 1), label.Frame);
- var expected = @"
- Menu
- ┌──────────────────────────────────────────────────────────────────────────────┐
- │ │
- │ │
- │ │
- │ │
- │ │
- │ │
- │ │
- │ │
- │ │
- │ │
- │ │
- │ │
- │ │
- │ │
- │ │
- │ │
- │ │
- │ │
- │ │
- │ │
- │ This should be the last line. │
- └──────────────────────────────────────────────────────────────────────────────┘
- F1 Help
- ";
- GraphViewTests.AssertDriverContentsWithFrameAre (expected, output);
- }
- [Fact]
- [AutoInitShutdown]
- public void AnchorEnd_Better_Than_Bottom_Equal_Inside_Window_With_MenuBar_And_StatusBar_On_Toplevel ()
- {
- var win = new Window ();
- var label = new Label ("This should be the last line.") {
- TextAlignment = Terminal.Gui.TextAlignment.Centered,
- ColorScheme = Colors.Menu,
- Width = Dim.Fill (),
- X = Pos.Center (),
- Y = Pos.AnchorEnd (1)
- };
- win.Add (label);
- var menu = new MenuBar (new MenuBarItem [] { new ("Menu", "", null) });
- var status = new StatusBar (new StatusItem [] { new (Key.F1, "~F1~ Help", null) });
- var top = Application.Top;
- top.Add (win, menu, status);
- Application.Begin (top);
- Assert.True (label.AutoSize);
- Assert.Equal (new Rect (0, 0, 80, 25), top.Frame);
- Assert.Equal (new Rect (0, 0, 80, 1), menu.Frame);
- Assert.Equal (new Rect (0, 24, 80, 1), status.Frame);
- Assert.Equal (new Rect (0, 1, 80, 23), win.Frame);
- Assert.Equal (new Rect (1, 1, 78, 21), win.Subviews [0].Frame);
- Assert.Equal (new Rect (0, 1, 80, 24), new Rect (
- win.Frame.Left, win.Frame.Top,
- win.Frame.Right, win.Frame.Bottom));
- Assert.Equal (new Rect (0, 20, 78, 1), label.Frame);
- var expected = @"
- Menu
- ┌──────────────────────────────────────────────────────────────────────────────┐
- │ │
- │ │
- │ │
- │ │
- │ │
- │ │
- │ │
- │ │
- │ │
- │ │
- │ │
- │ │
- │ │
- │ │
- │ │
- │ │
- │ │
- │ │
- │ │
- │ │
- │ This should be the last line. │
- └──────────────────────────────────────────────────────────────────────────────┘
- F1 Help
- ";
- GraphViewTests.AssertDriverContentsWithFrameAre (expected, output);
- }
- [Fact]
- public void AnchorEnd_Negative_Throws ()
- {
- Pos pos;
- var n = -1;
- Assert.Throws<ArgumentException> (() => pos = Pos.AnchorEnd (n));
- }
- [Fact]
- public void At_SetsValue ()
- {
- var pos = Pos.At (0);
- Assert.Equal ("Pos.Absolute(0)", pos.ToString ());
- pos = Pos.At (5);
- Assert.Equal ("Pos.Absolute(5)", pos.ToString ());
- pos = Pos.At (-1);
- Assert.Equal ("Pos.Absolute(-1)", pos.ToString ());
- }
- [Fact]
- public void At_Equal ()
- {
- var n1 = 0;
- var n2 = 0;
- var pos1 = Pos.At (n1);
- var pos2 = Pos.At (n2);
- Assert.Equal (pos1, pos2);
- }
- [Fact]
- public void SetSide_Null_Throws ()
- {
- var pos = Pos.Left (null);
- Assert.Throws<NullReferenceException> (() => pos.ToString ());
- pos = Pos.X (null);
- Assert.Throws<NullReferenceException> (() => pos.ToString ());
- pos = Pos.Top (null);
- Assert.Throws<NullReferenceException> (() => pos.ToString ());
- pos = Pos.Y (null);
- Assert.Throws<NullReferenceException> (() => pos.ToString ());
- pos = Pos.Bottom (null);
- Assert.Throws<NullReferenceException> (() => pos.ToString ());
- pos = Pos.Right (null);
- Assert.Throws<NullReferenceException> (() => pos.ToString ());
- }
- // TODO: Test Left, Top, Right bottom Equal
- /// <summary>
- /// Tests Pos.Left, Pos.X, Pos.Top, Pos.Y, Pos.Right, and Pos.Bottom set operations
- /// </summary>
- [Fact]
- public void PosSide_SetsValue ()
- {
- string side; // used in format string
- var testRect = Rect.Empty;
- var testInt = 0;
- Pos pos;
- // Pos.Left
- side = "x";
- testInt = 0;
- testRect = Rect.Empty;
- pos = Pos.Left (new View ());
- Assert.Equal ($"Pos.Combine(Pos.View(side={side}, target=View()({{X={testRect.X},Y={testRect.Y},Width={testRect.Width},Height={testRect.Height}}})){(testInt < 0 ? '-' : '+')}Pos.Absolute({testInt}))", pos.ToString ());
- pos = Pos.Left (new View (testRect));
- Assert.Equal ($"Pos.Combine(Pos.View(side={side}, target=View()({{X={testRect.X},Y={testRect.Y},Width={testRect.Width},Height={testRect.Height}}})){(testInt < 0 ? '-' : '+')}Pos.Absolute({testInt}))", pos.ToString ());
- testRect = new Rect (1, 2, 3, 4);
- pos = Pos.Left (new View (testRect));
- Assert.Equal ($"Pos.Combine(Pos.View(side={side}, target=View()({{X={testRect.X},Y={testRect.Y},Width={testRect.Width},Height={testRect.Height}}})){(testInt < 0 ? '-' : '+')}Pos.Absolute({testInt}))", pos.ToString ());
- // Pos.Left(win) + 0
- pos = Pos.Left (new View (testRect)) + testInt;
- Assert.Equal ($"Pos.Combine(Pos.Combine(Pos.View(side={side}, target=View()({{X={testRect.X},Y={testRect.Y},Width={testRect.Width},Height={testRect.Height}}}))+Pos.Absolute(0)){(testInt < 0 ? '-' : '+')}Pos.Absolute({testInt}))", pos.ToString ());
- testInt = 1;
- // Pos.Left(win) +1
- pos = Pos.Left (new View (testRect)) + testInt;
- Assert.Equal ($"Pos.Combine(Pos.Combine(Pos.View(side={side}, target=View()({{X={testRect.X},Y={testRect.Y},Width={testRect.Width},Height={testRect.Height}}}))+Pos.Absolute(0)){(testInt < 0 ? '-' : '+')}Pos.Absolute({testInt}))", pos.ToString ());
- testInt = -1;
- // Pos.Left(win) -1
- pos = Pos.Left (new View (testRect)) - testInt;
- Assert.Equal ($"Pos.Combine(Pos.Combine(Pos.View(side={side}, target=View()({{X={testRect.X},Y={testRect.Y},Width={testRect.Width},Height={testRect.Height}}}))+Pos.Absolute(0)){(testInt < 0 ? '-' : '+')}Pos.Absolute({testInt}))", pos.ToString ());
- // Pos.X
- side = "x";
- testInt = 0;
- testRect = Rect.Empty;
- pos = Pos.X (new View ());
- Assert.Equal ($"Pos.Combine(Pos.View(side={side}, target=View()({{X={testRect.X},Y={testRect.Y},Width={testRect.Width},Height={testRect.Height}}})){(testInt < 0 ? '-' : '+')}Pos.Absolute({testInt}))", pos.ToString ());
- pos = Pos.X (new View (testRect));
- Assert.Equal ($"Pos.Combine(Pos.View(side={side}, target=View()({{X={testRect.X},Y={testRect.Y},Width={testRect.Width},Height={testRect.Height}}})){(testInt < 0 ? '-' : '+')}Pos.Absolute({testInt}))", pos.ToString ());
- testRect = new Rect (1, 2, 3, 4);
- pos = Pos.X (new View (testRect));
- Assert.Equal ($"Pos.Combine(Pos.View(side={side}, target=View()({{X={testRect.X},Y={testRect.Y},Width={testRect.Width},Height={testRect.Height}}})){(testInt < 0 ? '-' : '+')}Pos.Absolute({testInt}))", pos.ToString ());
- // Pos.X(win) + 0
- pos = Pos.X (new View (testRect)) + testInt;
- Assert.Equal ($"Pos.Combine(Pos.Combine(Pos.View(side={side}, target=View()({{X={testRect.X},Y={testRect.Y},Width={testRect.Width},Height={testRect.Height}}}))+Pos.Absolute(0)){(testInt < 0 ? '-' : '+')}Pos.Absolute({testInt}))", pos.ToString ());
- testInt = 1;
- // Pos.X(win) +1
- pos = Pos.X (new View (testRect)) + testInt;
- Assert.Equal ($"Pos.Combine(Pos.Combine(Pos.View(side={side}, target=View()({{X={testRect.X},Y={testRect.Y},Width={testRect.Width},Height={testRect.Height}}}))+Pos.Absolute(0)){(testInt < 0 ? '-' : '+')}Pos.Absolute({testInt}))", pos.ToString ());
- testInt = -1;
- // Pos.X(win) -1
- pos = Pos.X (new View (testRect)) - testInt;
- Assert.Equal ($"Pos.Combine(Pos.Combine(Pos.View(side={side}, target=View()({{X={testRect.X},Y={testRect.Y},Width={testRect.Width},Height={testRect.Height}}}))+Pos.Absolute(0)){(testInt < 0 ? '-' : '+')}Pos.Absolute({testInt}))", pos.ToString ());
- // Pos.Top
- side = "y";
- testInt = 0;
- testRect = Rect.Empty;
- pos = Pos.Top (new View ());
- Assert.Equal ($"Pos.Combine(Pos.View(side={side}, target=View()({{X={testRect.X},Y={testRect.Y},Width={testRect.Width},Height={testRect.Height}}})){(testInt < 0 ? '-' : '+')}Pos.Absolute({testInt}))", pos.ToString ());
- pos = Pos.Top (new View (testRect));
- Assert.Equal ($"Pos.Combine(Pos.View(side={side}, target=View()({{X={testRect.X},Y={testRect.Y},Width={testRect.Width},Height={testRect.Height}}})){(testInt < 0 ? '-' : '+')}Pos.Absolute({testInt}))", pos.ToString ());
- testRect = new Rect (1, 2, 3, 4);
- pos = Pos.Top (new View (testRect));
- Assert.Equal ($"Pos.Combine(Pos.View(side={side}, target=View()({{X={testRect.X},Y={testRect.Y},Width={testRect.Width},Height={testRect.Height}}})){(testInt < 0 ? '-' : '+')}Pos.Absolute({testInt}))", pos.ToString ());
- // Pos.Top(win) + 0
- pos = Pos.Top (new View (testRect)) + testInt;
- Assert.Equal ($"Pos.Combine(Pos.Combine(Pos.View(side={side}, target=View()({{X={testRect.X},Y={testRect.Y},Width={testRect.Width},Height={testRect.Height}}}))+Pos.Absolute(0)){(testInt < 0 ? '-' : '+')}Pos.Absolute({testInt}))", pos.ToString ());
- testInt = 1;
- // Pos.Top(win) +1
- pos = Pos.Top (new View (testRect)) + testInt;
- Assert.Equal ($"Pos.Combine(Pos.Combine(Pos.View(side={side}, target=View()({{X={testRect.X},Y={testRect.Y},Width={testRect.Width},Height={testRect.Height}}}))+Pos.Absolute(0)){(testInt < 0 ? '-' : '+')}Pos.Absolute({testInt}))", pos.ToString ());
- testInt = -1;
- // Pos.Top(win) -1
- pos = Pos.Top (new View (testRect)) - testInt;
- Assert.Equal ($"Pos.Combine(Pos.Combine(Pos.View(side={side}, target=View()({{X={testRect.X},Y={testRect.Y},Width={testRect.Width},Height={testRect.Height}}}))+Pos.Absolute(0)){(testInt < 0 ? '-' : '+')}Pos.Absolute({testInt}))", pos.ToString ());
- // Pos.Y
- side = "y";
- testInt = 0;
- testRect = Rect.Empty;
- pos = Pos.Y (new View ());
- Assert.Equal ($"Pos.Combine(Pos.View(side={side}, target=View()({{X={testRect.X},Y={testRect.Y},Width={testRect.Width},Height={testRect.Height}}})){(testInt < 0 ? '-' : '+')}Pos.Absolute({testInt}))", pos.ToString ());
- pos = Pos.Y (new View (testRect));
- Assert.Equal ($"Pos.Combine(Pos.View(side={side}, target=View()({{X={testRect.X},Y={testRect.Y},Width={testRect.Width},Height={testRect.Height}}})){(testInt < 0 ? '-' : '+')}Pos.Absolute({testInt}))", pos.ToString ());
- testRect = new Rect (1, 2, 3, 4);
- pos = Pos.Y (new View (testRect));
- Assert.Equal ($"Pos.Combine(Pos.View(side={side}, target=View()({{X={testRect.X},Y={testRect.Y},Width={testRect.Width},Height={testRect.Height}}})){(testInt < 0 ? '-' : '+')}Pos.Absolute({testInt}))", pos.ToString ());
- // Pos.Y(win) + 0
- pos = Pos.Y (new View (testRect)) + testInt;
- Assert.Equal ($"Pos.Combine(Pos.Combine(Pos.View(side={side}, target=View()({{X={testRect.X},Y={testRect.Y},Width={testRect.Width},Height={testRect.Height}}}))+Pos.Absolute(0)){(testInt < 0 ? '-' : '+')}Pos.Absolute({testInt}))", pos.ToString ());
- testInt = 1;
- // Pos.Y(win) +1
- pos = Pos.Y (new View (testRect)) + testInt;
- Assert.Equal ($"Pos.Combine(Pos.Combine(Pos.View(side={side}, target=View()({{X={testRect.X},Y={testRect.Y},Width={testRect.Width},Height={testRect.Height}}}))+Pos.Absolute(0)){(testInt < 0 ? '-' : '+')}Pos.Absolute({testInt}))", pos.ToString ());
- testInt = -1;
- // Pos.Y(win) -1
- pos = Pos.Y (new View (testRect)) - testInt;
- Assert.Equal ($"Pos.Combine(Pos.Combine(Pos.View(side={side}, target=View()({{X={testRect.X},Y={testRect.Y},Width={testRect.Width},Height={testRect.Height}}}))+Pos.Absolute(0)){(testInt < 0 ? '-' : '+')}Pos.Absolute({testInt}))", pos.ToString ());
- // Pos.Bottom
- side = "bottom";
- testRect = Rect.Empty;
- testInt = 0;
- pos = Pos.Bottom (new View ());
- Assert.Equal ($"Pos.Combine(Pos.View(side={side}, target=View()({{X={testRect.X},Y={testRect.Y},Width={testRect.Width},Height={testRect.Height}}})){(testInt < 0 ? '-' : '+')}Pos.Absolute({testInt}))", pos.ToString ());
- pos = Pos.Bottom (new View (testRect));
- Assert.Equal ($"Pos.Combine(Pos.View(side={side}, target=View()({{X={testRect.X},Y={testRect.Y},Width={testRect.Width},Height={testRect.Height}}})){(testInt < 0 ? '-' : '+')}Pos.Absolute({testInt}))", pos.ToString ());
- testRect = new Rect (1, 2, 3, 4);
- pos = Pos.Bottom (new View (testRect));
- Assert.Equal ($"Pos.Combine(Pos.View(side={side}, target=View()({{X={testRect.X},Y={testRect.Y},Width={testRect.Width},Height={testRect.Height}}})){(testInt < 0 ? '-' : '+')}Pos.Absolute({testInt}))", pos.ToString ());
- // Pos.Bottom(win) + 0
- pos = Pos.Bottom (new View (testRect)) + testInt;
- Assert.Equal ($"Pos.Combine(Pos.Combine(Pos.View(side={side}, target=View()({{X={testRect.X},Y={testRect.Y},Width={testRect.Width},Height={testRect.Height}}}))+Pos.Absolute(0)){(testInt < 0 ? '-' : '+')}Pos.Absolute({testInt}))", pos.ToString ());
- testInt = 1;
- // Pos.Bottom(win) +1
- pos = Pos.Bottom (new View (testRect)) + testInt;
- Assert.Equal ($"Pos.Combine(Pos.Combine(Pos.View(side={side}, target=View()({{X={testRect.X},Y={testRect.Y},Width={testRect.Width},Height={testRect.Height}}}))+Pos.Absolute(0)){(testInt < 0 ? '-' : '+')}Pos.Absolute({testInt}))", pos.ToString ());
- testInt = -1;
- // Pos.Bottom(win) -1
- pos = Pos.Bottom (new View (testRect)) - testInt;
- Assert.Equal ($"Pos.Combine(Pos.Combine(Pos.View(side={side}, target=View()({{X={testRect.X},Y={testRect.Y},Width={testRect.Width},Height={testRect.Height}}}))+Pos.Absolute(0)){(testInt < 0 ? '-' : '+')}Pos.Absolute({testInt}))", pos.ToString ());
- }
- // See: https://github.com/gui-cs/Terminal.Gui/issues/504
- [Fact]
- public void LeftTopBottomRight_Win_ShouldNotThrow ()
- {
- // Setup Fake driver
- (Window win, Button button) setup ()
- {
- Application.Init (new FakeDriver (), new FakeMainLoop (() => FakeConsole.ReadKey (true)));
- Application.Iteration = () => {
- Application.RequestStop ();
- };
- var win = new Window ("window") {
- X = 0,
- Y = 0,
- Width = Dim.Fill (),
- Height = Dim.Fill (),
- };
- Application.Top.Add (win);
- var button = new Button ("button") {
- X = Pos.Center (),
- };
- win.Add (button);
- return (win, button);
- }
- Application.RunState rs;
- void cleanup (Application.RunState rs)
- {
- // Cleanup
- Application.End (rs);
- // Shutdown must be called to safely clean up Application if Init has been called
- Application.Shutdown ();
- }
- // Test cases:
- var app = setup ();
- app.button.Y = Pos.Left (app.win);
- rs = Application.Begin (Application.Top);
- // If Application.RunState is used then we must use Application.RunLoop with the rs parameter
- Application.RunLoop (rs);
- cleanup (rs);
- app = setup ();
- app.button.Y = Pos.X (app.win);
- rs = Application.Begin (Application.Top);
- // If Application.RunState is used then we must use Application.RunLoop with the rs parameter
- Application.RunLoop (rs);
- cleanup (rs);
- app = setup ();
- app.button.Y = Pos.Top (app.win);
- rs = Application.Begin (Application.Top);
- // If Application.RunState is used then we must use Application.RunLoop with the rs parameter
- Application.RunLoop (rs);
- cleanup (rs);
- app = setup ();
- app.button.Y = Pos.Y (app.win);
- rs = Application.Begin (Application.Top);
- // If Application.RunState is used then we must use Application.RunLoop with the rs parameter
- Application.RunLoop (rs);
- cleanup (rs);
- app = setup ();
- app.button.Y = Pos.Bottom (app.win);
- rs = Application.Begin (Application.Top);
- // If Application.RunState is used then we must use Application.RunLoop with the rs parameter
- Application.RunLoop (rs);
- cleanup (rs);
- app = setup ();
- app.button.Y = Pos.Right (app.win);
- rs = Application.Begin (Application.Top);
- // If Application.RunState is used then we must use Application.RunLoop with the rs parameter
- Application.RunLoop (rs);
- cleanup (rs);
- }
- [Fact]
- public void Center_SetsValue ()
- {
- var pos = Pos.Center ();
- Assert.Equal ("Pos.Center", pos.ToString ());
- }
- [Fact]
- public void Percent_SetsValue ()
- {
- float f = 0;
- var pos = Pos.Percent (f);
- Assert.Equal ($"Pos.Factor({f / 100:0.###})", pos.ToString ());
- f = 0.5F;
- pos = Pos.Percent (f);
- Assert.Equal ($"Pos.Factor({f / 100:0.###})", pos.ToString ());
- f = 100;
- pos = Pos.Percent (f);
- Assert.Equal ($"Pos.Factor({f / 100:0.###})", pos.ToString ());
- }
- [Fact]
- public void Percent_Equal ()
- {
- float n1 = 0;
- float n2 = 0;
- var pos1 = Pos.Percent (n1);
- var pos2 = Pos.Percent (n2);
- Assert.Equal (pos1, pos2);
- n1 = n2 = 1;
- pos1 = Pos.Percent (n1);
- pos2 = Pos.Percent (n2);
- Assert.Equal (pos1, pos2);
- n1 = n2 = 0.5f;
- pos1 = Pos.Percent (n1);
- pos2 = Pos.Percent (n2);
- Assert.Equal (pos1, pos2);
- n1 = n2 = 100f;
- pos1 = Pos.Percent (n1);
- pos2 = Pos.Percent (n2);
- Assert.Equal (pos1, pos2);
- n1 = 0;
- n2 = 1;
- pos1 = Pos.Percent (n1);
- pos2 = Pos.Percent (n2);
- Assert.NotEqual (pos1, pos2);
- n1 = 0.5f;
- n2 = 1.5f;
- pos1 = Pos.Percent (n1);
- pos2 = Pos.Percent (n2);
- Assert.NotEqual (pos1, pos2);
- }
- [Fact]
- public void Percent_ThrowsOnIvalid ()
- {
- var pos = Pos.Percent (0);
- Assert.Throws<ArgumentException> (() => pos = Pos.Percent (-1));
- Assert.Throws<ArgumentException> (() => pos = Pos.Percent (101));
- Assert.Throws<ArgumentException> (() => pos = Pos.Percent (100.0001F));
- Assert.Throws<ArgumentException> (() => pos = Pos.Percent (1000001));
- }
- [Fact]
- public void ForceValidatePosDim_True_Pos_Validation_Throws_If_NewValue_Is_PosAbsolute_And_OldValue_Is_Another_Type ()
- {
- Application.Init (new FakeDriver (), new FakeMainLoop (() => FakeConsole.ReadKey (true)));
- var t = Application.Top;
- var w = new Window ("w") {
- X = Pos.Left (t) + 2,
- Y = Pos.At (2)
- };
- var v = new View ("v") {
- X = Pos.Center (),
- Y = Pos.Percent (10),
- ForceValidatePosDim = true
- };
- w.Add (v);
- t.Add (w);
- t.Ready += () => {
- Assert.Equal (2, w.X = 2);
- Assert.Equal (2, w.Y = 2);
- Assert.Throws<ArgumentException> (() => v.X = 2);
- Assert.Throws<ArgumentException> (() => v.Y = 2);
- };
- Application.Iteration += () => Application.RequestStop ();
- Application.Run ();
- Application.Shutdown ();
- }
- [Fact]
- public void Pos_Validation_Do_Not_Throws_If_NewValue_Is_PosAbsolute_And_OldValue_Is_Null ()
- {
- Application.Init (new FakeDriver (), new FakeMainLoop (() => FakeConsole.ReadKey (true)));
- var t = Application.Top;
- var w = new Window (new Rect (1, 2, 4, 5), "w");
- t.Add (w);
- t.Ready += () => {
- Assert.Equal (2, w.X = 2);
- Assert.Equal (2, w.Y = 2);
- };
- Application.Iteration += () => Application.RequestStop ();
- Application.Run ();
- Application.Shutdown ();
- }
- [Fact]
- public void Pos_Validation_Do_Not_Throws_If_NewValue_Is_PosAbsolute_And_OldValue_Is_Another_Type_After_Sets_To_LayoutStyle_Absolute ()
- {
- Application.Init (new FakeDriver (), new FakeMainLoop (() => FakeConsole.ReadKey (true)));
- var t = Application.Top;
- var w = new Window ("w") {
- X = Pos.Left (t) + 2,
- Y = Pos.At (2)
- };
- var v = new View ("v") {
- X = Pos.Center (),
- Y = Pos.Percent (10)
- };
- w.Add (v);
- t.Add (w);
- t.Ready += () => {
- v.LayoutStyle = LayoutStyle.Absolute;
- Assert.Equal (2, v.X = 2);
- Assert.Equal (2, v.Y = 2);
- };
- Application.Iteration += () => Application.RequestStop ();
- Application.Run ();
- Application.Shutdown ();
- }
- // DONE: Test PosCombine
- // DONE: Test operators
- [Fact]
- public void PosCombine_Do_Not_Throws ()
- {
- Application.Init (new FakeDriver (), new FakeMainLoop (() => FakeConsole.ReadKey (true)));
- var t = Application.Top;
- var w = new Window ("w") {
- X = Pos.Left (t) + 2,
- Y = Pos.Top (t) + 2
- };
- var f = new FrameView ("f");
- var v1 = new View ("v1") {
- X = Pos.Left (w) + 2,
- Y = Pos.Top (w) + 2
- };
- var v2 = new View ("v2") {
- X = Pos.Left (v1) + 2,
- Y = Pos.Top (v1) + 2
- };
- f.Add (v1, v2);
- w.Add (f);
- t.Add (w);
- f.X = Pos.X (t) + Pos.X (v2) - Pos.X (v1);
- f.Y = Pos.Y (t) + Pos.Y (v2) - Pos.Y (v1);
- t.Ready += () => {
- Assert.Equal (0, t.Frame.X);
- Assert.Equal (0, t.Frame.Y);
- Assert.Equal (2, w.Frame.X);
- Assert.Equal (2, w.Frame.Y);
- Assert.Equal (2, f.Frame.X);
- Assert.Equal (2, f.Frame.Y);
- Assert.Equal (4, v1.Frame.X);
- Assert.Equal (4, v1.Frame.Y);
- Assert.Equal (6, v2.Frame.X);
- Assert.Equal (6, v2.Frame.Y);
- };
- Application.Iteration += () => Application.RequestStop ();
- Application.Run ();
- Application.Shutdown ();
- }
- [Fact]
- public void PosCombine_Will_Throws ()
- {
- Application.Init (new FakeDriver (), new FakeMainLoop (() => FakeConsole.ReadKey (true)));
- var t = Application.Top;
- var w = new Window ("w") {
- X = Pos.Left (t) + 2,
- Y = Pos.Top (t) + 2
- };
- var f = new FrameView ("f");
- var v1 = new View ("v1") {
- X = Pos.Left (w) + 2,
- Y = Pos.Top (w) + 2
- };
- var v2 = new View ("v2") {
- X = Pos.Left (v1) + 2,
- Y = Pos.Top (v1) + 2
- };
- f.Add (v1); // v2 not added
- w.Add (f);
- t.Add (w);
- f.X = Pos.X (v2) - Pos.X (v1);
- f.Y = Pos.Y (v2) - Pos.Y (v1);
- Assert.Throws<InvalidOperationException> (() => Application.Run ());
- Application.Shutdown ();
- }
- [Fact]
- public void Pos_Add_Operator ()
- {
- Application.Init (new FakeDriver (), new FakeMainLoop (() => FakeConsole.ReadKey (true)));
- var top = Application.Top;
- var view = new View () { X = 0, Y = 0, Width = 20, Height = 20 };
- var field = new TextField () { X = 0, Y = 0, Width = 20 };
- var count = 0;
- field.KeyDown += (k) => {
- if (k.KeyEvent.Key == Key.Enter) {
- field.Text = $"Label {count}";
- var label = new Label (field.Text) { X = 0, Y = field.Y, Width = 20 };
- view.Add (label);
- Assert.Equal ($"Label {count}", label.Text);
- Assert.Equal ($"Pos.Absolute({count})", label.Y.ToString ());
- Assert.Equal ($"Pos.Absolute({count})", field.Y.ToString ());
- field.Y += 1;
- count++;
- Assert.Equal ($"Pos.Absolute({count})", field.Y.ToString ());
- }
- };
- Application.Iteration += () => {
- while (count < 20) {
- field.OnKeyDown (new KeyEvent (Key.Enter, new KeyModifiers ()));
- }
- Application.RequestStop ();
- };
- var win = new Window ();
- win.Add (view);
- win.Add (field);
- top.Add (win);
- Application.Run (top);
- Assert.Equal (20, count);
- // Shutdown must be called to safely clean up Application if Init has been called
- Application.Shutdown ();
- }
- [Fact]
- public void Pos_Subtract_Operator ()
- {
- Application.Init (new FakeDriver (), new FakeMainLoop (() => FakeConsole.ReadKey (true)));
- var top = Application.Top;
- var view = new View () { X = 0, Y = 0, Width = 20, Height = 20 };
- var field = new TextField () { X = 0, Y = 0, Width = 20 };
- var count = 20;
- var listLabels = new List<Label> ();
- for (int i = 0; i < count; i++) {
- field.Text = $"Label {i}";
- var label = new Label (field.Text) { X = 0, Y = field.Y, Width = 20 };
- view.Add (label);
- Assert.Equal ($"Label {i}", label.Text);
- Assert.Equal ($"Pos.Absolute({i})", field.Y.ToString ());
- listLabels.Add (label);
- Assert.Equal ($"Pos.Absolute({i})", field.Y.ToString ());
- field.Y += 1;
- Assert.Equal ($"Pos.Absolute({i + 1})", field.Y.ToString ());
- }
- field.KeyDown += (k) => {
- if (k.KeyEvent.Key == Key.Enter) {
- Assert.Equal ($"Label {count - 1}", listLabels [count - 1].Text);
- view.Remove (listLabels [count - 1]);
- Assert.Equal ($"Pos.Absolute({count})", field.Y.ToString ());
- field.Y -= 1;
- count--;
- Assert.Equal ($"Pos.Absolute({count})", field.Y.ToString ());
- }
- };
- Application.Iteration += () => {
- while (count > 0) {
- field.OnKeyDown (new KeyEvent (Key.Enter, new KeyModifiers ()));
- }
- Application.RequestStop ();
- };
- var win = new Window ();
- win.Add (view);
- win.Add (field);
- top.Add (win);
- Application.Run (top);
- Assert.Equal (0, count);
- // Shutdown must be called to safely clean up Application if Init has been called
- Application.Shutdown ();
- }
- [Fact]
- public void Internal_Tests ()
- {
- var posFactor = new Pos.PosFactor (0.10F);
- Assert.Equal (10, posFactor.Anchor (100));
- var posAnchorEnd = new Pos.PosAnchorEnd (1);
- Assert.Equal (99, posAnchorEnd.Anchor (100));
- var posCenter = new Pos.PosCenter ();
- Assert.Equal (50, posCenter.Anchor (100));
- var posAbsolute = new Pos.PosAbsolute (10);
- Assert.Equal (10, posAbsolute.Anchor (0));
- var posCombine = new Pos.PosCombine (true, posFactor, posAbsolute);
- Assert.Equal (posCombine.left, posFactor);
- Assert.Equal (posCombine.right, posAbsolute);
- Assert.Equal (20, posCombine.Anchor (100));
- var view = new View (new Rect (20, 10, 20, 1));
- var posViewX = new Pos.PosView (view, 0);
- Assert.Equal (20, posViewX.Anchor (0));
- var posViewY = new Pos.PosView (view, 1);
- Assert.Equal (10, posViewY.Anchor (0));
- var posRight = new Pos.PosView (view, 2);
- Assert.Equal (40, posRight.Anchor (0));
- var posViewBottom = new Pos.PosView (view, 3);
- Assert.Equal (11, posViewBottom.Anchor (0));
- }
- [Fact]
- public void Function_SetsValue ()
- {
- var text = "Test";
- var pos = Pos.Function (() => text.Length);
- Assert.Equal ("Pos.PosFunc(4)", pos.ToString ());
- text = "New Test";
- Assert.Equal ("Pos.PosFunc(8)", pos.ToString ());
- text = "";
- Assert.Equal ("Pos.PosFunc(0)", pos.ToString ());
- }
- [Fact]
- public void Function_Equal ()
- {
- var f1 = () => 0;
- var f2 = () => 0;
- var pos1 = Pos.Function (f1);
- var pos2 = Pos.Function (f2);
- Assert.Equal (pos1, pos2);
- f2 = () => 1;
- pos2 = Pos.Function (f2);
- Assert.NotEqual (pos1, pos2);
- }
- }
- }
|