123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382 |
- using Terminal.Gui.EnumExtensions;
- using Xunit.Abstractions;
- namespace Terminal.Gui.InputTests;
- public class KeyBindingTests
- {
- public KeyBindingTests (ITestOutputHelper output) { _output = output; }
- private readonly ITestOutputHelper _output;
- [Fact]
- public void Add_Invalid_Key_Throws ()
- {
- var keyBindings = new KeyBindings (new View ());
- List<Command> commands = new ();
- Assert.Throws<ArgumentException> (() => keyBindings.Add (Key.Empty, KeyBindingScope.HotKey, Command.Accept));
- }
- [Fact]
- public void Add_BoundView_Null_Non_AppScope_Throws ()
- {
- var keyBindings = new KeyBindings ();
- List<Command> commands = new ();
- Assert.Throws<InvalidOperationException> (() => keyBindings.Add (Key.Empty, KeyBindingScope.HotKey, Command.Accept));
- }
- [Fact]
- public void Add_Multiple_Adds ()
- {
- var keyBindings = new KeyBindings ();
- Command [] commands = { Command.Right, Command.Left };
- keyBindings.Add (Key.A, KeyBindingScope.Application, commands);
- Command [] resultCommands = keyBindings.GetCommands (Key.A);
- Assert.Contains (Command.Right, resultCommands);
- Assert.Contains (Command.Left, resultCommands);
- keyBindings.Add (Key.B, KeyBindingScope.Application, commands);
- resultCommands = keyBindings.GetCommands (Key.B);
- Assert.Contains (Command.Right, resultCommands);
- Assert.Contains (Command.Left, resultCommands);
- }
- [Fact]
- public void Add_No_Commands_Throws ()
- {
- var keyBindings = new KeyBindings ();
- List<Command> commands = new ();
- Assert.Throws<ArgumentException> (() => keyBindings.Add (Key.A, commands.ToArray ()));
- }
- [Fact]
- public void Add_Single_Adds ()
- {
- var keyBindings = new KeyBindings ();
- keyBindings.Add (Key.A, KeyBindingScope.Application, Command.HotKey);
- Command [] resultCommands = keyBindings.GetCommands (Key.A);
- Assert.Contains (Command.HotKey, resultCommands);
- keyBindings.Add (Key.B, KeyBindingScope.Application, Command.HotKey);
- resultCommands = keyBindings.GetCommands (Key.B);
- Assert.Contains (Command.HotKey, resultCommands);
- }
- // Add should not allow duplicates
- [Fact]
- public void Add_With_Bound_View_Throws_If_App_Scope ()
- {
- var keyBindings = new KeyBindings (new View ());
- Assert.Throws<InvalidOperationException> (() => keyBindings.Add (Key.A, KeyBindingScope.Application, Command.Accept));
- }
- // Add should not allow duplicates
- [Fact]
- public void Add_With_Throws_If_Exists ()
- {
- var keyBindings = new KeyBindings (new View ());
- keyBindings.Add (Key.A, KeyBindingScope.HotKey, Command.HotKey);
- Assert.Throws<InvalidOperationException> (() => keyBindings.Add (Key.A, KeyBindingScope.HotKey, Command.Accept));
- Command [] resultCommands = keyBindings.GetCommands (Key.A);
- Assert.Contains (Command.HotKey, resultCommands);
- keyBindings = new (new View ());
- keyBindings.Add (Key.A, KeyBindingScope.Focused, Command.HotKey);
- Assert.Throws<InvalidOperationException> (() => keyBindings.Add (Key.A, KeyBindingScope.Focused, Command.Accept));
- resultCommands = keyBindings.GetCommands (Key.A);
- Assert.Contains (Command.HotKey, resultCommands);
- keyBindings = new (new View ());
- keyBindings.Add (Key.A, KeyBindingScope.HotKey, Command.HotKey);
- Assert.Throws<InvalidOperationException> (() => keyBindings.Add (Key.A, KeyBindingScope.HotKey, Command.Accept));
- resultCommands = keyBindings.GetCommands (Key.A);
- Assert.Contains (Command.HotKey, resultCommands);
- keyBindings = new (new View ());
- keyBindings.Add (Key.A, new KeyBinding (new [] { Command.HotKey }, KeyBindingScope.HotKey));
- Assert.Throws<InvalidOperationException> (() => keyBindings.Add (Key.A, new KeyBinding (new [] { Command.Accept }, KeyBindingScope.HotKey)));
- resultCommands = keyBindings.GetCommands (Key.A);
- Assert.Contains (Command.HotKey, resultCommands);
- }
- // Clear
- [Fact]
- public void Clear_Clears ()
- {
- var keyBindings = new KeyBindings ();
- keyBindings.Add (Key.B, KeyBindingScope.Application, Command.HotKey);
- keyBindings.Clear ();
- Command [] resultCommands = keyBindings.GetCommands (Key.A);
- Assert.Empty (resultCommands);
- resultCommands = keyBindings.GetCommands (Key.B);
- Assert.Empty (resultCommands);
- }
- [Fact]
- public void Defaults ()
- {
- var keyBindings = new KeyBindings ();
- Assert.Empty (keyBindings.Bindings);
- Assert.Null (keyBindings.GetKeyFromCommands (Command.Accept));
- Assert.Null (keyBindings.BoundView);
- }
- [Fact]
- public void Get_Binding_Not_Found_Throws ()
- {
- var keyBindings = new KeyBindings ();
- Assert.Throws<InvalidOperationException> (() => keyBindings.Get (Key.A));
- Assert.Throws<InvalidOperationException> (() => keyBindings.Get (Key.B, KeyBindingScope.Application));
- }
- // GetCommands
- [Fact]
- public void GetCommands_Unknown_ReturnsEmpty ()
- {
- var keyBindings = new KeyBindings ();
- Command [] resultCommands = keyBindings.GetCommands (Key.A);
- Assert.Empty (resultCommands);
- }
- [Fact]
- public void GetCommands_WithCommands_ReturnsCommands ()
- {
- var keyBindings = new KeyBindings ();
- keyBindings.Add (Key.A, KeyBindingScope.Application, Command.HotKey);
- Command [] resultCommands = keyBindings.GetCommands (Key.A);
- Assert.Contains (Command.HotKey, resultCommands);
- }
- [Fact]
- public void GetCommands_WithMultipleBindings_ReturnsCommands ()
- {
- var keyBindings = new KeyBindings ();
- Command [] commands = { Command.Right, Command.Left };
- keyBindings.Add (Key.A, KeyBindingScope.Application, commands);
- keyBindings.Add (Key.B, KeyBindingScope.Application, commands);
- Command [] resultCommands = keyBindings.GetCommands (Key.A);
- Assert.Contains (Command.Right, resultCommands);
- Assert.Contains (Command.Left, resultCommands);
- resultCommands = keyBindings.GetCommands (Key.B);
- Assert.Contains (Command.Right, resultCommands);
- Assert.Contains (Command.Left, resultCommands);
- }
- [Fact]
- public void GetCommands_WithMultipleCommands_ReturnsCommands ()
- {
- var keyBindings = new KeyBindings ();
- Command [] commands = { Command.Right, Command.Left };
- keyBindings.Add (Key.A, KeyBindingScope.Application, commands);
- Command [] resultCommands = keyBindings.GetCommands (Key.A);
- Assert.Contains (Command.Right, resultCommands);
- Assert.Contains (Command.Left, resultCommands);
- }
- [Fact]
- public void GetKeyFromCommands_MultipleCommands ()
- {
- var keyBindings = new KeyBindings ();
- Command [] commands1 = { Command.Right, Command.Left };
- keyBindings.Add (Key.A, KeyBindingScope.Application, commands1);
- Command [] commands2 = { Command.Up, Command.Down };
- keyBindings.Add (Key.B, KeyBindingScope.Application, commands2);
- Key key = keyBindings.GetKeyFromCommands (commands1);
- Assert.Equal (Key.A, key);
- key = keyBindings.GetKeyFromCommands (commands2);
- Assert.Equal (Key.B, key);
- }
- [Fact]
- public void GetKeyFromCommands_OneCommand ()
- {
- var keyBindings = new KeyBindings ();
- keyBindings.Add (Key.A, KeyBindingScope.Application, Command.Right);
- Key key = keyBindings.GetKeyFromCommands (Command.Right);
- Assert.Equal (Key.A, key);
- }
- // GetKeyFromCommands
- [Fact]
- public void GetKeyFromCommands_Unknown_Returns_Key_Empty ()
- {
- var keyBindings = new KeyBindings ();
- Assert.Null (keyBindings.GetKeyFromCommands (Command.Accept));
- }
- [Fact]
- public void GetKeyFromCommands_WithCommands_ReturnsKey ()
- {
- var keyBindings = new KeyBindings ();
- keyBindings.Add (Key.A, KeyBindingScope.Application, Command.HotKey);
- Key resultKey = keyBindings.GetKeyFromCommands (Command.HotKey);
- Assert.Equal (Key.A, resultKey);
- }
- [Fact]
- public void ReplaceKey_Replaces ()
- {
- var keyBindings = new KeyBindings (new ());
- keyBindings.Add (Key.A, KeyBindingScope.Focused, Command.HotKey);
- keyBindings.Add (Key.B, KeyBindingScope.Focused, Command.HotKey);
- keyBindings.Add (Key.C, KeyBindingScope.Focused, Command.HotKey);
- keyBindings.Add (Key.D, KeyBindingScope.Focused, Command.HotKey);
- keyBindings.ReplaceKey (Key.A, Key.E);
- Assert.Empty (keyBindings.GetCommands (Key.A));
- Assert.Contains (Command.HotKey, keyBindings.GetCommands (Key.E));
- keyBindings.ReplaceKey (Key.B, Key.F);
- Assert.Empty (keyBindings.GetCommands (Key.B));
- Assert.Contains (Command.HotKey, keyBindings.GetCommands (Key.F));
- keyBindings.ReplaceKey (Key.C, Key.G);
- Assert.Empty (keyBindings.GetCommands (Key.C));
- Assert.Contains (Command.HotKey, keyBindings.GetCommands (Key.G));
- keyBindings.ReplaceKey (Key.D, Key.H);
- Assert.Empty (keyBindings.GetCommands (Key.D));
- Assert.Contains (Command.HotKey, keyBindings.GetCommands (Key.H));
- }
- [Fact]
- public void ReplaceKey_Replaces_Leaves_Old_Binding ()
- {
- var keyBindings = new KeyBindings (new ());
- keyBindings.Add (Key.A, KeyBindingScope.Focused, Command.Accept);
- keyBindings.Add (Key.B, KeyBindingScope.Focused, Command.HotKey);
- keyBindings.ReplaceKey (keyBindings.GetKeyFromCommands (Command.Accept), Key.C);
- Assert.Empty (keyBindings.GetCommands (Key.A));
- Assert.Contains (Command.Accept, keyBindings.GetCommands (Key.C));
- }
- [Fact]
- public void ReplaceKey_Throws_If_DoesNotContain_Old ()
- {
- var keyBindings = new KeyBindings ();
- Assert.Throws<InvalidOperationException> (() => keyBindings.ReplaceKey (Key.A, Key.B));
- }
- [Fact]
- public void ReplaceKey_Throws_If_New_Is_Empty ()
- {
- var keyBindings = new KeyBindings ();
- keyBindings.Add (Key.A, KeyBindingScope.Application, Command.HotKey);
- Assert.Throws<InvalidOperationException> (() => keyBindings.ReplaceKey (Key.A, Key.Empty));
- }
- // Add with scope does the right things
- [Theory]
- [InlineData (KeyBindingScope.Focused)]
- [InlineData (KeyBindingScope.HotKey)]
- [InlineData (KeyBindingScope.Application)]
- public void Scope_Add_Adds (KeyBindingScope scope)
- {
- var keyBindings = new KeyBindings (scope.FastHasFlags(KeyBindingScope.Application) ? null : new ());
- Command [] commands = { Command.Right, Command.Left };
- var key = new Key (Key.A);
- keyBindings.Add (Key.A, scope, commands);
- KeyBinding binding = keyBindings.Get (key);
- Assert.Contains (Command.Right, binding.Commands);
- Assert.Contains (Command.Left, binding.Commands);
- binding = keyBindings.Get (key, scope);
- Assert.Contains (Command.Right, binding.Commands);
- Assert.Contains (Command.Left, binding.Commands);
- Command [] resultCommands = keyBindings.GetCommands (key);
- Assert.Contains (Command.Right, resultCommands);
- Assert.Contains (Command.Left, resultCommands);
- }
- [Theory]
- [InlineData (KeyBindingScope.Focused)]
- [InlineData (KeyBindingScope.HotKey)]
- [InlineData (KeyBindingScope.Application)]
- public void Scope_Get_Filters (KeyBindingScope scope)
- {
- var keyBindings = new KeyBindings (scope.FastHasFlags (KeyBindingScope.Application) ? null : new ());
- Command [] commands = { Command.Right, Command.Left };
- var key = new Key (Key.A);
- keyBindings.Add (key, scope, commands);
- KeyBinding binding = keyBindings.Get (key);
- Assert.Contains (Command.Right, binding.Commands);
- Assert.Contains (Command.Left, binding.Commands);
- binding = keyBindings.Get (key, scope);
- Assert.Contains (Command.Right, binding.Commands);
- Assert.Contains (Command.Left, binding.Commands);
- }
- [Theory]
- [InlineData (KeyBindingScope.Focused)]
- [InlineData (KeyBindingScope.HotKey)]
- [InlineData (KeyBindingScope.Application)]
- public void Scope_TryGet_Filters (KeyBindingScope scope)
- {
- var keyBindings = new KeyBindings (scope.FastHasFlags (KeyBindingScope.Application) ? null : new ());
- Command [] commands = { Command.Right, Command.Left };
- var key = new Key (Key.A);
- keyBindings.Add (key, scope, commands);
- bool success = keyBindings.TryGet (key, out KeyBinding binding);
- Assert.Contains (Command.Right, binding.Commands);
- Assert.Contains (Command.Left, binding.Commands);
- success = keyBindings.TryGet (key, scope, out binding);
- Assert.Contains (Command.Right, binding.Commands);
- Assert.Contains (Command.Left, binding.Commands);
- // negative test
- success = keyBindings.TryGet (key, 0, out binding);
- Assert.False (success);
- Command [] resultCommands = keyBindings.GetCommands (key);
- Assert.Contains (Command.Right, resultCommands);
- Assert.Contains (Command.Left, resultCommands);
- }
- // TryGet
- [Fact]
- public void TryGet_Succeeds ()
- {
- var keyBindings = new KeyBindings ();
- keyBindings.Add (Key.Q.WithCtrl, KeyBindingScope.Application, Command.HotKey);
- var key = new Key (Key.Q.WithCtrl);
- bool result = keyBindings.TryGet (key, out KeyBinding _);
- Assert.True (result);;
- result = keyBindings.Bindings.TryGetValue (key, out KeyBinding _);
- Assert.True (result);
- }
- [Fact]
- public void TryGet_Unknown_ReturnsFalse ()
- {
- var keyBindings = new KeyBindings ();
- bool result = keyBindings.TryGet (Key.A, out KeyBinding _);
- Assert.False (result);
- }
- [Fact]
- public void TryGet_WithCommands_ReturnsTrue ()
- {
- var keyBindings = new KeyBindings ();
- keyBindings.Add (Key.A, KeyBindingScope.Application, Command.HotKey);
- bool result = keyBindings.TryGet (Key.A, out KeyBinding bindings);
- Assert.True (result);
- Assert.Contains (Command.HotKey, bindings.Commands);
- }
- }
|