123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233 |
- using Xunit.Abstractions;
- namespace Terminal.Gui.ViewTests;
- public class HasFocusTests (ITestOutputHelper _output) : TestsAllViews
- {
- [Fact]
- public void HasFocus_False ()
- {
- var view = new View ()
- {
- Id = "view",
- CanFocus = true
- };
- view.SetFocus ();
- Assert.True (view.HasFocus);
- view.HasFocus = false;
- Assert.False (view.HasFocus);
- }
- [Fact]
- public void HasFocus_False_WithSuperView_Does_Not_Change_SuperView ()
- {
- var view = new View ()
- {
- Id = "view",
- CanFocus = true
- };
- var subview = new View ()
- {
- Id = "subview",
- CanFocus = true
- };
- view.Add (subview);
- view.SetFocus ();
- Assert.True (view.HasFocus);
- Assert.True (subview.HasFocus);
- subview.HasFocus = false;
- Assert.False (subview.HasFocus);
- Assert.True (view.HasFocus);
- }
- [Fact]
- public void HasFocus_False_WithSubview_Leaves_All ()
- {
- var view = new View ()
- {
- Id = "view",
- CanFocus = true
- };
- var subview = new View ()
- {
- Id = "subview",
- CanFocus = true
- };
- view.Add (subview);
- view.SetFocus ();
- Assert.True (view.HasFocus);
- Assert.True (subview.HasFocus);
- Assert.Equal (subview, view.Focused);
- view.HasFocus = false;
- Assert.Null (view.Focused);
- Assert.False (view.HasFocus);
- Assert.False (subview.HasFocus);
- }
- [Fact]
- public void Enabled_False_Sets_HasFocus_To_False ()
- {
- var wasClicked = false;
- var view = new Button { Text = "Click Me" };
- view.Accept += (s, e) => wasClicked = !wasClicked;
- view.NewKeyDownEvent (Key.Space);
- Assert.True (wasClicked);
- view.NewMouseEvent (new () { Flags = MouseFlags.Button1Clicked });
- Assert.False (wasClicked);
- Assert.True (view.Enabled);
- Assert.True (view.CanFocus);
- Assert.True (view.HasFocus);
- view.Enabled = false;
- view.NewKeyDownEvent (Key.Space);
- Assert.False (wasClicked);
- view.NewMouseEvent (new () { Flags = MouseFlags.Button1Clicked });
- Assert.False (wasClicked);
- Assert.False (view.Enabled);
- Assert.True (view.CanFocus);
- Assert.False (view.HasFocus);
- view.SetFocus ();
- Assert.False (view.HasFocus);
- }
- [Fact]
- public void HasFocus_False_CompoundSubView_Leaves_All ()
- {
- var view = new View ()
- {
- Id = "view",
- CanFocus = true
- };
- var subView = new View ()
- {
- Id = "subView",
- CanFocus = true
- };
- var subViewSubView1 = new View ()
- {
- Id = "subViewSubView1",
- CanFocus = false
- };
- var subViewSubView2 = new View ()
- {
- Id = "subViewSubView2",
- CanFocus = true
- };
- var subViewSubView3 = new View ()
- {
- Id = "subViewSubView3",
- CanFocus = false
- };
- subView.Add (subViewSubView1, subViewSubView2, subViewSubView3);
- view.Add (subView);
- view.SetFocus ();
- Assert.True (view.HasFocus);
- Assert.True (subView.HasFocus);
- Assert.False (subViewSubView1.HasFocus);
- Assert.True (subViewSubView2.HasFocus);
- Assert.False (subViewSubView3.HasFocus);
- view.HasFocus = false;
- Assert.False (view.HasFocus);
- Assert.False (subView.HasFocus);
- Assert.False (subViewSubView1.HasFocus);
- Assert.False (subViewSubView2.HasFocus);
- Assert.False (subViewSubView3.HasFocus);
- }
- [Fact]
- public void HasFocus_False_Subview_Raises_HasFocusChanged ()
- {
- var top = new View
- {
- Id = "top",
- CanFocus = true
- };
- var subView1 = new View
- {
- Id = "subView1",
- CanFocus = true
- };
- var subView2 = new View
- {
- Id = "subView2",
- CanFocus = true
- };
- top.Add (subView1, subView2);
- var subView1HasFocusChangedTrueCount = 0;
- var subView1HasFocusChangedFalseCount = 0;
- subView1.HasFocusChanged += (s, e) =>
- {
- if (e.NewValue)
- {
- subView1HasFocusChangedTrueCount++;
- }
- else
- {
- subView1HasFocusChangedFalseCount++;
- }
- };
- var subView2HasFocusChangedTrueCount = 0;
- var subView2HasFocusChangedFalseCount = 0;
- subView2.HasFocusChanged += (s, e) =>
- {
- if (e.NewValue)
- {
- subView2HasFocusChangedTrueCount++;
- }
- else
- {
- subView2HasFocusChangedFalseCount++;
- }
- };
- top.SetFocus ();
- Assert.True (top.HasFocus);
- Assert.True (subView1.HasFocus);
- Assert.False (subView2.HasFocus);
- Assert.Equal (1, subView1HasFocusChangedTrueCount);
- Assert.Equal (0, subView1HasFocusChangedFalseCount);
- Assert.Equal (0, subView2HasFocusChangedTrueCount);
- Assert.Equal (0, subView2HasFocusChangedFalseCount);
- subView1.HasFocus = false; // this should have the same resuilt as top.AdvanceFocus (NavigationDirection.Forward, null);
- Assert.False (subView1.HasFocus);
- Assert.True (subView2.HasFocus);
- Assert.Equal (1, subView1HasFocusChangedTrueCount);
- Assert.Equal (1, subView1HasFocusChangedFalseCount);
- Assert.Equal (1, subView2HasFocusChangedTrueCount);
- Assert.Equal (0, subView2HasFocusChangedFalseCount);
- }
- }
|