1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516 |
- using System.Text;
- using Xunit.Abstractions;
- // Alias Console to MockConsole so we don't accidentally use Console
- namespace Terminal.Gui.ViewTests;
- public class ViewTests
- {
- private readonly ITestOutputHelper _output;
- public ViewTests (ITestOutputHelper output) { _output = output; }
- [Fact]
- [TestRespondersDisposed]
- public void Added_Removed ()
- {
- var v = new View { Frame = new Rect (0, 0, 10, 24) };
- var t = new View ();
- v.Added += (s, e) =>
- {
- Assert.Same (v.SuperView, e.Parent);
- Assert.Same (t, e.Parent);
- Assert.Same (v, e.Child);
- };
- v.Removed += (s, e) =>
- {
- Assert.Same (t, e.Parent);
- Assert.Same (v, e.Child);
- Assert.True (v.SuperView == null);
- };
- t.Add (v);
- Assert.True (t.Subviews.Count == 1);
- t.Remove (v);
- Assert.True (t.Subviews.Count == 0);
- t.Dispose ();
- v.Dispose ();
- }
- [Fact]
- [AutoInitShutdown]
- public void Clear_Bounds_Can_Use_Driver_AddRune_Or_AddStr_Methods ()
- {
- var view = new FrameView { Width = Dim.Fill (), Height = Dim.Fill () };
- view.DrawContent += (s, e) =>
- {
- Rect savedClip = Application.Driver.Clip;
- Application.Driver.Clip = new Rect (1, 1, view.Bounds.Width, view.Bounds.Height);
- for (var row = 0; row < view.Bounds.Height; row++)
- {
- Application.Driver.Move (1, row + 1);
- for (var col = 0; col < view.Bounds.Width; col++)
- {
- Application.Driver.AddStr ($"{col}");
- }
- }
- Application.Driver.Clip = savedClip;
- e.Cancel = true;
- };
- Application.Top.Add (view);
- Application.Begin (Application.Top);
- ((FakeDriver)Application.Driver).SetBufferSize (20, 10);
- var expected = @"
- ┌──────────────────┐
- │012345678910111213│
- │012345678910111213│
- │012345678910111213│
- │012345678910111213│
- │012345678910111213│
- │012345678910111213│
- │012345678910111213│
- │012345678910111213│
- └──────────────────┘
- ";
- Rect pos = TestHelpers.AssertDriverContentsWithFrameAre (expected, _output);
- Assert.Equal (new Rect (0, 0, 20, 10), pos);
- view.Clear (view.Frame);
- expected = @"
- ";
- pos = TestHelpers.AssertDriverContentsWithFrameAre (expected, _output);
- Assert.Equal (Rect.Empty, pos);
- }
- [Fact]
- [AutoInitShutdown]
- public void Clear_Can_Use_Driver_AddRune_Or_AddStr_Methods ()
- {
- var view = new FrameView { Width = Dim.Fill (), Height = Dim.Fill () };
- view.DrawContent += (s, e) =>
- {
- Rect savedClip = Application.Driver.Clip;
- Application.Driver.Clip = new Rect (1, 1, view.Bounds.Width, view.Bounds.Height);
- for (var row = 0; row < view.Bounds.Height; row++)
- {
- Application.Driver.Move (1, row + 1);
- for (var col = 0; col < view.Bounds.Width; col++)
- {
- Application.Driver.AddStr ($"{col}");
- }
- }
- Application.Driver.Clip = savedClip;
- e.Cancel = true;
- };
- Application.Top.Add (view);
- Application.Begin (Application.Top);
- ((FakeDriver)Application.Driver).SetBufferSize (20, 10);
- var expected = @"
- ┌──────────────────┐
- │012345678910111213│
- │012345678910111213│
- │012345678910111213│
- │012345678910111213│
- │012345678910111213│
- │012345678910111213│
- │012345678910111213│
- │012345678910111213│
- └──────────────────┘
- ";
- Rect pos = TestHelpers.AssertDriverContentsWithFrameAre (expected, _output);
- Assert.Equal (new Rect (0, 0, 20, 10), pos);
- view.Clear (view.Frame);
- expected = @"
- ";
- pos = TestHelpers.AssertDriverContentsWithFrameAre (expected, _output);
- Assert.Equal (Rect.Empty, pos);
- }
- [Theory]
- [AutoInitShutdown]
- [InlineData (true)]
- [InlineData (false)]
- public void Clear_Does_Not_Spillover_Its_Parent (bool label)
- {
- var root = new View { Width = 20, Height = 10, ColorScheme = Colors.ColorSchemes ["Base"] };
- View v = label
- ? new Label { Text = new string ('c', 100) }
- : new TextView { Height = 1, Text = new string ('c', 100), Width = Dim.Fill () };
- root.Add (v);
- Application.Top.Add (root);
- RunState runState = Application.Begin (Application.Top);
- if (label)
- {
- Assert.True (v.AutoSize);
- Assert.False (v.CanFocus);
- Assert.Equal (new Rect (0, 0, 100, 1), v.Frame);
- }
- else
- {
- Assert.False (v.AutoSize);
- Assert.True (v.CanFocus);
- Assert.Equal (new Rect (0, 0, 20, 1), v.Frame);
- }
- TestHelpers.AssertDriverContentsWithFrameAre (
- @"
- cccccccccccccccccccc",
- _output
- );
- Attribute [] attributes =
- {
- Colors.ColorSchemes ["TopLevel"].Normal,
- Colors.ColorSchemes ["Base"].Normal,
- Colors.ColorSchemes ["Base"].Focus
- };
- if (label)
- {
- TestHelpers.AssertDriverAttributesAre (
- @"
- 111111111111111111110
- 111111111111111111110",
- Application.Driver,
- attributes
- );
- }
- else
- {
- TestHelpers.AssertDriverAttributesAre (
- @"
- 222222222222222222220
- 111111111111111111110",
- Application.Driver,
- attributes
- );
- }
- if (label)
- {
- root.CanFocus = true;
- v.CanFocus = true;
- Assert.False (v.HasFocus);
- v.SetFocus ();
- Assert.True (v.HasFocus);
- Application.Refresh ();
- TestHelpers.AssertDriverAttributesAre (
- @"
- 222222222222222222220
- 111111111111111111110",
- Application.Driver,
- attributes
- );
- }
- Application.End (runState);
- }
- [Fact]
- [AutoInitShutdown]
- public void Correct_Redraw_Bounds_NeedDisplay_On_Shrink_And_Move_Down_Right_Using_Frame ()
- {
- var label = new Label { Text = "At 0,0" };
- var view = new DerivedView
- {
- X = 2,
- Y = 2,
- Width = 30,
- Height = 2,
- Text = "A text with some long width\n and also with two lines."
- };
- Toplevel top = Application.Top;
- top.Add (label, view);
- RunState runState = Application.Begin (top);
- TestHelpers.AssertDriverContentsWithFrameAre (
- @"
- At 0,0
-
- A text with some long width
- and also with two lines. ",
- _output
- );
- view.Frame = new Rect (3, 3, 10, 1);
- Assert.Equal (new Rect (3, 3, 10, 1), view.Frame);
- Assert.Equal (LayoutStyle.Absolute, view.LayoutStyle);
- Assert.Equal (new Rect (0, 0, 10, 1), view.Bounds);
- Assert.Equal (new Rect (0, 0, 10, 1), view._needsDisplayRect);
- top.Draw ();
- TestHelpers.AssertDriverContentsWithFrameAre (
- @"
- At 0,0
-
-
- A text wit",
- _output
- );
- Application.End (runState);
- }
- [Fact]
- [AutoInitShutdown]
- public void Correct_Redraw_Bounds_NeedDisplay_On_Shrink_And_Move_Down_Right_Using_Pos_Dim ()
- {
- var label = new Label { Text = "At 0,0" };
- var view = new DerivedView
- {
- X = 2,
- Y = 2,
- Width = 30,
- Height = 2,
- Text = "A text with some long width\n and also with two lines."
- };
- Toplevel top = Application.Top;
- top.Add (label, view);
- RunState runState = Application.Begin (top);
- top.Draw ();
- TestHelpers.AssertDriverContentsWithFrameAre (
- @"
- At 0,0
-
- A text with some long width
- and also with two lines. ",
- _output
- );
- view.X = 3;
- view.Y = 3;
- view.Width = 10;
- view.Height = 1;
- Assert.Equal (new Rect (3, 3, 10, 1), view.Frame);
- Assert.Equal (new Rect (0, 0, 10, 1), view.Bounds);
- Assert.Equal (new Rect (0, 0, 30, 2), view._needsDisplayRect);
- top.Draw ();
- TestHelpers.AssertDriverContentsWithFrameAre (
- @"
- At 0,0
-
-
- A text wit",
- _output
- );
- Application.End (runState);
- }
- [Fact]
- [AutoInitShutdown]
- public void Correct_Redraw_Bounds_NeedDisplay_On_Shrink_And_Move_Up_Left_Using_Frame ()
- {
- var label = new Label { Text = "At 0,0" };
- var view = new DerivedView
- {
- X = 2,
- Y = 2,
- Width = 30,
- Height = 2,
- Text = "A text with some long width\n and also with two lines."
- };
- Toplevel top = Application.Top;
- top.Add (label, view);
- RunState runState = Application.Begin (top);
- top.Draw ();
- TestHelpers.AssertDriverContentsWithFrameAre (
- @"
- At 0,0
-
- A text with some long width
- and also with two lines. ",
- _output
- );
- view.Frame = new Rect (1, 1, 10, 1);
- Assert.Equal (new Rect (1, 1, 10, 1), view.Frame);
- Assert.Equal (LayoutStyle.Absolute, view.LayoutStyle);
- Assert.Equal (new Rect (0, 0, 10, 1), view.Bounds);
- Assert.Equal (new Rect (0, 0, 10, 1), view._needsDisplayRect);
- top.Draw ();
- TestHelpers.AssertDriverContentsWithFrameAre (
- @"
- At 0,0
- A text wit",
- _output
- );
- Application.End (runState);
- }
- [Fact]
- [AutoInitShutdown]
- public void Correct_Redraw_Bounds_NeedDisplay_On_Shrink_And_Move_Up_Left_Using_Pos_Dim ()
- {
- var label = new Label { Text = "At 0,0" };
- var view = new DerivedView
- {
- X = 2,
- Y = 2,
- Width = 30,
- Height = 2,
- Text = "A text with some long width\n and also with two lines."
- };
- Toplevel top = Application.Top;
- top.Add (label, view);
- RunState runState = Application.Begin (top);
- top.Draw ();
- TestHelpers.AssertDriverContentsWithFrameAre (
- @"
- At 0,0
-
- A text with some long width
- and also with two lines. ",
- _output
- );
- view.X = 1;
- view.Y = 1;
- view.Width = 10;
- view.Height = 1;
- Assert.Equal (new Rect (1, 1, 10, 1), view.Frame);
- Assert.Equal (new Rect (0, 0, 10, 1), view.Bounds);
- Assert.Equal (new Rect (0, 0, 30, 2), view._needsDisplayRect);
- top.Draw ();
- TestHelpers.AssertDriverContentsWithFrameAre (
- @"
- At 0,0
- A text wit",
- _output
- );
- Application.End (runState);
- }
- [Fact]
- [TestRespondersDisposed]
- public void Dispose_View ()
- {
- var view = new View ();
- Assert.NotNull (view.Margin);
- Assert.NotNull (view.Border);
- Assert.NotNull (view.Padding);
- #if DEBUG_IDISPOSABLE
- Assert.Equal (4, Responder.Instances.Count);
- #endif
- view.Dispose ();
- Assert.Null (view.Margin);
- Assert.Null (view.Border);
- Assert.Null (view.Padding);
- }
- [Fact]
- [AutoInitShutdown]
- public void DrawContentComplete_Event_Is_Always_Called ()
- {
- var viewCalled = false;
- var tvCalled = false;
- var view = new View { Width = 10, Height = 10, Text = "View" };
- view.DrawContentComplete += (s, e) => viewCalled = true;
- var tv = new TextView { Y = 11, Width = 10, Height = 10 };
- tv.DrawContentComplete += (s, e) => tvCalled = true;
- Application.Top.Add (view, tv);
- Application.Begin (Application.Top);
- Assert.True (viewCalled);
- Assert.True (tvCalled);
- }
- [Fact]
- [AutoInitShutdown]
- public void Frame_Set_After_Initialize_Update_NeededDisplay ()
- {
- var frame = new FrameView ();
- var label = new Label
- {
- ColorScheme = Colors.ColorSchemes ["Menu"], X = 0, Y = 0, Text = "This should be the first line."
- };
- var button = new Button
- {
- X = 0, // don't overcomplicate unit tests
- Y = 1,
- Text = "Press me!"
- };
- frame.Add (label, button);
- frame.X = Pos.Center ();
- frame.Y = Pos.Center ();
- frame.Width = 40;
- frame.Height = 8;
- Toplevel top = Application.Top;
- top.Add (frame);
- RunState runState = Application.Begin (top);
- top.LayoutComplete += (s, e) => { Assert.Equal (new Rect (0, 0, 80, 25), top._needsDisplayRect); };
- frame.LayoutComplete += (s, e) => { Assert.Equal (new Rect (0, 0, 40, 8), frame._needsDisplayRect); };
- label.LayoutComplete += (s, e) => { Assert.Equal (new Rect (0, 0, 38, 1), label._needsDisplayRect); };
- button.LayoutComplete += (s, e) => { Assert.Equal (new Rect (0, 0, 13, 1), button._needsDisplayRect); };
- Assert.True (label.AutoSize);
- Assert.Equal (new Rect (0, 0, 80, 25), top.Frame);
- Assert.Equal (new Rect (20, 8, 40, 8), frame.Frame);
- Assert.Equal (
- new Rect (20, 8, 60, 16),
- new Rect (
- frame.Frame.Left,
- frame.Frame.Top,
- frame.Frame.Right,
- frame.Frame.Bottom
- )
- );
- Assert.Equal (new Rect (0, 0, 30, 1), label.Frame);
- Assert.Equal (new Rect (0, 1, 13, 1), button.Frame); // this proves frame was set
- Application.End (runState);
- }
- [Fact]
- [AutoInitShutdown]
- public void GetHotNormalColor_ColorScheme ()
- {
- var view = new View { ColorScheme = Colors.ColorSchemes ["Base"] };
- Assert.Equal (view.ColorScheme.HotNormal, view.GetHotNormalColor ());
- view.Enabled = false;
- Assert.Equal (view.ColorScheme.Disabled, view.GetHotNormalColor ());
- view.Dispose ();
- }
- [Fact]
- [AutoInitShutdown]
- public void GetNormalColor_ColorScheme ()
- {
- var view = new View { ColorScheme = Colors.ColorSchemes ["Base"] };
- Assert.Equal (view.ColorScheme.Normal, view.GetNormalColor ());
- view.Enabled = false;
- Assert.Equal (view.ColorScheme.Disabled, view.GetNormalColor ());
- view.Dispose ();
- }
- [Fact]
- [AutoInitShutdown]
- public void GetTopSuperView_Test ()
- {
- var v1 = new View ();
- var fv1 = new FrameView ();
- fv1.Add (v1);
- var tf1 = new TextField ();
- var w1 = new Window ();
- w1.Add (fv1, tf1);
- var top1 = new Toplevel ();
- top1.Add (w1);
- var v2 = new View ();
- var fv2 = new FrameView ();
- fv2.Add (v2);
- var tf2 = new TextField ();
- var w2 = new Window ();
- w2.Add (fv2, tf2);
- var top2 = new Toplevel ();
- top2.Add (w2);
- Assert.Equal (top1, v1.GetTopSuperView ());
- Assert.Equal (top2, v2.GetTopSuperView ());
- v1.Dispose ();
- fv1.Dispose ();
- tf1.Dispose ();
- w1.Dispose ();
- top1.Dispose ();
- v2.Dispose ();
- fv2.Dispose ();
- tf2.Dispose ();
- w2.Dispose ();
- top2.Dispose ();
- }
- [Fact]
- [AutoInitShutdown]
- public void Incorrect_Redraw_Bounds_NeedDisplay_On_Shrink_And_Move_Down_Right_Using_Frame ()
- {
- var label = new Label { Text = "At 0,0" };
- var view = new DerivedView
- {
- X = 2,
- Y = 2,
- Width = 30,
- Height = 2,
- Text = "A text with some long width\n and also with two lines."
- };
- Toplevel top = Application.Top;
- top.Add (label, view);
- RunState runState = Application.Begin (top);
- view.Draw ();
- TestHelpers.AssertDriverContentsWithFrameAre (
- @"
- At 0,0
-
- A text with some long width
- and also with two lines. ",
- _output
- );
- view.Frame = new Rect (3, 3, 10, 1);
- Assert.Equal (new Rect (0, 0, 10, 1), view.Bounds);
- Assert.Equal (new Rect (0, 0, 10, 1), view._needsDisplayRect);
- view.Draw ();
- TestHelpers.AssertDriverContentsWithFrameAre (
- @"
- At 0,0
-
- A text with some long width
- A text witith two lines. ",
- _output
- );
- Application.End (runState);
- }
- [Fact]
- [AutoInitShutdown]
- public void Incorrect_Redraw_Bounds_NeedDisplay_On_Shrink_And_Move_Down_Right_Using_Pos_Dim ()
- {
- var label = new Label { Text = "At 0,0" };
- var view = new DerivedView
- {
- X = 2,
- Y = 2,
- Width = 30,
- Height = 2,
- Text = "A text with some long width\n and also with two lines."
- };
- Toplevel top = Application.Top;
- top.Add (label, view);
- RunState runState = Application.Begin (top);
- view.Draw ();
- TestHelpers.AssertDriverContentsWithFrameAre (
- @"
- At 0,0
-
- A text with some long width
- and also with two lines. ",
- _output
- );
- view.X = 3;
- view.Y = 3;
- view.Width = 10;
- view.Height = 1;
- Assert.Equal (new Rect (3, 3, 10, 1), view.Frame);
- Assert.Equal (new Rect (0, 0, 10, 1), view.Bounds);
- Assert.Equal (new Rect (0, 0, 30, 2), view._needsDisplayRect);
- view.Draw ();
- TestHelpers.AssertDriverContentsWithFrameAre (
- @"
- At 0,0
-
- A text with some long width
- A text witith two lines. ",
- _output
- );
- Application.End (runState);
- }
- [Fact]
- [AutoInitShutdown]
- public void Incorrect_Redraw_Bounds_NeedDisplay_On_Shrink_And_Move_Up_Left_Using_Frame ()
- {
- var label = new Label { Text = "At 0,0" };
- var view = new DerivedView
- {
- X = 2,
- Y = 2,
- Width = 30,
- Height = 2,
- Text = "A text with some long width\n and also with two lines."
- };
- Toplevel top = Application.Top;
- top.Add (label, view);
- RunState runState = Application.Begin (top);
- view.Draw ();
- TestHelpers.AssertDriverContentsWithFrameAre (
- @"
- At 0,0
-
- A text with some long width
- and also with two lines. ",
- _output
- );
- view.Frame = new Rect (1, 1, 10, 1);
- Assert.Equal (new Rect (1, 1, 10, 1), view.Frame);
- Assert.Equal (LayoutStyle.Absolute, view.LayoutStyle);
- Assert.Equal (new Rect (0, 0, 10, 1), view.Bounds);
- Assert.Equal (new Rect (0, 0, 10, 1), view._needsDisplayRect);
- view.Draw ();
- TestHelpers.AssertDriverContentsWithFrameAre (
- @"
- At 0,0
- A text wit
- A text with some long width
- and also with two lines. ",
- _output
- );
- Application.End (runState);
- }
- [Fact]
- [AutoInitShutdown]
- public void Incorrect_Redraw_Bounds_NeedDisplay_On_Shrink_And_Move_Up_Left_Using_Pos_Dim ()
- {
- var label = new Label { Text = "At 0,0" };
- var view = new DerivedView
- {
- X = 2,
- Y = 2,
- Width = 30,
- Height = 2,
- Text = "A text with some long width\n and also with two lines."
- };
- Toplevel top = Application.Top;
- top.Add (label, view);
- RunState runState = Application.Begin (top);
- view.Draw ();
- TestHelpers.AssertDriverContentsWithFrameAre (
- @"
- At 0,0
-
- A text with some long width
- and also with two lines. ",
- _output
- );
- view.X = 1;
- view.Y = 1;
- view.Width = 10;
- view.Height = 1;
- Assert.Equal (new Rect (1, 1, 10, 1), view.Frame);
- Assert.Equal (new Rect (0, 0, 10, 1), view.Bounds);
- Assert.Equal (new Rect (0, 0, 30, 2), view._needsDisplayRect);
- view.Draw ();
- TestHelpers.AssertDriverContentsWithFrameAre (
- @"
- At 0,0
- A text wit
- A text with some long width
- and also with two lines. ",
- _output
- );
- Application.End (runState);
- }
- [Fact]
- [TestRespondersDisposed]
- public void Initialized_Event_Comparing_With_Added_Event ()
- {
- Application.Init (new FakeDriver ());
- var top = new Toplevel { Id = "0" }; // Frame: 0, 0, 80, 25; Bounds: 0, 0, 80, 25
- var winAddedToTop = new Window
- {
- Id = "t", Width = Dim.Fill (), Height = Dim.Fill ()
- }; // Frame: 0, 0, 80, 25; Bounds: 0, 0, 78, 23
- var v1AddedToWin = new View
- {
- Id = "v1", Width = Dim.Fill (), Height = Dim.Fill ()
- }; // Frame: 1, 1, 78, 23 (because Windows has a border)
- var v2AddedToWin = new View
- {
- Id = "v2", Width = Dim.Fill (), Height = Dim.Fill ()
- }; // Frame: 1, 1, 78, 23 (because Windows has a border)
- var svAddedTov1 = new View
- {
- Id = "sv1", Width = Dim.Fill (), Height = Dim.Fill ()
- }; // Frame: 1, 1, 78, 23 (same as it's superview v1AddedToWin)
- int tc = 0, wc = 0, v1c = 0, v2c = 0, sv1c = 0;
- winAddedToTop.Added += (s, e) =>
- {
- Assert.Equal (e.Parent.Frame.Width, winAddedToTop.Frame.Width);
- Assert.Equal (e.Parent.Frame.Height, winAddedToTop.Frame.Height);
- };
- v1AddedToWin.Added += (s, e) =>
- {
- Assert.Equal (e.Parent.Frame.Width, v1AddedToWin.Frame.Width);
- Assert.Equal (e.Parent.Frame.Height, v1AddedToWin.Frame.Height);
- };
- v2AddedToWin.Added += (s, e) =>
- {
- Assert.Equal (e.Parent.Frame.Width, v2AddedToWin.Frame.Width);
- Assert.Equal (e.Parent.Frame.Height, v2AddedToWin.Frame.Height);
- };
- svAddedTov1.Added += (s, e) =>
- {
- Assert.Equal (e.Parent.Frame.Width, svAddedTov1.Frame.Width);
- Assert.Equal (e.Parent.Frame.Height, svAddedTov1.Frame.Height);
- };
- top.Initialized += (s, e) =>
- {
- tc++;
- Assert.Equal (1, tc);
- Assert.Equal (1, wc);
- Assert.Equal (1, v1c);
- Assert.Equal (1, v2c);
- Assert.Equal (1, sv1c);
- Assert.True (top.CanFocus);
- Assert.True (winAddedToTop.CanFocus);
- Assert.False (v1AddedToWin.CanFocus);
- Assert.False (v2AddedToWin.CanFocus);
- Assert.False (svAddedTov1.CanFocus);
- Application.Refresh ();
- };
- winAddedToTop.Initialized += (s, e) =>
- {
- wc++;
- Assert.Equal (top.Bounds.Width, winAddedToTop.Frame.Width);
- Assert.Equal (top.Bounds.Height, winAddedToTop.Frame.Height);
- };
- v1AddedToWin.Initialized += (s, e) =>
- {
- v1c++;
- // Top.Frame: 0, 0, 80, 25; Top.Bounds: 0, 0, 80, 25
- // BUGBUG: This is wrong, it should be 78, 23. This test has always been broken.
- // in no way should the v1AddedToWin.Frame be the same as the Top.Frame/Bounds
- // as it is a subview of winAddedToTop, which has a border!
- //Assert.Equal (top.Bounds.Width, v1AddedToWin.Frame.Width);
- //Assert.Equal (top.Bounds.Height, v1AddedToWin.Frame.Height);
- };
- v2AddedToWin.Initialized += (s, e) =>
- {
- v2c++;
- // Top.Frame: 0, 0, 80, 25; Top.Bounds: 0, 0, 80, 25
- // BUGBUG: This is wrong, it should be 78, 23. This test has always been broken.
- // in no way should the v2AddedToWin.Frame be the same as the Top.Frame/Bounds
- // as it is a subview of winAddedToTop, which has a border!
- //Assert.Equal (top.Bounds.Width, v2AddedToWin.Frame.Width);
- //Assert.Equal (top.Bounds.Height, v2AddedToWin.Frame.Height);
- };
- svAddedTov1.Initialized += (s, e) =>
- {
- sv1c++;
- // Top.Frame: 0, 0, 80, 25; Top.Bounds: 0, 0, 80, 25
- // BUGBUG: This is wrong, it should be 78, 23. This test has always been broken.
- // in no way should the svAddedTov1.Frame be the same as the Top.Frame/Bounds
- // because sv1AddedTov1 is a subview of v1AddedToWin, which is a subview of
- // winAddedToTop, which has a border!
- //Assert.Equal (top.Bounds.Width, svAddedTov1.Frame.Width);
- //Assert.Equal (top.Bounds.Height, svAddedTov1.Frame.Height);
- Assert.False (svAddedTov1.CanFocus);
- Assert.Throws<InvalidOperationException> (() => svAddedTov1.CanFocus = true);
- Assert.False (svAddedTov1.CanFocus);
- };
- v1AddedToWin.Add (svAddedTov1);
- winAddedToTop.Add (v1AddedToWin, v2AddedToWin);
- top.Add (winAddedToTop);
- Application.Iteration += (s, a) =>
- {
- Application.Refresh ();
- top.Running = false;
- };
- Application.Run (top);
- Application.Shutdown ();
- Assert.Equal (1, tc);
- Assert.Equal (1, wc);
- Assert.Equal (1, v1c);
- Assert.Equal (1, v2c);
- Assert.Equal (1, sv1c);
- Assert.True (top.CanFocus);
- Assert.True (winAddedToTop.CanFocus);
- Assert.False (v1AddedToWin.CanFocus);
- Assert.False (v2AddedToWin.CanFocus);
- Assert.False (svAddedTov1.CanFocus);
- v1AddedToWin.CanFocus = true;
- Assert.False (svAddedTov1.CanFocus); // False because sv1 was disposed and it isn't a subview of v1.
- }
- [Fact]
- [TestRespondersDisposed]
- public void Initialized_Event_Will_Be_Invoked_When_Added_Dynamically ()
- {
- Application.Init (new FakeDriver ());
- var t = new Toplevel { Id = "0" };
- var w = new Window { Id = "t", Width = Dim.Fill (), Height = Dim.Fill () };
- var v1 = new View { Id = "v1", Width = Dim.Fill (), Height = Dim.Fill () };
- var v2 = new View { Id = "v2", Width = Dim.Fill (), Height = Dim.Fill () };
- int tc = 0, wc = 0, v1c = 0, v2c = 0, sv1c = 0;
- t.Initialized += (s, e) =>
- {
- tc++;
- Assert.Equal (1, tc);
- Assert.Equal (1, wc);
- Assert.Equal (1, v1c);
- Assert.Equal (1, v2c);
- Assert.Equal (0, sv1c); // Added after t in the Application.Iteration.
- Assert.True (t.CanFocus);
- Assert.True (w.CanFocus);
- Assert.False (v1.CanFocus);
- Assert.False (v2.CanFocus);
- Application.Refresh ();
- };
- w.Initialized += (s, e) =>
- {
- wc++;
- Assert.Equal (t.Bounds.Width, w.Frame.Width);
- Assert.Equal (t.Bounds.Height, w.Frame.Height);
- };
- v1.Initialized += (s, e) =>
- {
- v1c++;
- //Assert.Equal (t.Bounds.Width, v1.Frame.Width);
- //Assert.Equal (t.Bounds.Height, v1.Frame.Height);
- };
- v2.Initialized += (s, e) =>
- {
- v2c++;
- //Assert.Equal (t.Bounds.Width, v2.Frame.Width);
- //Assert.Equal (t.Bounds.Height, v2.Frame.Height);
- };
- w.Add (v1, v2);
- t.Add (w);
- Application.Iteration += (s, a) =>
- {
- var sv1 = new View { Id = "sv1", Width = Dim.Fill (), Height = Dim.Fill () };
- sv1.Initialized += (s, e) =>
- {
- sv1c++;
- Assert.NotEqual (t.Frame.Width, sv1.Frame.Width);
- Assert.NotEqual (t.Frame.Height, sv1.Frame.Height);
- Assert.False (sv1.CanFocus);
- Assert.Throws<InvalidOperationException> (() => sv1.CanFocus = true);
- Assert.False (sv1.CanFocus);
- };
- v1.Add (sv1);
- Application.Refresh ();
- t.Running = false;
- };
- Application.Run (t);
- Application.Shutdown ();
- Assert.Equal (1, tc);
- Assert.Equal (1, wc);
- Assert.Equal (1, v1c);
- Assert.Equal (1, v2c);
- Assert.Equal (1, sv1c);
- Assert.True (t.CanFocus);
- Assert.True (w.CanFocus);
- Assert.False (v1.CanFocus);
- Assert.False (v2.CanFocus);
- }
- [Fact]
- public void Internal_Tests ()
- {
- var rect = new Rect (1, 1, 10, 1);
- var view = new View { Frame = rect };
- }
- [Fact]
- [TestRespondersDisposed]
- public void IsAdded_Added_Removed ()
- {
- var top = new Toplevel ();
- var view = new View ();
- Assert.False (view.IsAdded);
- top.Add (view);
- Assert.True (view.IsAdded);
- top.Remove (view);
- Assert.False (view.IsAdded);
- top.Dispose ();
- view.Dispose ();
- }
- [Theory]
- [TestRespondersDisposed]
- [InlineData (1)]
- [InlineData (2)]
- [InlineData (3)]
- public void LabelChangeText_RendersCorrectly_Constructors (int choice)
- {
- var driver = new FakeDriver ();
- Application.Init (driver);
- try
- {
- // Create a label with a short text
- Label lbl;
- var text = "test";
- if (choice == 1)
- {
- // An object initializer should call the default constructor.
- lbl = new Label { Text = text };
- }
- else if (choice == 2)
- {
- // Calling the default constructor followed by the object initializer.
- lbl = new Label { Text = text };
- }
- else
- {
- // Calling the Text constructor.
- lbl = new Label { Text = text };
- }
- Application.Top.Add (lbl);
- Application.Begin (Application.Top);
- // should have the initial text
- Assert.Equal ((Rune)'t', driver.Contents [0, 0].Rune);
- Assert.Equal ((Rune)'e', driver.Contents [0, 1].Rune);
- Assert.Equal ((Rune)'s', driver.Contents [0, 2].Rune);
- Assert.Equal ((Rune)'t', driver.Contents [0, 3].Rune);
- Assert.Equal ((Rune)' ', driver.Contents [0, 4].Rune);
- }
- finally
- {
- Application.Shutdown ();
- }
- }
- [Fact]
- [TestRespondersDisposed]
- public void New_Initializes ()
- {
- // Parameterless
- var r = new View ();
- Assert.NotNull (r);
- Assert.Equal (LayoutStyle.Absolute, r.LayoutStyle);
- Assert.Equal ("View()(0,0,0,0)", r.ToString ());
- Assert.False (r.CanFocus);
- Assert.False (r.HasFocus);
- Assert.Equal (new Rect (0, 0, 0, 0), r.Bounds);
- Assert.Equal (new Rect (0, 0, 0, 0), r.Frame);
- Assert.Null (r.Focused);
- Assert.Null (r.ColorScheme);
- Assert.Equal (0, r.Width);
- Assert.Equal (0, r.Height);
- Assert.Equal (0, r.X);
- Assert.Equal (0, r.Y);
- Assert.False (r.IsCurrentTop);
- Assert.Empty (r.Id);
- Assert.Empty (r.Subviews);
- Assert.False (r.WantContinuousButtonPressed);
- Assert.False (r.WantMousePositionReports);
- Assert.Null (r.SuperView);
- Assert.Null (r.MostFocused);
- Assert.Equal (TextDirection.LeftRight_TopBottom, r.TextDirection);
- r.Dispose ();
- // Empty Rect
- r = new View { Frame = Rect.Empty };
- Assert.NotNull (r);
- Assert.Equal (LayoutStyle.Absolute, r.LayoutStyle);
- Assert.Equal ("View()(0,0,0,0)", r.ToString ());
- Assert.False (r.CanFocus);
- Assert.False (r.HasFocus);
- Assert.Equal (new Rect (0, 0, 0, 0), r.Bounds);
- Assert.Equal (new Rect (0, 0, 0, 0), r.Frame);
- Assert.Null (r.Focused);
- Assert.Null (r.ColorScheme);
- Assert.Equal (0, r.Width);
- Assert.Equal (0, r.Height);
- Assert.Equal (0, r.X);
- Assert.Equal (0, r.Y);
- Assert.False (r.IsCurrentTop);
- Assert.Empty (r.Id);
- Assert.Empty (r.Subviews);
- Assert.False (r.WantContinuousButtonPressed);
- Assert.False (r.WantMousePositionReports);
- Assert.Null (r.SuperView);
- Assert.Null (r.MostFocused);
- Assert.Equal (TextDirection.LeftRight_TopBottom, r.TextDirection);
- r.Dispose ();
- // Rect with values
- r = new View { Frame = new Rect (1, 2, 3, 4) };
- Assert.NotNull (r);
- Assert.Equal (LayoutStyle.Absolute, r.LayoutStyle);
- Assert.Equal ("View()(1,2,3,4)", r.ToString ());
- Assert.False (r.CanFocus);
- Assert.False (r.HasFocus);
- Assert.Equal (new Rect (0, 0, 3, 4), r.Bounds);
- Assert.Equal (new Rect (1, 2, 3, 4), r.Frame);
- Assert.Null (r.Focused);
- Assert.Null (r.ColorScheme);
- Assert.Equal (3, r.Width);
- Assert.Equal (4, r.Height);
- Assert.Equal (1, r.X);
- Assert.Equal (2, r.Y);
- Assert.False (r.IsCurrentTop);
- Assert.Empty (r.Id);
- Assert.Empty (r.Subviews);
- Assert.False (r.WantContinuousButtonPressed);
- Assert.False (r.WantMousePositionReports);
- Assert.Null (r.SuperView);
- Assert.Null (r.MostFocused);
- Assert.Equal (TextDirection.LeftRight_TopBottom, r.TextDirection);
- r.Dispose ();
- // Initializes a view with a vertical direction
- r = new View
- {
- Text = "Vertical View", TextDirection = TextDirection.TopBottom_LeftRight, AutoSize = true
- }; // BUGBUG: AutoSize or Height need be set
- Assert.NotNull (r);
- Assert.Equal (LayoutStyle.Absolute, r.LayoutStyle);
- // BUGBUG: IsInitialized must be true to process calculation
- r.BeginInit ();
- r.EndInit ();
- #if DEBUG
- Assert.Equal ("View(Vertical View)(0,0,1,13)", r.ToString ());
- #else
- Assert.Equal ("View()(0,0,1,13)", r.ToString ());
- #endif
- Assert.False (r.CanFocus);
- Assert.False (r.HasFocus);
- Assert.Equal (new Rect (0, 0, 1, 13), r.Bounds);
- Assert.Equal (new Rect (0, 0, 1, 13), r.Frame);
- Assert.Null (r.Focused);
- Assert.Null (r.ColorScheme);
- Assert.False (r.IsCurrentTop);
- #if DEBUG
- Assert.Equal ("Vertical View", r.Id);
- #else
- Assert.Equal (string.Empty, r.Id);
- #endif
- Assert.Empty (r.Subviews);
- Assert.False (r.WantContinuousButtonPressed);
- Assert.False (r.WantMousePositionReports);
- Assert.Null (r.SuperView);
- Assert.Null (r.MostFocused);
- Assert.Equal (TextDirection.TopBottom_LeftRight, r.TextDirection);
- r.Dispose ();
- }
- [Fact]
- [TestRespondersDisposed]
- public void New_Methods_Return_False ()
- {
- var r = new View ();
- Assert.False (r.OnKeyDown (new Key { KeyCode = KeyCode.Null }));
- //Assert.False (r.OnKeyDown (new KeyEventArgs () { Key = Key.Unknown }));
- Assert.False (r.OnKeyUp (new Key { KeyCode = KeyCode.Null }));
- Assert.False (r.MouseEvent (new MouseEvent { Flags = MouseFlags.AllEvents }));
- Assert.False (r.OnMouseEnter (new MouseEvent { Flags = MouseFlags.AllEvents }));
- Assert.False (r.OnMouseLeave (new MouseEvent { Flags = MouseFlags.AllEvents }));
- var v1 = new View ();
- Assert.False (r.OnEnter (v1));
- v1.Dispose ();
- var v2 = new View ();
- Assert.False (r.OnLeave (v2));
- v2.Dispose ();
- r.Dispose ();
- // TODO: Add more
- }
- [Fact]
- [AutoInitShutdown]
- public void Test_Nested_Views_With_Height_Equal_To_One ()
- {
- var v = new View { Width = 11, Height = 3, ColorScheme = new ColorScheme () };
- var top = new View { Width = Dim.Fill (), Height = 1 };
- var bottom = new View { Width = Dim.Fill (), Height = 1, Y = 2 };
- top.Add (new Label { Text = "111" });
- v.Add (top);
- v.Add (new LineView (Orientation.Horizontal) { Y = 1 });
- bottom.Add (new Label { Text = "222" });
- v.Add (bottom);
- v.BeginInit ();
- v.EndInit ();
- v.LayoutSubviews ();
- v.Draw ();
- var looksLike =
- @"
- 111
- ───────────
- 222";
- TestHelpers.AssertDriverContentsAre (looksLike, _output);
- v.Dispose ();
- top.Dispose ();
- bottom.Dispose ();
- }
- [Fact]
- [TestRespondersDisposed]
- public void View_With_No_Difference_Between_An_Object_Initializer_Compute_And_A_Absolute ()
- {
- // Object Initializer Computed
- var view = new View { X = 1, Y = 2, Width = 3, Height = 4 };
- // Object Initializer Absolute
- var super = new View { Frame = new Rect (0, 0, 10, 10) };
- super.Add (view);
- super.BeginInit ();
- super.EndInit ();
- super.LayoutSubviews ();
- Assert.Equal (1, view.X);
- Assert.Equal (2, view.Y);
- Assert.Equal (3, view.Width);
- Assert.Equal (4, view.Height);
- Assert.False (view.Frame.IsEmpty);
- Assert.Equal (new Rect (1, 2, 3, 4), view.Frame);
- Assert.False (view.Bounds.IsEmpty);
- Assert.Equal (new Rect (0, 0, 3, 4), view.Bounds);
- view.LayoutSubviews ();
- Assert.Equal (1, view.X);
- Assert.Equal (2, view.Y);
- Assert.Equal (3, view.Width);
- Assert.Equal (4, view.Height);
- Assert.False (view.Frame.IsEmpty);
- Assert.False (view.Bounds.IsEmpty);
- super.Dispose ();
- #if DEBUG_IDISPOSABLE
- Assert.Empty (Responder.Instances);
- #endif
- // Default Constructor
- view = new View ();
- Assert.Equal (0, view.X);
- Assert.Equal (0, view.Y);
- Assert.Equal (0, view.Width);
- Assert.Equal (0, view.Height);
- Assert.True (view.Frame.IsEmpty);
- Assert.True (view.Bounds.IsEmpty);
- view.Dispose ();
- // Object Initializer
- view = new View { X = 1, Y = 2, Text = "" };
- Assert.Equal (1, view.X);
- Assert.Equal (2, view.Y);
- Assert.Equal (0, view.Width);
- Assert.Equal (0, view.Height);
- Assert.False (view.Frame.IsEmpty);
- Assert.True (view.Bounds.IsEmpty);
- view.Dispose ();
- // Default Constructor and post assignment equivalent to Object Initializer
- view = new View ();
- view.X = 1;
- view.Y = 2;
- view.Width = 3;
- view.Height = 4;
- super = new View { Frame = new Rect (0, 0, 10, 10) };
- super.Add (view);
- super.BeginInit ();
- super.EndInit ();
- super.LayoutSubviews ();
- Assert.Equal (1, view.X);
- Assert.Equal (2, view.Y);
- Assert.Equal (3, view.Width);
- Assert.Equal (4, view.Height);
- Assert.False (view.Frame.IsEmpty);
- Assert.Equal (new Rect (1, 2, 3, 4), view.Frame);
- Assert.False (view.Bounds.IsEmpty);
- Assert.Equal (new Rect (0, 0, 3, 4), view.Bounds);
- super.Dispose ();
- }
- [Fact]
- [AutoInitShutdown]
- public void Visible_Clear_The_View_Output ()
- {
- var view = new View { Text = "Testing visibility." }; // use View, not Label to avoid AutoSize == true
- // BUGBUG: AutoSize is false and size wasn't provided so it's 0,0
- Assert.Equal (0, view.Frame.Width);
- Assert.Equal (0, view.Height);
- var win = new Window ();
- win.Add (view);
- Toplevel top = Application.Top;
- top.Add (win);
- RunState rs = Application.Begin (top);
- view.AutoSize = true;
- Assert.Equal ("Testing visibility.".Length, view.Frame.Width);
- Assert.True (view.Visible);
- ((FakeDriver)Application.Driver).SetBufferSize (30, 5);
- TestHelpers.AssertDriverContentsWithFrameAre (
- @"
- ┌────────────────────────────┐
- │Testing visibility. │
- │ │
- │ │
- └────────────────────────────┘
- ",
- _output
- );
- view.Visible = false;
- var firstIteration = false;
- Application.RunIteration (ref rs, ref firstIteration);
- TestHelpers.AssertDriverContentsWithFrameAre (
- @"
- ┌────────────────────────────┐
- │ │
- │ │
- │ │
- └────────────────────────────┘
- ",
- _output
- );
- Application.End (rs);
- }
- [Fact]
- [AutoInitShutdown]
- public void Visible_Sets_Also_Sets_Subviews ()
- {
- var button = new Button { Text = "Click Me" };
- var win = new Window { Width = Dim.Fill (), Height = Dim.Fill () };
- win.Add (button);
- Toplevel top = Application.Top;
- top.Add (win);
- var iterations = 0;
- Application.Iteration += (s, a) =>
- {
- iterations++;
- Assert.True (button.Visible);
- Assert.True (button.CanFocus);
- Assert.True (button.HasFocus);
- Assert.True (win.Visible);
- Assert.True (win.CanFocus);
- Assert.True (win.HasFocus);
- Assert.True (RunesCount () > 0);
- win.Visible = false;
- Assert.True (button.Visible);
- Assert.True (button.CanFocus);
- Assert.False (button.HasFocus);
- Assert.False (win.Visible);
- Assert.True (win.CanFocus);
- Assert.False (win.HasFocus);
- button.SetFocus ();
- Assert.False (button.HasFocus);
- Assert.False (win.HasFocus);
- win.SetFocus ();
- Assert.False (button.HasFocus);
- Assert.False (win.HasFocus);
- top.Draw ();
- Assert.True (RunesCount () == 0);
- win.Visible = true;
- win.FocusFirst ();
- Assert.True (button.HasFocus);
- Assert.True (win.HasFocus);
- top.Draw ();
- Assert.True (RunesCount () > 0);
- Application.RequestStop ();
- };
- Application.Run ();
- Assert.Equal (1, iterations);
- int RunesCount ()
- {
- Cell [,] contents = ((FakeDriver)Application.Driver).Contents;
- var runesCount = 0;
- for (var i = 0; i < Application.Driver.Rows; i++)
- {
- for (var j = 0; j < Application.Driver.Cols; j++)
- {
- if (contents [i, j].Rune != (Rune)' ')
- {
- runesCount++;
- }
- }
- }
- return runesCount;
- }
- }
- public class DerivedView : View
- {
- public DerivedView () { CanFocus = true; }
- public bool IsKeyDown { get; set; }
- public bool IsKeyPress { get; set; }
- public bool IsKeyUp { get; set; }
- public override string Text { get; set; }
- public override void OnDrawContent (Rect contentArea)
- {
- var idx = 0;
- // BUGBUG: v2 - this should use Bounds, not Frame
- for (var r = 0; r < Frame.Height; r++)
- {
- for (var c = 0; c < Frame.Width; c++)
- {
- if (idx < Text.Length)
- {
- char rune = Text [idx];
- if (rune != '\n')
- {
- AddRune (c, r, (Rune)Text [idx]);
- }
- idx++;
- if (rune == '\n')
- {
- break;
- }
- }
- }
- }
- ClearLayoutNeeded ();
- ClearNeedsDisplay ();
- }
- public override bool OnKeyDown (Key keyEvent)
- {
- IsKeyDown = true;
- return true;
- }
- public override bool OnKeyUp (Key keyEvent)
- {
- IsKeyUp = true;
- return true;
- }
- public override bool OnProcessKeyDown (Key keyEvent)
- {
- IsKeyPress = true;
- return true;
- }
- }
- }
|