From d17a3b92b41c4cb909b7c4fba346aa97b4806499 Mon Sep 17 00:00:00 2001 From: Michael Render Date: Mon, 2 Dec 2024 17:37:23 -0500 Subject: [PATCH 1/2] [dotnet] Annotate nullable reference types on `ActionBuilder` --- .../webdriver/Interactions/ActionBuilder.cs | 34 ++++++++++++++----- 1 file changed, 25 insertions(+), 9 deletions(-) diff --git a/dotnet/src/webdriver/Interactions/ActionBuilder.cs b/dotnet/src/webdriver/Interactions/ActionBuilder.cs index 077678605d346..cf7383fad9f3e 100644 --- a/dotnet/src/webdriver/Interactions/ActionBuilder.cs +++ b/dotnet/src/webdriver/Interactions/ActionBuilder.cs @@ -21,6 +21,8 @@ using System.Collections.Generic; using System.Text; +#nullable enable + namespace OpenQA.Selenium.Interactions { /// @@ -29,7 +31,7 @@ namespace OpenQA.Selenium.Interactions /// public class ActionBuilder { - private Dictionary sequences = new Dictionary(); + private readonly Dictionary sequences = new Dictionary(); /// /// Adds an action to the built set of actions. Adding an action will @@ -39,7 +41,7 @@ public class ActionBuilder /// A self reference. public ActionBuilder AddAction(Interaction actionToAdd) { - this.AddActions(actionToAdd); + this.ProcessTick(actionToAdd); return this; } @@ -71,7 +73,7 @@ public IList ToActionSequenceList() /// public void ClearSequences() { - this.sequences = new Dictionary(); + this.sequences.Clear(); } /// @@ -89,13 +91,26 @@ public override string ToString() return builder.ToString(); } + private void ProcessTick(Interaction interaction) + { + ActionSequence sequence = this.GetOrAddSequence(interaction.SourceDevice); + sequence.AddAction(interaction); + + foreach (KeyValuePair pair in this.sequences) + { + if (pair.Key != interaction.SourceDevice) + { + pair.Value.AddAction(new PauseInteraction(pair.Key, TimeSpan.Zero)); + } + } + } + private void ProcessTick(params Interaction[] interactionsToAdd) { List usedDevices = new List(); foreach (Interaction interaction in interactionsToAdd) { - InputDevice actionDevice = interaction.SourceDevice; - if (usedDevices.Contains(actionDevice)) + if (usedDevices.Contains(interaction.SourceDevice)) { throw new ArgumentException("You can only add one action per device for a single tick."); } @@ -104,8 +119,9 @@ private void ProcessTick(params Interaction[] interactionsToAdd) List unusedDevices = new List(this.sequences.Keys); foreach (Interaction interaction in interactionsToAdd) { - ActionSequence sequence = this.FindSequence(interaction.SourceDevice); + ActionSequence sequence = this.GetOrAddSequence(interaction.SourceDevice); sequence.AddAction(interaction); + unusedDevices.Remove(interaction.SourceDevice); } @@ -116,11 +132,11 @@ private void ProcessTick(params Interaction[] interactionsToAdd) } } - private ActionSequence FindSequence(InputDevice device) + private ActionSequence GetOrAddSequence(InputDevice device) { - if (this.sequences.ContainsKey(device)) + if (this.sequences.TryGetValue(device, out ActionSequence? existingSequence)) { - return this.sequences[device]; + return existingSequence; } int longestSequenceLength = 0; From e09ef7fd785334991cd920b972ba86295c19d719 Mon Sep 17 00:00:00 2001 From: Michael Render Date: Sun, 8 Dec 2024 01:17:18 -0500 Subject: [PATCH 2/2] remove unnecessary changes from `ActionBuilder` --- .../src/webdriver/Interactions/ActionBuilder.cs | 16 +--------------- 1 file changed, 1 insertion(+), 15 deletions(-) diff --git a/dotnet/src/webdriver/Interactions/ActionBuilder.cs b/dotnet/src/webdriver/Interactions/ActionBuilder.cs index cf7383fad9f3e..de9ce42a66af4 100644 --- a/dotnet/src/webdriver/Interactions/ActionBuilder.cs +++ b/dotnet/src/webdriver/Interactions/ActionBuilder.cs @@ -41,7 +41,7 @@ public class ActionBuilder /// A self reference. public ActionBuilder AddAction(Interaction actionToAdd) { - this.ProcessTick(actionToAdd); + this.AddActions(actionToAdd); return this; } @@ -91,20 +91,6 @@ public override string ToString() return builder.ToString(); } - private void ProcessTick(Interaction interaction) - { - ActionSequence sequence = this.GetOrAddSequence(interaction.SourceDevice); - sequence.AddAction(interaction); - - foreach (KeyValuePair pair in this.sequences) - { - if (pair.Key != interaction.SourceDevice) - { - pair.Value.AddAction(new PauseInteraction(pair.Key, TimeSpan.Zero)); - } - } - } - private void ProcessTick(params Interaction[] interactionsToAdd) { List usedDevices = new List();